您的位置:首页 > 编程语言 > C#

C#--WinForm系统平台之登录界面及数据连接

2010-01-04 17:52 295 查看
今天主要写平台的登录功能,这主要涉及三个方面的内容:
1、登录界面与主窗体;
2、登录时的判断(含数据库的连接);
3、密码的加密。

首先要做的是登录窗体和主窗体的关系,我们一般情况下都是默认这样先显示登录窗体,然后再显示主窗体。


static void Main()


{


Application.EnableVisualStyles();


Application.SetCompatibleTextRenderingDefault(false);


Application.Run(new frmLogin());//如果要先显示登录窗体再显示主窗体,就需修改此处,默认是“Application.Run(new MainFrm())” 。简单通俗点说就是设置运行开始的入口。


}
第二个就是登录时用户名和密码的判断了.我们要先做的就是在工具箱中添加SQLCONNECTION等(在找这个控件的时候,一直找不到,所以一度认为是自己版本不对,汗)。
添加一个SqlConnection控件后,名称为SqlCon,设置ConnectionString(这个跟Delphi一样),步骤如下:
这边为了方便我选择本机服务器,然后选择数据库为“Master”,选择他其中的表 dbo.MSreplication_options,默认它的optname列为登录名, value列为密码。



点击“测试连接”成功以后,点击“确定”,报如下错误:



这个具体原因可以到微软网站上看到: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的属性,添加两个,分别对应着登录名和密码。如果写成代码的话就应该如下:
首先是登陆按钮:


private void BtnOk_Click(object sender, EventArgs e)


{


if (MaskEdtName.Text =="")


{


MaskEdtName.Focus();


MessageBox.Show("登录名不能为空");




}


else


{


if (MaskEdtPassword.Text == "")


{


MaskEdtPassword.Focus();


MessageBox.Show("密码不能为空!");


}


else


{


if ( IsExist(MaskEdtName.Text ,MaskEdtPassword.Text)==false)


{


MaskEdtName.Focus();


MessageBox.Show("登录名和密码不对,请重新输入");


return;


}


else


{


MainFrm Main = new MainFrm();


Main.Show();


this.Hide();


}


}


}


}
然后是判断的函数:


private bool IsExist(string StrName,string StrPassWord)


{


bool Result = false;


//string StrSql = "SELECT optname, major_version FROM MSreplication_options WHERE (optname = @Name) AND (major_version = @Password)";


string StrSql = "SELECT count(*) FROM MSreplication_options WHERE (optname ='"+ StrName +"') AND (optname = '"+ StrPassWord +"' )";


//SqlCommand.Parameters.Add("@Name", StrName);


SqlCommand.CommandText = StrSql;


//SqlCommand.Parameters.AddWithValue("@Name", StrName);


//SqlCommand.Parameters.AddWithValue("@Password", StrPassWord);




//SqlCommand.Parameters["@Name"].Value = StrName;


//SqlCommand.Parameters["@Password"].Value = StrPassWord;




SqlCommand.Connection.Open();


//int i = Convert.ToInt32(SqlCommand.ExecuteNonQuery());


int i = Convert.ToInt32(SqlCommand.ExecuteScalar());//这个一直搞不懂,为什么ExecuteNonQuery返回的影响行数一直是-1,就是查询有结果也是显示-1


if (i > 0)


{


Result = true;


}


else


{


Result = false;


}


return Result;




}
这边我的疑惑就是关于ExecuteNonQuery这个函数,执行后没有效果,希望大家能够帮忙解释下。谢谢!
这次写的数据连接是最初级的,其实可以写个数据连接的通用单元,下次使用的时候直接拿来用就可以了。
第三个关于密码加密,这边我其实是有两个注意点:
1、在编辑框中显示密码的格式为特殊字符。
2、密码也应该通过加密,解密 。这个太大了下次有机会再说。
修改密码的显示方式很简单,就是将PasswordChar的属性值中输入*号就行了。

关于登陆解面,我目前遇到的最复杂的就是增加了一个短信猫的验证,每次登陆除了出入用户名和密码外,还通过发送验证码到手机上,实时保证登陆安全。
另外就是系统高手能够帮我解释下上面Sql执行的疑惑,万分感谢!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: