今天主要写平台的登录功能,这主要涉及三个方面的内容:
   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执行的疑惑,万分感谢!