云服务器网:购买云服务器和VPS必上的网站!

怎么防止:登录怎么防止sql注入

登录怎样避免sql注入登录避免sql注入的方法:1.登录查询语句最好不要用连接字符串查询,避免sql注入1‘or’1‘=’1,代码以下:string username=\”admin\”;string password=\”123\”;string str=\”连接字符

登录怎样避免SQL注入

登录避免sql注入的方法:

1.登录查询语句最好不要用连接字符串查询,避免sql注入1‘or’1‘=’1,代码以下:

string username="admin";

string password="123";

string str="连接字符串";

using(sqlconnection cnn=newsqlconnection(str))

{

using(sqlcommand cmd=cnn.createcommand())

{

cmd.commandtext="select count(*) from login where username='"+username+"'and password='"+password+"'";

int i=convert.toint32(cmd.executescalar());

if(i>3)

{

console.write("yes");

}

else

{

console.write("no");

}

}

}

2.登录查询语句最好要用,连接字符串来避免sql注入,例如:

string username="admin";

string password="123";

string str="连接字符串";

using(sqlconnection cnn=newsqlconnection(str))

{

using(sqlcommand cmd=cnn.createcommand())

{

cmd.commandtext="select count(*) from login where username=@username and password=@password";

cmd.parameters.add(new sqlparameter("username",username));

cmd.parameters.add(new sqlparameter("password",password));

int i=convert.toint32(cmd.executescalar());

if(i>3)

{

console.write("yes");

}

else

{

console.write("no");

}

}

}

3.限制毛病登录次数,例如:

private void incerrortimes()

{

using(sqlconnection cnn2=newsqlconnection(str))

{

using(sqlcommand cmd2=cnn2.createcommand())

{

cmd2.commandtext="update login set errortimes=errortimes+1 where username=@username";

cmd2.parameters.add(new sqlparameter("username",username));

cmd2.executenonquery();

}

}

}

private void reseterrortimes()

{

using(sqlconnection cnn2=newsqlconnection(str))

{

using(sqlcommand cmd2=cnn2.createcommand())

{

cmd2.commandtext="update login set errortimes=0 where username=@username";

cmd2.parameters.add(new sqlparameter("username",username));

cmd2.executenonquery();

}

}

}

using(sqlconnection cnn=newsqlconnection(str))

{

using(sqlcommand cmd=cnn.createcommand())

{

cmd.commandtext="select * from login where username=@username";

cmd.parameters.add(new sqlparameter("username",username));

using(sqldatareader reader=cmd.executereader())

{

if(reader.read())

{

int errortimes=convert.toint32(read["errortimes"]);

if(errortimes>3)

{

console.write("登录毛病次数过量,制止登录");

return;

}

string dbpassword=read["password"];

if(password=dbpassword)

{

console.write("登录成功");

reseterrortimes()

}

else

{

console.write("登录失败");

incerrortimes();

}

}

else

{

console.write("用户名不存在");

}

}

}

}

本文来源:https://www.yuntue.com/post/62262.html | 云服务器网,转载请注明出处!

关于作者: yuntue

云服务器(www.yuntue.com)是一家专门做阿里云服务器代金券、腾讯云服务器优惠券的网站,这里你可以找到阿里云服务器腾讯云服务器等国内主流云服务器优惠价格,以及海外云服务器、vps主机等优惠信息,我们会为你提供性价比最高的云服务器和域名、数据库、CDN、免费邮箱等企业常用互联网资源。

为您推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注