zoukankan      html  css  js  c++  java
  • WinForm中的登录

    在一般的C/S系统中,登录功能基本上是必备功能,

    总结了三种C# Winform登录功能的实现方法。

    第一种:在应用程序设置代码里(Program.cs)将应用程序入口改成系统主窗口

    听起来有点绕,就是说,在应用程序初始化时,第一个加载的页面是我们登录后的主页面。

    1、在Program.cs文件中设置Application.Run:

        Application.Run(new FormMain());//设置应用程序运行时加载的窗口

    2、添加登录按钮事件private void button1_Click(object sender, EventArgs e)代码

        private void button1_Click(object sender, EventArgs e)//登录
            {
                if (this.textBoxPassword.Text == "")
                {
                    MessageBox.Show("请输入密码!");
                }
                else if (this.textBoxUsername.Text=="123" && this.textBoxPassword.Text == "123")
                {
                    this.DialogResult = DialogResult.OK;
                    this.Close();
                }
                else
                {
                    MessageBox.Show("Username or Password Error");
                }
            }

    3、添加主窗口formMain加载时事件代码

    private void main_Load(object sender, EventArgs e)
            {
                Form formLogin = new login();
                formLogin.ShowDialog();
                if (formLogin.DialogResult == DialogResult.OK)//如果登录框返回DialogResult.OK
                {
                    MessageBox.Show("正常登录");
                }
                else
                {
                    this.Close();
                }
            }

    设计逻辑:

    首先程序load主窗口formMain,这时formMain就会new一个login登录窗口并弹出窗口,然后关闭自身。在登录窗口验证用户名和密码后通过登录窗口的this.DialogResult = DialogResult.OK;并关闭登录框。关闭以后formMain的main_Load事件再次判断登录框的DialogResult是否是OK,如果是则加载主窗口。

    第二种:通过登录验证来控制是否是否执行Application.Run()。

    代码如下:

        Form formLogin = new login();
        formLogin.ShowDialog();
        if (formLogin.DialogResult == DialogResult.OK)
        {
            Application.Run(new formMain());
        }
        else
        {
            return;
        }

    这种方法的原理理解起来相对第一种来说要简单些,在应用程序初始化时,首先加载登录窗口并进行验证,只有验证通过才Run(new formMain());

    第三种:在通过登录验证后,直接将登录框隐藏(注是隐藏,this.Hide()而不是this.Close())。这种方法理解起来就更简单了。

  • 相关阅读:
    Bzoj 2820: YY的GCD(莫比乌斯反演+除法分块)
    Cogs 2221. [SDOI2016 Round1] 数字配对(二分图)
    Cogs 750. 栅格网络(对偶图)
    最小环问题
    浅谈卡特兰数
    洛谷 P1744 采购特价商品
    HDU 1212 Big Number
    HDU 2108 Shape of HDU
    HDU 1029 Ignatius and the Princess IV
    HDU 1021 Fibonacci Again
  • 原文地址:https://www.cnblogs.com/judgelee/p/2756390.html
Copyright © 2011-2022 走看看