C# 动态组合SQL脚本LIKE语句及查询参数防SQL注入攻击


  C# 动态组合SQL脚本LIKE语句及查询参数防SQL注入攻击C# 动态组合SQL脚本LIKE语句及查询参数防SQL注入攻击



动态组合SQL脚本的多个LIKE条件,并要求传入SQL参数防止SQL注入攻击。


贴图图片-动态组合SQL脚本LIKE语句查询参数



动态组合的SQL脚本:


贴图图片-动态组合SQL脚本LIKE语句查询参数1(1)



参考代码1:


C# Code:


public DataTable Search(String DocType, String DeptID, String FileCaption, String DocKind)
{
  
//构建CommandHelper实例,用于动态创建参数对象
  
CommandHelper cmd = _Database.CreateCommand("");
  
  StringBuilder sb
= new StringBuilder();
  sb.Append(
"SELECT * FROM dt_doc WHERE 1=1 ");
  
  
if (!String.IsNullOrEmpty(DocType))
  {
    sb.Append($
" AND DocType LIKE {_Database.ParamSymboName}DocType");//拼接SQL参数
    
cmd.AddParam("DocType", "%" + DocType + "%");// 添加SQL参数对象,组合LIKE条件的值
    
}
    
    
if (!String.IsNullOrEmpty(DeptID))
    {
      sb.Append($
" AND DeptID LIKE {_Database.ParamSymboName}DeptID");
      cmd.AddParam(
"DeptID", "%" + DeptID + "%");
    }
    
    
if (!String.IsNullOrEmpty(FileCaption))
    {
      sb.Append($
" AND FileCaption LIKE {_Database.ParamSymboName}FileCaption");
      cmd.AddParam(
"FileCaption", "%" + FileCaption + "%");
    }
    
    
//数字类型
    
if (!String.IsNullOrEmpty(DocKind))
    {
      sb.Append($
" AND DocKind = {_Database.ParamSymboName}DocKind");
      cmd.AddParam(
"DocKind", DocKind);
    }
    
    sb.Append(
" ORDER BY " + dt_Doc.__KeyName);
    
    
//给DbCommand绑定SQL脚本
    
DbCommand command = cmd.Command;
    command.CommandText
= sb.ToString();
    
    
//调用IDatabase底层组件的方法
    
return _Database.GetTable(command, dt_Doc.__TableName);
  }
  
  
//来源:C/S框架网 | www.csframework.com | QQ:23404761




参考代码2:



C# Code:

public DataTable Search(string content)
{
  
string sql = "SELECT * FROM tb_MyUser ";
  
  CommandHelper cmd
= _Database.CreateCommand("");
  
if (!string.IsNullOrEmpty(content))
  {
    sql
= sql + $" WHERE Account LIKE {_Database.ParamSymboName}Account OR UserName LIKE {_Database.ParamSymboName}UserName ";
    cmd.AddParam(
"Account", "%" + content + "%");
    cmd.AddParam(
"UserName", "%" + content + "%");
  }
  
  cmd.Command.CommandText
= sql;
  
  DataTable dt
= _Database.GetTable(cmd.Command, tb_MyUser.__TableName);
  
return dt;
}

//来源:C/S框架网 | www.csframework.com | QQ:23404761




C/S框架网|原创精神.创造价值.打造精品


扫一扫加作者微信
C/S框架网作者微信 C/S框架网|原创作品.质量保障.竭诚为您服务

版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:生成的项目模块(Project)添加到VS解决方案 - C/S框架三层架构代码生成器操作指南
下一篇:C# FieldFitString类:将资料表(DataTable)已修改的资料行数据去左右空格、全角转半角
评论列表

发表评论

评论内容
昵称:
关联文章

C# 动态组合SQL脚本LIKE语句查询参数SQL注入攻击
C# 检查字符串,SQL注入攻击
SQL注入攻击的原理及其防范措施
SQL注入攻击一日通
C#SQL注入攻击检查类SQLInjection
[原创]C# Access 模糊查询SQL语句
SQL注入漏洞全接触--高级篇
SQL注入漏洞全接触--进阶篇
SQL2008多个查询条件分页查询脚本(原创)
SQL注入漏洞全接触--入门篇
SQL使用LIKE查询模糊匹配多个特殊标点符号的数据
SQL Server应用程序中的高级SQL注入
C#实现SQL查询分析器(C# Visual SQL Query Designer)
C# 动态编译调用WebService的方法
提交数据时生成的SQL脚本便于实时跟踪
SQL递归获取当前类别所有子类别,用于按类型查询
动态SQL生成器(Dynamic SQL Generator)
WebApi接口安全之用户认证篡改数字签名(Data Sign)机制
C# continue语句
C# break语句