C#--WinForm系统平台之登录界面及数据连接
2010-01-04 17:52
295 查看
今天主要写平台的登录功能,这主要涉及三个方面的内容:
1、登录界面与主窗体;
2、登录时的判断(含数据库的连接);
3、密码的加密。
首先要做的是登录窗体和主窗体的关系,我们一般情况下都是默认这样先显示登录窗体,然后再显示主窗体。
![](http://blog.51cto.com/images/editer/InBlock.gif)
static void Main()
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.EnableVisualStyles();
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.SetCompatibleTextRenderingDefault(false);
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.Run(new frmLogin());//如果要先显示登录窗体再显示主窗体,就需修改此处,默认是“Application.Run(new MainFrm())” 。简单通俗点说就是设置运行开始的入口。
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
第二个就是登录时用户名和密码的判断了.我们要先做的就是在工具箱中添加SQLCONNECTION等(在找这个控件的时候,一直找不到,所以一度认为是自己版本不对,汗)。
添加一个SqlConnection控件后,名称为SqlCon,设置ConnectionString(这个跟Delphi一样),步骤如下:
这边为了方便我选择本机服务器,然后选择数据库为“Master”,选择他其中的表 dbo.MSreplication_options,默认它的optname列为登录名, value列为密码。
![](http://img1.51cto.com/attachment/201001/201001051262683821581.jpg)
点击“测试连接”成功以后,点击“确定”,报如下错误:
![](http://img1.51cto.com/attachment/201001/201001051262684635291.jpg)
这个具体原因可以到微软网站上看到:http://blog.csdn.net/net_lover/archive/2008/09/07/2894636.aspx,主要是ShareManagementObjects.msi没有安装,安装完毕将VSS重启就行了。
重新连接确定后,会在ConnectionString中显示“Data Source=.;Initial Catalog=master;Integrated Security=True”。DataBase显示刚才选择的数据表Master。Datasource显示为本机数据库。
添加一个SqlCommand控件,名字为SqlCommand,设置Connection为上面的SqlCon,设置CommandText属性:“select optname, major_version from dbo.MSreplication_options”。
设置SqlCommand的Parameter的属性,添加两个,分别对应着登录名和密码。如果写成代码的话就应该如下:
首先是登陆按钮:
![](http://blog.51cto.com/images/editer/InBlock.gif)
private void BtnOk_Click(object sender, EventArgs e)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (MaskEdtName.Text =="")
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtName.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("登录名不能为空");
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (MaskEdtPassword.Text == "")
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtPassword.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("密码不能为空!");
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if ( IsExist(MaskEdtName.Text ,MaskEdtPassword.Text)==false)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtName.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("登录名和密码不对,请重新输入");
![](http://blog.51cto.com/images/editer/InBlock.gif)
return;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MainFrm Main = new MainFrm();
![](http://blog.51cto.com/images/editer/InBlock.gif)
Main.Show();
![](http://blog.51cto.com/images/editer/InBlock.gif)
this.Hide();
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
然后是判断的函数:
![](http://blog.51cto.com/images/editer/InBlock.gif)
private bool IsExist(string StrName,string StrPassWord)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
bool Result = false;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//string StrSql = "SELECT optname, major_version FROM MSreplication_options WHERE (optname = @Name) AND (major_version = @Password)";
![](http://blog.51cto.com/images/editer/InBlock.gif)
string StrSql = "SELECT count(*) FROM MSreplication_options WHERE (optname ='"+ StrName +"') AND (optname = '"+ StrPassWord +"' )";
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.Add("@Name", StrName);
![](http://blog.51cto.com/images/editer/InBlock.gif)
SqlCommand.CommandText = StrSql;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.AddWithValue("@Name", StrName);
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.AddWithValue("@Password", StrPassWord);
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters["@Name"].Value = StrName;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters["@Password"].Value = StrPassWord;
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
SqlCommand.Connection.Open();
![](http://blog.51cto.com/images/editer/InBlock.gif)
//int i = Convert.ToInt32(SqlCommand.ExecuteNonQuery());
![](http://blog.51cto.com/images/editer/InBlock.gif)
int i = Convert.ToInt32(SqlCommand.ExecuteScalar());//这个一直搞不懂,为什么ExecuteNonQuery返回的影响行数一直是-1,就是查询有结果也是显示-1
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (i > 0)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Result = true;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Result = false;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
return Result;
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
这边我的疑惑就是关于ExecuteNonQuery这个函数,执行后没有效果,希望大家能够帮忙解释下。谢谢!
这次写的数据连接是最初级的,其实可以写个数据连接的通用单元,下次使用的时候直接拿来用就可以了。
第三个关于密码加密,这边我其实是有两个注意点:
1、在编辑框中显示密码的格式为特殊字符。
2、密码也应该通过加密,解密 。这个太大了下次有机会再说。
修改密码的显示方式很简单,就是将PasswordChar的属性值中输入*号就行了。
关于登陆解面,我目前遇到的最复杂的就是增加了一个短信猫的验证,每次登陆除了出入用户名和密码外,还通过发送验证码到手机上,实时保证登陆安全。
另外就是系统高手能够帮我解释下上面Sql执行的疑惑,万分感谢!
1、登录界面与主窗体;
2、登录时的判断(含数据库的连接);
3、密码的加密。
首先要做的是登录窗体和主窗体的关系,我们一般情况下都是默认这样先显示登录窗体,然后再显示主窗体。
![](http://blog.51cto.com/images/editer/InBlock.gif)
static void Main()
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.EnableVisualStyles();
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.SetCompatibleTextRenderingDefault(false);
![](http://blog.51cto.com/images/editer/InBlock.gif)
Application.Run(new frmLogin());//如果要先显示登录窗体再显示主窗体,就需修改此处,默认是“Application.Run(new MainFrm())” 。简单通俗点说就是设置运行开始的入口。
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
第二个就是登录时用户名和密码的判断了.我们要先做的就是在工具箱中添加SQLCONNECTION等(在找这个控件的时候,一直找不到,所以一度认为是自己版本不对,汗)。
添加一个SqlConnection控件后,名称为SqlCon,设置ConnectionString(这个跟Delphi一样),步骤如下:
这边为了方便我选择本机服务器,然后选择数据库为“Master”,选择他其中的表 dbo.MSreplication_options,默认它的optname列为登录名, value列为密码。
![](http://img1.51cto.com/attachment/201001/201001051262683821581.jpg)
点击“测试连接”成功以后,点击“确定”,报如下错误:
![](http://img1.51cto.com/attachment/201001/201001051262684635291.jpg)
这个具体原因可以到微软网站上看到:http://blog.csdn.net/net_lover/archive/2008/09/07/2894636.aspx,主要是ShareManagementObjects.msi没有安装,安装完毕将VSS重启就行了。
重新连接确定后,会在ConnectionString中显示“Data Source=.;Initial Catalog=master;Integrated Security=True”。DataBase显示刚才选择的数据表Master。Datasource显示为本机数据库。
添加一个SqlCommand控件,名字为SqlCommand,设置Connection为上面的SqlCon,设置CommandText属性:“select optname, major_version from dbo.MSreplication_options”。
设置SqlCommand的Parameter的属性,添加两个,分别对应着登录名和密码。如果写成代码的话就应该如下:
首先是登陆按钮:
![](http://blog.51cto.com/images/editer/InBlock.gif)
private void BtnOk_Click(object sender, EventArgs e)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (MaskEdtName.Text =="")
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtName.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("登录名不能为空");
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (MaskEdtPassword.Text == "")
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtPassword.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("密码不能为空!");
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
if ( IsExist(MaskEdtName.Text ,MaskEdtPassword.Text)==false)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MaskEdtName.Focus();
![](http://blog.51cto.com/images/editer/InBlock.gif)
MessageBox.Show("登录名和密码不对,请重新输入");
![](http://blog.51cto.com/images/editer/InBlock.gif)
return;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
MainFrm Main = new MainFrm();
![](http://blog.51cto.com/images/editer/InBlock.gif)
Main.Show();
![](http://blog.51cto.com/images/editer/InBlock.gif)
this.Hide();
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
然后是判断的函数:
![](http://blog.51cto.com/images/editer/InBlock.gif)
private bool IsExist(string StrName,string StrPassWord)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
bool Result = false;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//string StrSql = "SELECT optname, major_version FROM MSreplication_options WHERE (optname = @Name) AND (major_version = @Password)";
![](http://blog.51cto.com/images/editer/InBlock.gif)
string StrSql = "SELECT count(*) FROM MSreplication_options WHERE (optname ='"+ StrName +"') AND (optname = '"+ StrPassWord +"' )";
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.Add("@Name", StrName);
![](http://blog.51cto.com/images/editer/InBlock.gif)
SqlCommand.CommandText = StrSql;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.AddWithValue("@Name", StrName);
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters.AddWithValue("@Password", StrPassWord);
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters["@Name"].Value = StrName;
![](http://blog.51cto.com/images/editer/InBlock.gif)
//SqlCommand.Parameters["@Password"].Value = StrPassWord;
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
SqlCommand.Connection.Open();
![](http://blog.51cto.com/images/editer/InBlock.gif)
//int i = Convert.ToInt32(SqlCommand.ExecuteNonQuery());
![](http://blog.51cto.com/images/editer/InBlock.gif)
int i = Convert.ToInt32(SqlCommand.ExecuteScalar());//这个一直搞不懂,为什么ExecuteNonQuery返回的影响行数一直是-1,就是查询有结果也是显示-1
![](http://blog.51cto.com/images/editer/InBlock.gif)
if (i > 0)
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Result = true;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
else
![](http://blog.51cto.com/images/editer/InBlock.gif)
{
![](http://blog.51cto.com/images/editer/InBlock.gif)
Result = false;
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
![](http://blog.51cto.com/images/editer/InBlock.gif)
return Result;
![](http://blog.51cto.com/images/editer/InBlock.gif)
![](http://blog.51cto.com/images/editer/InBlock.gif)
}
这边我的疑惑就是关于ExecuteNonQuery这个函数,执行后没有效果,希望大家能够帮忙解释下。谢谢!
这次写的数据连接是最初级的,其实可以写个数据连接的通用单元,下次使用的时候直接拿来用就可以了。
第三个关于密码加密,这边我其实是有两个注意点:
1、在编辑框中显示密码的格式为特殊字符。
2、密码也应该通过加密,解密 。这个太大了下次有机会再说。
修改密码的显示方式很简单,就是将PasswordChar的属性值中输入*号就行了。
关于登陆解面,我目前遇到的最复杂的就是增加了一个短信猫的验证,每次登陆除了出入用户名和密码外,还通过发送验证码到手机上,实时保证登陆安全。
另外就是系统高手能够帮我解释下上面Sql执行的疑惑,万分感谢!
相关文章推荐
- C#--WinForm系统平台之初始界面
- 数据结构实验:AVL平衡树做出用户登录系统(dos界面)
- 求java写的类似网吧的管理系统登录界面
- 简单医疗系统设计(一)登录界面的制作
- WebForm管理平台 -- 系统登录
- 如何定制Domino平台的登录界面
- JS 退出系统并跳转到登录界面的实现代码
- 更改Windows系统登录界面
- 系统登录界面
- 关闭Win7登录欢迎界面 直接进入系统
- “多负载识别监控平台(上位机)”技术细节 之Unit4-Form4系统设置界面
- 【电信计费系统项目实战】基础篇---登录界面实现
- Flask实战2问答平台-父模板抽离(登录注册界面)
- WinForm系统 -- 登录模块
- Swing界面的布局联系(学生成绩管理系统登录界面演示和菜单栏、菜单项、菜单的布局方式演示)
- ATM系统实现[1]——用户登录界面[00原创]
- Qt银行管理系统——初始界面功能函数_登录
- 系统登录后,界面全屏,且屏蔽快捷键使系统更加正规化
- 系统登录界面的验证码
- Linux配置登录系统欢迎文字(文本界面)