加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

C# Winform程序 使用登录窗体到主窗体 且传登录信息

发布时间:2021-07-06 05:55:23 所属栏目:大数据 来源: https://blog.csdn.net/kasama1
导读:C# Winform程序 使用登录窗体到主窗体 且传登录信息 ????看到很多朋友在CSDN中发帖放分求“如何实现登录验证正确后弹出主窗体”的问题。关于这个问题的实现方法,一般很多人都是使用在登录窗体点击“登录”按钮后,通过后台数据验证正确后,把登录窗体隐藏,

C# Winform程序 使用登录窗体到主窗体 且传登录信息

????看到很多朋友在CSDN中发帖放分求“如何实现登录验证正确后弹出主窗体”的问题。关于这个问题的实现方法,一般很多人都是使用在登录窗体点击“登录”按钮后,通过后台数据验证正确后,把登录窗体隐藏,然后载入主窗体。还有一种做法是以上提问的这些人的一个不太对的一个实现办法(其实是无法实现的),他们的做法是点击“登录”按钮后,调用this.close()方法去把登录窗体关闭,然后实例化主窗体

?????????? frmMain dlg=new frmMain();

?????????? dlg.ShowDialog();

????用以上代码想实现登录后加载主窗体,你可以发现,当点击“登录”按钮后,登录窗体确实是关闭了,然后程序加载主窗体,主窗体是一闪而过,随即又关闭了。这是为什么呢?其实,你调用登录窗体的关闭事件时,把进程给关了,frmMain和frmLogin窗体是同一个进程,所以就出现了以上的一闪而过的现象。

????那么我们如何能够实现验证登录信息正确后加载主窗体呢?我的答案是通过验证返回参数去实现过程控制。

???????? 在程序的类库里定义一个全局变量,如Bool? bLoginOk=false;

???????? 此变量在未作登录时的初始值为false。

????在项目中的Program.cs中,通过先加载frmLogin,点击登录窗体中的“登录”按钮后,在后台查询数据库验证合法性,如果合法,则把bLoginOk赋值true;否则赋值falsse。

????在最后通过判断bLoginOk的值

???????if(bLoginOk==true)

?????? {

?????????? Application.run(frmMain);

?????? }

?????? else

????????? Application.Exit();

????同样可以通过以上的方法实现验证数据库连接参数的准确性。

?

在 龙星 项目中 本人就使用到了?? 例子如下:

?

 1     static class Program
2
3 {
4
5 /// <summary>
6 /// 应用程序的主入口点。
7 </summary>
8 [STAThread]
9 void Main()
10 {
11 Application.EnableVisualStyles();
12 Application.SetCompatibleTextRenderingDefault(false);
13 //Application.Run(new Login());14
15 System.Threading.Mutex mutex = new System.Threading.Mutex(false,"ThisShouldOnlyRunOnce");
16 bool Running = !mutex.WaitOne(0,17 if (!Running
18 {
19 20 Login login = new Login();
21 if (System.Windows.Forms.DialogResult.Cancel == login.ShowDialog())
22 {
23 return;
24 }
25 Main main = new Main();
26 main.ShowDialog();
27 }
28 else
29 {
30 MessageBox.Show(程序已启动!31 }
32 }
33 }

?

全局类:

1 public class GlobalClass
2 {
3 struct User
4 {
5 string strUsrId;
6 string strUsrName;
7 };
8 static User user;
9 } 登录方法:

1
private void CheckIn()
2 {
3 BaseData bd=new BaseData();
4 string strsql = Select * from [User] Where UserId='" + bd.Replace(this.txt_UserId.Text.Trim()) + ' And PassWord='this.txt_PassWord.Text.Trim())+'";
5 DataSet ds = new DataSet();
6 ds = sqlHelper.ExecuteDataset(strConn,CommandType.Text,strsql);
7
8 if (ds != null && ds.Tables[0] != null)
9 {
10 if (ds.Tables[0].Rows.Count > 0)
11 {
12 GlobalClass.user.strUsrId = ds.Tables[0].Rows[0][UserId"].ToString();
13 GlobalClass.user.strUsrName = ds.Tables[UserName14 this.DialogResult = System.Windows.Forms.DialogResult.OK;
15 this.Close();
16 }
17 18 {
19 MessageBox.Show(用户名或密码错误!20 }
21 }
22 }
?

主要窗体使用:

??? public partial class Main : Form

??? {

??????? public Main()

??????? {

??????????? InitializeComponent();

?

??????????? this.label1.Text = GlobalClass.user.strUsrName;

??????? }

}

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读