ADO之密码验证--3次错误就锁定
这个程序是那vs2010下写的,C#语言。数据库是sql server 2008
首先在数据库中新建一个数据库Test1,在数据库中新建一个表用来保存用户名和密码USERINFO,
CREATE TABLE USERINFO
(
UserID varchar(12) NOT NULL PRIMARY KEY,
Password varchar(12) NOT NULL ,
ErrorTimes int NULL,
)
ErrorTimes就是用来判断用户输入密码错误的次数的,每错一次加一
添加几条数据
INSERT INTO USERINFO
VALUES('song','')
INSERT INTO USERINFO
VALUES('wang','')
然后,在VS里做个简单界面,给控件绑定变量tb_UserID和tb_Password

最后响应登录按钮btn_Login_Click()
private void btn_Login_Click(object sender, RoutedEventArgs e)
{
//从控件获取数据
string userid = tb_UserID.Text;
string password = tb_Password.Text;
if (userid != "" && password != "")//用户名和密码全不为空
{
using (SqlConnection conn = new SqlConnection(
"Data Source=.;Initial Catalog=Test1;User ID=sa;Password=123456"))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
//查找用户名是否存在
cmd.CommandText = "select ErrorTimes from USERINFO where UserID=@user";
cmd.Parameters.Add(new SqlParameter("@user", tb_UserID.Text));//
int resoult = -;
try {
resoult = (int)cmd.ExecuteScalar();//如果用户名不存在就抛出异常
}
catch (Exception ex) {
if (ex is SqlException)
{
MessageBox.Show("用户不存在,请重试");
}
} if (resoult >= )//输入密码错误超过3次
{
MessageBox.Show("你的帐户已锁定,请找管理员解锁");
}
else if (resoult >= && resoult < )
{
cmd.CommandText = "select Password from USERINFO where UserID=@user";
string pass = (string)cmd.ExecuteScalar();
if (pass.Equals(password))//比较两个字符串是否相等
{
MessageBox.Show("登录成功");
}
else
{
MessageBox.Show("密码错误,请重试");
cmd.CommandText = "update USERINFO set ErrorTimes = ErrorTimes+1 where UserID=@user";//更新数据
cmd.ExecuteNonQuery();
}
}
else if (resoult == -)
{
MessageBox.Show("用户不存在,请重试");
}
//MessageBox.Show(resoult.ToString());
}
}
}
else if (userid == "")
{
MessageBox.Show("用户名不能为空");
}
else
{
MessageBox.Show("密码不能为空");
}
}
这里总结一下数据库连接的一般过程
第一步,建立连接使用SqlConnection,参数可以为空,也可以为一个字符串。
DataSource 表示数据库的地址,如果是本机的话可以用"."或者127.0.0.1,其他的就指定一个IP地址。
Initial Catalog 表示要连接的数据库名,
User ID 指定用户名,
Password指定密码
SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=Test1;User ID=sa;Password=123456")
第二步,连接成功后就可以打开数据库里,Open()方法使用 ConnectionString 所指定的属性设置打开数据库连接。
conn.Open();
第三步,对 SQL Server 数据库执行的一个 Transact-SQL 语句或存储过程,使用 SqlCommand类来指定要执行的语句。
SqlCommand cmd = conn.CreateCommand();//创建一个命令用于执行查询
cmd.CommandText = "select ErrorTimes from USERINFO where UserID=@user";//这个就是要执行的sql语句
cmd.Parameters.Add(new SqlParameter("@user", tb_UserID.Text));//这个给参数赋值,可以指定多个参数
最后执行语句 int resoult = (int)cmd.ExecuteScalar();
ExecuteScalar();//返回结果集的第一行第一列的数据
ExecuteNonQuery();//执行语句但是不查询
当然上面那个例子有很多需要改进的地方,继续学习。
ADO之密码验证--3次错误就锁定的更多相关文章
- ADO之密码验证--3次错误就锁定『改进』
这里使用了SqlHelper,简化程序 自己写一个SqlHelper,把数据库的连接等都写到里面去. 首先把连接字符串添加到配置文件里去,右键解决方案-->添加新建项-->选择应用程序配置 ...
- 【WCF】使用“用户名/密码”验证的合理方法
我不敢说俺的方法是最佳方案,反正这世界上很多东西都是变动的,正像老子所说的——“反(返)者,道之动”.以往看到有些文章中说,为每个客户端安装证书嫌麻烦,就直接采用把用户名和密码塞在SOAP头中发送,然 ...
- WCF 安全性之 自定义用户名密码验证
案例下载 http://download.csdn.net/detail/woxpp/4113172 客户端调用代码 通过代理类 代理生成 参见 http://www.cnblogs.com/woxp ...
- wordpress密码生成与登录密码验证
一.研究wordpress时wordpess的密码密码生成与登录密码验证方式很重要 WordPress密码已成为整合的首要目标,如何征服整合,就得了解WordPress密码算法. WordPress系 ...
- [c/c++] programming之路(24)、字符串(五)——字符串插入,字符串转整数,删除字符,密码验证,注意事项
1.将字符串插入到某位置(原字符串“hello yincheng hello cpp hello linux”,查找cpp,找到后在cpp的后面插入字符串“hello c”) 需要用到strstr字符 ...
- 如何在主Form出现之前,弹出密码验证From,Cancel就退出程序,Ok后密码正确才出现主Form
如何在主Form出现之前,弹出密码验证From,Cancel就退出程序,Ok后密码正确才出现主Form本文地址 :CodeGo.net/5175478/ ----------------------- ...
- WCF服务安全控制之netTcpBinding的用户名密码验证【转】
选择netTcpBinding WCF的绑定方式比较多,常用的大体有四种: wsHttpBinding basicHttpBinding netTcpBinding wsDualHttpBinding ...
- WCF用户名密码验证方式
WCF使用用户名密码验证 服务契约 namespace WCFUserNameConstract { [ServiceContract] public interface IWcfContract { ...
- 第一百五十节,封装库--JavaScript,表单验证--密码验证
封装库--JavaScript,表单验证--密码验证 效果图 html <div id="reg"> <h2 class="tuo">& ...
随机推荐
- Android ImageView的几种对图片的缩放处理 解决imageview放大图片后失真问题解决办法
我的解决办法: 1 首先设置android:layout_width=”wrap_content”和android:layout_height=”wrap_content”,否则你按比例缩放后的图片放 ...
- 【ros】【bug】gtk2\3 冲突
ORBSLAM2首次运行出现GTK冲突. Gtk-ERROR **: GTK+ 3 symbols detected. Using GTK+ 2.x and GTK+ 3 in the same pr ...
- OpenSSL context 的几个参数
NAME SYNOPSIS DESCRIPTION NOTES BUGS RETURN VALUES EXAMPLES SEE ALSO NAME SSL_CTX_set_verify, SSL_se ...
- cms-帖子静态化
实现帖子静态化和实现友情链接静态化一致, 1.首先建立帖子类别的实体类: package com.open1111.entity; /** * 帖子类别实体 * @author user * */pu ...
- C语言——字符串长度的计算方法
1.不带转义字符的字符串 如:“abc!x=/”,其长度为7 2.带转义字符的字符串 (1) 字符串“abc\n”:其中的'\n'为转义字符(换行符),计算字符串长度时只能计作一个字符,所以该字符串的 ...
- 《Ruby on Rails教程》学习笔记
本文是我在阅读 Ruby on Rails 教程的简体中文版时所做的摘录,以及学习时寻找的补充知识.补充知识主要来自于 Ruby on Rails 實戰聖經. Asset Pipeline 在最新版 ...
- World Wind Java开发之十四——添加WMS地图服务资源(转)
数据是GIS的核心,没有数据一切无从谈起,Internet上有很多在线WMS地图服务资源,我们可以好好利用这些数据资源,比如天地图.必应地图.NASA.OGC数据服务等等. 在我们国家常用的还是天地图 ...
- Problem I: Satellite Photographs
Problem I: Satellite Photographs Time Limit: 1 Sec Memory Limit: 128 MB Submit: 208 Solved: 118 [S ...
- python_44_文件属性
#打印文件属性信息 import os#os.stat()返回的文件属性元组元素的含义 filestats=os.stat('yesterday')#获取文件/目录的状态 print(filestat ...
- 避免修改Android.mk添加cpp文件路径
手工输入项目需要编译的cpp文件到Android.mk里的缺点 1)繁琐,如果cpp文件很多,简直无法忍受 2)手工输入过程中容易出现错误 3)如果cpp文件更改名称,需要修改android.mk文件 ...