C#参数化(防止SQL注入)

摘要:
select*fromuserwhereid=@idandpwd=@pwd:*SqlDataAdapterdat=newSqlDataAdapter(sql;SqlParameterid=newSqlParameter(“@id”);SqlParameterpwd=newSqlParameter(“pwd”;//dat.SelectCommand.Parameters.Add(id);
C#参数化(防止SQL注入)

2018年08月08日 16:12:43 One_Piece_Fu 阅读数 968更多

分类专栏: C#

转:https://blog.csdn.net/lsuwen/article/details/53224945

/*
* C#防止SQL注入式攻击
* Author:ICE FROG
* TIME:2016/4/20
*/

/*
* SQL注入式攻击就是值通过SQL执行语句的漏洞进行百分百匹配条件的攻击
* 那么在执行语句的where语句后面的条件就永远为true
*
* C#在数据库的这一块漏洞上添加了一个类来处理这个问题:
* SqlParameter - using System.Data.SqlClient;
* 原理就是让where条件后面字段不和整个执行语句化为一个字符串,而是以通过一个参数的形式传递进去
* 这样可以达到两个效果:
* 第一就是避免注入式攻击
* 第二就是防止非法字符导致软件崩溃
* 那么我们需要把原来的sql执行语句比如:string.format(“select * from user where id=’{0}’ and pwd = ‘{1}’”,id,pwd)
* 更改为: “select * from user where id = @id and pwd = @pwd”;
* 我们使用了@名 代替了占位符,而这个@名 原先是不存在不需要声明的。只需要在后面使用上面那么类声明一下就ok
* Code:
*


 
  1. SqlParameter i = new SqlParameter("@id",id);

  2. * SqlParameter j = new SqlParameter("@pwd",pwd);

  • //第一参数是在sql语句中出现的名字,第二个参数是用来代替这个变量的真实的值-第一个参数需要用双引号
  • 那么我们数据库执行语句搞定了,我们接下来会需要使用SqlCommand类来操作数据库,我们也需要对这个对象声明这个执行语句中的变量的意思
  • Code:
  •  

 
  1. SqlCommand cmd = new SqlCommand(sql,conn);

  2. * cmd.Parameters.Add(i);

  3. * cmd.Parameters.Add(j);

  • //有几个参数就添加几个
  • 如果用户使用的是适配器- SqlDataAdapter
  • Code:

 
  1. * SqlDataAdapter dat = new SqlDataAdapter(sql,conn);

  2. * dat.SelectCommand.Parameters.Add(i);

  3. * dat.SelectCommand.Parameters.Add(j);

  • 完整实例:
  • Code:

 
  1. SqlConnection conn = new SqlConnection("...");

  2. conn.Open();

  3. string sqlSentence = "select * from user where id = @id and pwd = @pwd";

  4. SqlParameter id = new SqlParameter("@id",value1);

  5. SqlParameter pwd = new SqlParameter("pwd",value2);

  6. SqlCommand cmd = new SqlCommand(sqlSentence,conn);

  7. //SqlDataAdapter dat = new SqlDataAdapter(sqlSentence,conn);

  8. //dat.SelectCommand.Parameters.Add(id);

  9. //dat.SelectCommand.Parameters.Add(pwd);

  10. cmd.Parameters.Add(id);

  11. cmd.Parameters.Add(pwd);

  12. object obj = cmd.ExecuteScalar();

  13. conn.Close();

免责声明:文章转载自《C#参数化(防止SQL注入)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇.class 字节码文件修改原码,反码,补码详解下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Qt之getOpenFileName,getSaveFileName,getOpenFileNames

1.头文件   #include<QFileDialog> 2.用处   这几个函数都是QFileDialog这个类中的静态函数,可以调用当前系统的文件对话框。具体来讲:   getOpenFileName返回一个被用户选中的文件的路径,前提是这个文件是存在的。   getSaveFileName返回一个被用户选中的文件的路径,这个文件可以是不...

一个美丽的java烟花程序

<img src="http://img.blog.csdn.net/20150625104525974?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzkxMDM1Nw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gra...

jenkins动态参数插件Dynamic Parameter安装及简单使用

插件安装: 1.先下载插件hpi文件到本地   jenkins插件下载地址 http://mirror.xmission.com/jenkins/plugins/ http://updates.jenkins-ci.org/download/plugins/   dynamicparameter下载地址: http://mirror.xmission.co...

Ubuntu中查找文件

首先打开Ubuntu的终端,利用find命令,然后后面跟一个name参数,冒号里式过滤条件,两个星号表示包含name的文件 find / -name "*name" 权限不够,在前面加sudo 只搜索名称为name的文件: find / -name "name" 按照size大小查找文件: find / -size 1G...

vue 使用vuedraggable 实现列表拖拽排序

首先安装  npm install vuedraggable --save 页面使用时引入import Draggable from 'vuedraggable' export default { name: "draggable", components: { Draggable }, data(){ return {...

ztree树的模糊搜索功能

在做机场项目的时候,业务为一个input框,点击的时候出现一个下拉树,这个下拉树是所有的设备,由于设备太多,加上分了区域,为了更好的用户体验,设计一个模糊搜索的功能,方便用户进行选择 具体实现过程如下: 第一步:ui设计  一个input输入框,用于输入用,下方一个div或者是一个ul用于ztree树用 <ul class="list">...