今天主要写平台的登录功能,这主要涉及三个方面的内容:
   1、登录界面与主窗体;
   2、登录时的判断(含数据库的连接);
   3、密码的加密。
 
    首先要做的是登录窗体和主窗体的关系,我们一般情况下都是默认这样先显示登录窗体,然后再显示主窗体。
InBlock.gif                 static void Main()
InBlock.gif                {
InBlock.gif                        Application.EnableVisualStyles();
InBlock.gif                        Application.SetCompatibleTextRenderingDefault( false);
InBlock.gif                        Application.Run( new frmLogin()); //如果要先显示登录窗体再显示主窗体,就需修改此处,默认是“Application.Run(new MainFrm())” 。简单通俗点说就是设置运行开始的入口。
InBlock.gif                }
    第二个就是登录时用户名和密码的判断了.我们要先做的就是在工具箱中添加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的属性,添加两个,分别对应着登录名和密码。如果写成代码的话就应该如下:
首先是登陆按钮:
InBlock.gif private void BtnOk_Click( object sender, EventArgs e)
InBlock.gif                {
InBlock.gif                         if (MaskEdtName.Text =="")
InBlock.gif                        {
InBlock.gif                                MaskEdtName.Focus();
InBlock.gif                                MessageBox.Show( "登录名不能为空");
InBlock.gif
InBlock.gif                        }
InBlock.gif                         else
InBlock.gif                        {
InBlock.gif                                 if (MaskEdtPassword.Text == "")
InBlock.gif                                {
InBlock.gif                                        MaskEdtPassword.Focus();
InBlock.gif                                        MessageBox.Show( "密码不能为空!");
InBlock.gif                                }
InBlock.gif                                 else
InBlock.gif                                {
InBlock.gif                                     if ( IsExist(MaskEdtName.Text ,MaskEdtPassword.Text)== false)
InBlock.gif                                     {
InBlock.gif                                             MaskEdtName.Focus();
InBlock.gif                                             MessageBox.Show( "登录名和密码不对,请重新输入");
InBlock.gif                                             return;
InBlock.gif                                     }
InBlock.gif                                     else
InBlock.gif                                     {
InBlock.gif                                             MainFrm Main = new MainFrm();
InBlock.gif                                             Main.Show();
InBlock.gif                                             this.Hide();
InBlock.gif                                     }
InBlock.gif                                }
InBlock.gif                        }
InBlock.gif                }
 然后是判断的函数:
InBlock.gif private bool IsExist( string StrName, string StrPassWord)
InBlock.gif                {
InBlock.gif                         bool Result = false;
InBlock.gif                         //string StrSql = "SELECT     optname, major_version FROM            MSreplication_options WHERE     (optname = @Name) AND (major_version = @Password)";
InBlock.gif                         string StrSql = "SELECT     count(*)    FROM            MSreplication_options WHERE     (optname ='"+ StrName + "') AND (optname = '"+ StrPassWord + "' )";
InBlock.gif                         //SqlCommand.Parameters.Add("@Name", StrName);
InBlock.gif                        SqlCommand.CommandText = StrSql;
InBlock.gif                         //SqlCommand.Parameters.AddWithValue("@Name", StrName);
InBlock.gif                         //SqlCommand.Parameters.AddWithValue("@Password", StrPassWord);
InBlock.gif
InBlock.gif                         //SqlCommand.Parameters["@Name"].Value = StrName;
InBlock.gif                         //SqlCommand.Parameters["@Password"].Value = StrPassWord;
InBlock.gif
InBlock.gif                        SqlCommand.Connection.Open();
InBlock.gif                         //int i = Convert.ToInt32(SqlCommand.ExecuteNonQuery());
InBlock.gif                         int i = Convert.ToInt32(SqlCommand.ExecuteScalar()); //这个一直搞不懂,为什么ExecuteNonQuery返回的影响行数一直是-1,就是查询有结果也是显示-1
InBlock.gif                         if (i > 0)
InBlock.gif                        {
InBlock.gif                                Result = true;
InBlock.gif                        }
InBlock.gif                         else
InBlock.gif                        {
InBlock.gif                                Result = false;
InBlock.gif                        }
InBlock.gif                         return Result;
InBlock.gif
InBlock.gif                }
    这边我的疑惑就是关于ExecuteNonQuery这个函数,执行后没有效果,希望大家能够帮忙解释下。谢谢! 
    这次写的数据连接是最初级的,其实可以写个数据连接的通用单元,下次使用的时候直接拿来用就可以了。
    第三个关于密码加密,这边我其实是有两个注意点:
    1、在编辑框中显示密码的格式为特殊字符。
    2、密码也应该通过加密,解密 。这个太大了下次有机会再说。
修改密码的显示方式很简单,就是将PasswordChar的属性值中输入*号就行了。 
 
 
关于登陆解面,我目前遇到的最复杂的就是增加了一个短信猫的验证,每次登陆除了出入用户名和密码外,还通过发送验证码到手机上,实时保证登陆安全。
另外就是系统高手能够帮我解释下上面Sql执行的疑惑,万分感谢!