Как безопасно параметризировать имена таблиц в C#, чтобы предотвратить инъекцию SQL?C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Как безопасно параметризировать имена таблиц в C#, чтобы предотвратить инъекцию SQL?

Сообщение Anonymous »

Я использую Dapper в своем проекте и хочу передать имя таблицы в качестве динамического параметра в запросе.
Это мой код: < /p>
var tableName = GetTableNameDynamically();
using (var builder = new SqlCommandBuilder())
{
tableName = builder.QuoteIdentifier(tableName);
}
string qry = $"select case when exists(select 1 from "+ tableName +" where Id = @Id) then 1 else 0 end";
return await sqlConnection.QuerySingleAsync(qry, new { Id = id }, sqlTransaction);
< /code>
Когда я запускаю сканер Sonarqube, я получил такую ​​ошибку, подобную этой
, убедитесь, что использование динамически отформатированного SQL -запроса здесь безопасно. »
Как его исправить? Я не могу использовать хранимые процедуры.
Спасибо!

Подробнее здесь: https://stackoverflow.com/questions/794 ... -injection
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»