-2

我有一个程序,用户必须登录,所以他们有一个 ID 和密码。具有用户登录详细信息的数据库存储在本地 .mdf 文件中。

我想设置它,以便在用户登录时,程序的其余部分在右上角显示他们的详细信息,例如他们的姓名和他们的 ID。

不幸的是,我不知道如何做到这一点,而我在浏览时所看到的只是人们使用实际的系统登录名,这不是我想要的。

登录表单代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace InventoryManager
{
    public partial class frmLogin : Form
    {
        public frmLogin()
        {
            InitializeComponent();
        }

        private void frmLogin_Load(object sender, EventArgs e)
        {
            this.AcceptButton = btnSubmit;
        }

        string cs = @"Data Source= (LocalDB)\v11.0;AttachDbFilename=|DataDirectory|Users.mdf;Integrated Security = True;";

        private void btnSubmit_Click(object sender, EventArgs e)
        {
            if (txtUserID.Text == "" || txtPassword.Text == "")
            {
                MessageBox.Show("Please enter a User ID and Password");
                return;
            }

            try
            {
                SqlConnection con = new SqlConnection(cs);
                SqlCommand cmd = new SqlCommand("SELECT * FROM tbl_Login WHERE UserID = @userid AND Password = @password", con);
                cmd.Parameters.AddWithValue("@userid", txtUserID.Text);
                cmd.Parameters.AddWithValue("@password", txtPassword.Text);
                con.Open();
                SqlDataAdapter adapt = new SqlDataAdapter(cmd);
                DataSet ds = new DataSet();
                adapt.Fill(ds);
                con.Close();
                int count = ds.Tables[0].Rows.Count;

                if (count == 1)
                {
                    MessageBox.Show("Login Successful!");
                    this.Hide();
                    frmOverview fo = new frmOverview();
                    fo.Show();
                }

                else
                {
                    MessageBox.Show("Login Failed");
                    txtPassword.Text = "";
                }
            }

            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
}
4

1 回答 1

1

你可以制作一些像这样的静态类

public static class LoggedUser
{
    public static string Name { get; set; }
    public static string Username { get; set; }

}

成功登录后,用数据填充该类(例如):

        if (count == 1)
        {
            MessageBox.Show("Login Successful!");
            LoggedUser.Name = ds.Tables[0].Rows[1].ToString();
            LoggedUser.Username = ds.Tables[0].Rows[2].ToString();
            this.Hide();
            frmOverview fo = new frmOverview();
            fo.Show();
        }

LoggedUser稍后,您可以在项目中的每个表单上使用存储在类中的数据...

于 2016-05-06T09:05:56.323 回答