ado.not--数据库防字符串注入攻击学习及 练习

Posted 右掱写爱

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ado.not--数据库防字符串注入攻击学习及 练习相关的知识,希望对你有一定的参考价值。

数据库防字符串注入攻击:
cmd.CommandText = "update student set name=@Sname,sex=@Ssex,birthday=@Sbirthday,score=@Sscore where code = @Scode";
cmd.Parameters.Clear();                ---------一个集合
cmd.Parameters.Add("@Sname", Sname);
cmd.Parameters.Add("@Ssex", Ssex);   ---------------------用一个占位符 代替输入的字符串,防止执行
cmd.Parameters.Add("@Sbirthday", Sbirthday);
cmd.Parameters.Add("@Sscore", Sscore);
cmd.Parameters.Add("@Scode", Scode);

 

 

 

练习题:
1、Car表数据查出显示
2、请输入要查的汽车名称:
请输入要查的汽车油耗:
请输入要查的汽车马力:
名称:宝马
油耗:8
马力:1 

 

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Text;
  5 using System.Threading.Tasks;
  6 using System.Data.SqlClient;
  7 
  8 namespace _06_22
  9 {
 10     class Program
 11     {
 12         static void Main(string[] args)
 13         {
 14 
 15             //练习题: 
 16           
 17                 #region  显示全部
 18                 //1、Car表数据查出显示
 19                 SqlConnection coon = new SqlConnection("server=.;database=Data0425;user=sa;pwd=123;");
 20                 SqlCommand com = coon.CreateCommand();
 21 
 22                 com.CommandText = "select * from car";
 23                 coon.Open();
 24                 SqlDataReader a1 = com.ExecuteReader();
 25                 if (a1.HasRows)
 26                 {
 27                     while (a1.Read())
 28                     {
 29                         Console.WriteLine("编号:" + a1["Code"] + " 品牌:" + a1["name"] + " 油耗:" + a1["oil"] + " 马力:" + a1["powers"] + " 排量:" + a1["exhaust"] + " 价格:" + a1["price"]);
 30                     }
 31                 }
 32 
 33                 coon.Close();
 34                 #endregion
 35 
 36                 //2、请输入要查的汽车名称:
 37                 //    请输入要查的汽车油耗:
 38                 //    请输入要查的汽车马力:
 39                 //名称:宝马
 40                 //油耗:8
 41                 //马力:1
 42 
 43 
 44 
 45                 for (; ; )
 46                 {
 47                     Console.Write("请输入要查的汽车名称:");
 48                     string cname = Console.ReadLine();
 49                     Console.Write("请输入要查的汽车油耗:");
 50                     string coil = Console.ReadLine();
 51                     Console.Write(" 请输入要查的汽车马力:");
 52                     string cpowers = Console.ReadLine();        //输入查询内容
 53 
 54 
 55                     #region       三项不为空时
 56                     if (cname != "" && coil != "" && cpowers != "")   //三项不为空时
 57                     {
 58                         com.CommandText = "select * from car where name like @cname and oil like @coil and powers like @cpowers ";
 59 
 60                         com.Parameters.Clear();  ------防字符串注入攻击
 61                         com.Parameters.Add("@cname","%"+cname+"%");
 62                         com.Parameters.Add("@coil","%"+coil+"%");
 63                         com.Parameters.Add("@cpowers","%"+cpowers+"%");
 64 
 65                         coon.Open();
 66                         SqlDataReader c1 = com.ExecuteReader();
 67                         if (c1.HasRows)
 68                         {
 69                             while (c1.Read())
 70                             {
 71                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
 72                             }
 73                             Console.Write("是否结束?[y/n]");   ------是否跳出
 74                             string js = Console.ReadLine();
 75                             if (js == "y")
 76                             { break; }
 77                         }
 78                         else
 79                         { Console.WriteLine("查无此项!!!重新输入!!"); }
 80                         coon.Close();
 81                     }
 82 
 83                     #endregion
 84 
 85                     #region       cname为空时
 86                     else if (cname == "" && coil != "" && cpowers != "")
 87                     {
 88                         com.CommandText = "select * from car where oil like @coil and powers like @cpowers ";
 89 
 90                         com.Parameters.Clear();
 91                         com.Parameters.Add("@coil", "%" + coil + "%");
 92                         com.Parameters.Add("@cpowers", "%" + cpowers + "%");
 93 
 94                         coon.Open();
 95                         SqlDataReader c1 = com.ExecuteReader();
 96                         if (c1.HasRows)
 97                         {
 98                             while (c1.Read())
 99                             {
100                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
101                             }
102                             Console.Write("是否结束?[y/n]");
103                             string js = Console.ReadLine();
104                             if (js == "y")
105                             { break; }
106                         }
107                         else
108                         { Console.WriteLine("查无此项!!!重新输入!!"); }
109                         coon.Close();
110                     }
111 
112                     #endregion
113 
114                     #region      coil为空时
115                     else if (cname != "" && coil == "" && cpowers != "")
116                     {
117                         com.CommandText = "select * from car where name like @cname and powers like @cpowers ";
118 
119                         com.Parameters.Clear();
120                         com.Parameters.Add("@cname", "%" + cname + "%");
121                         com.Parameters.Add("@cpowers", "%" + cpowers + "%");
122 
123                         coon.Open();
124                         SqlDataReader c1 = com.ExecuteReader();
125                         if (c1.HasRows)
126                         {
127                             while (c1.Read())
128                             {
129                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
130                             }
131                             Console.Write("是否结束?[y/n]");
132                             string js = Console.ReadLine();
133                             if (js == "y")
134                             { break; }
135                         }
136                         else
137                         { Console.WriteLine("查无此项!!!重新输入!!"); }
138                         coon.Close();
139                     }
140 
141                     #endregion
142 
143                     #region       cpowers为空时
144                     else if (cname != "" && coil != "" && cpowers == "")
145                     {
146                         com.CommandText = "select * from car where name like @cname and oil like @coil ";
147 
148                         com.Parameters.Clear();
149                         com.Parameters.Add("@cname", "%" + cname + "%");
150                         com.Parameters.Add("@coil", "%" + coil + "%");
151 
152                         coon.Open();
153                         SqlDataReader c1 = com.ExecuteReader();
154                         if (c1.HasRows)
155                         {
156                             while (c1.Read())
157                             {
158                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
159                             }
160                             Console.Write("是否结束?[y/n]");
161                             string js = Console.ReadLine();
162                             if (js == "y")
163                             { break; }
164                         }
165                         else
166                         { Console.WriteLine("查无此项!!!重新输入!!"); }
167                         coon.Close();
168                     }
169 
170                     #endregion
171 
172                     #region       cname不为空时
173                     else if (cname != "" && coil == "" && cpowers == "")
174                     {
175                         com.CommandText = "select * from car where name like @cname";
176 
177                         com.Parameters.Clear();
178                         com.Parameters.Add("@cname", "%" + cname + "%");
179                        
180                         coon.Open();
181                         SqlDataReader c1 = com.ExecuteReader();
182                         if (c1.HasRows)
183                         {
184                             while (c1.Read())
185                             {
186                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
187                             }
188                             Console.Write("是否结束?[y/n]");
189                             string js = Console.ReadLine();
190                             if (js == "y")
191                             { break; }
192                           
193                         }
194                         else
195                         { Console.WriteLine("查无此项!!!重新输入!!"); }
196                         coon.Close();
197                     }
198 
199                     #endregion
200 
201                     #region       coil不为空时
202                     else if (cname == "" && coil != "" && cpowers == "")
203                     {
204                         com.CommandText = "select * from car where oil like @coil";
205 
206                         com.Parameters.Clear();
207                         com.Parameters.Add("@coil", "%" + coil + "%");
208 
209                         coon.Open();
210                         SqlDataReader c1 = com.ExecuteReader();
211                         if (c1.HasRows)
212                         {
213                             while (c1.Read())
214                             {
215                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
216                             }
217                             Console.Write("是否结束?[y/n]");
218                             string js = Console.ReadLine();
219                             if (js == "y")
220                             { break; }
221                         }
222                         else
223                         { Console.WriteLine("查无此项!!!重新输入!!"); }
224                         coon.Close();
225                     }
226 
227                     #endregion
228 
229                     #region       cpowers不为空时
230                     else if (cname == "" && coil == "" && cpowers != "")
231                     {
232                         com.CommandText = "select * from car where  powers like @cpowers ";
233 
234                         com.Parameters.Clear();
235                         com.Parameters.Add("@cpowers", "%" + cpowers + "%");
236 
237                         coon.Open();
238                         SqlDataReader c1 = com.ExecuteReader();
239                         if (c1.HasRows)
240                         {
241                             while (c1.Read())
242                             {
243                                 Console.WriteLine("编号:" + c1["Code"] + " 品牌:" + c1["name"] + " 油耗:" + c1["oil"] + " 马力:" + c1["powers"] + " 排量:" + c1["exhaust"] + " 价格:" + c1["price"]);
244                             }
245                             Console.Write("是否结束?[y/n]");
246                             string js = Console.ReadLine();
247                             if (js == "y")
248                             { break; }
249                         }
250                         else
251                         { Console.WriteLine("查无此项!!!重新输入!!"); }
252                         coon.Close();
253                     }
254 
255                     #endregion
256 
257                   
258                    
259                 } 
260             Console.ReadLine();
261         }
262     }     
263 }

以上是关于ado.not--数据库防字符串注入攻击学习及 练习的主要内容,如果未能解决你的问题,请参考以下文章

字符串攻击防攻击实体类数据访问类--11月29日

完整修改和删除以及防字符串注入攻击

web前端怎么防止代码注入攻击

如何防止代码注入攻击在PHP

防SQL注入

防注入攻击