学生信息管理系统简介

中文摘要

为了提高学生信息的管理效率,本课题使用C#语言和SQL Server数据库系统开发了一个WinForm类型的学生信息管理系统对学校的学生信息进行高效管理,以提升教学质量。本系统包含管理员登录注册、管理员信息修改模块、添加学生信息模块、删除学生信息模块、查找学生信息模块、修改学生信息模块六个模块。毕业设计报告从可行性研究与项目开发计划及系统开发环境;系统需求分析;概要设计(含数据库设计)和详细设计;各功能模块的具体编码实现;系统测试;毕业设计总结六个方面进行了阐述。通过该系统的开发,对软件项目设计与开发工作的完整流程进行了实践。

关键词:学生信息管理系统,C#,SQL Server
更多源码和原文档获取:winform之家

1软件可行性研究与项目开发计划

1.1问题定义

1.2可行性分析

1.3进度计划

2.需求分析

2.1引言

2.2功能说明

2.3其他要求

操作系统:Windows

运行环境:VisualStudio

数据库环境:SQL Server

3.概要设计

3.1功能模块设计

本学生信息管理系统主要为登录注册、添加学生信息、删除学生信息、查找学生信息、修改学生信息等。

系统功能模块图如图3-1所示。

在这里插入图片描述

图3-1系统功能模块图

1)登陆注册功能

A.登录:输入用户名和密码登录,验证用户名和密码,进行登录。

B.注册:新建用户和密码,用来实现登陆,并有基本信息录入。

2)增删查改功能

A.管理员注册信息修改:管理员自身信息更改。

B.添加学生信息:对新生信息的录入。

C.删除学生信息:对毕业学生信息的移除。

D.查找学生信息:对学号和姓名提供查询学生信息功能。

E.修改学生信息:对学生错误信息进行修改。

3.2数据库设计

4.详细设计

4.1总体设计

(1)系统用例图

(2)系统体系结构

(3)E-R图

4.2功能模块详细分析

5.软件编码

5.1用户管理模块

(1)登录模块设计

在这里插入图片描述

5-1.1登录窗口

此窗体界面用于用户的登录,无账号的用户可点击注册。

登录窗口设计如下:

public static string ToMD5(string source)
{
     StringBuilder sb = new StringBuilder();
     MD5 md5 = MD5.Create();
     byte[] data = Encoding.UTF8.GetBytes(source);
     data = md5.ComputeHash(data);
     foreach (var item in data)
     {
         sb.Append(item.ToString("x2"));
     }
     return sb.ToString();

 }
 private void Login_Load(object sender, EventArgs e)
 {
     txtPwd.PasswordChar = '*';
 
 }
 private void btlogin_Click(object sender, EventArgs e)
 {
     string no = txtAccount.Text;
     string pwd = ToMD5(txtPwd.Text);
     User user = new User { Mno = no, Mpwd = pwd };
     bool result = ma.Login(user);
     if (result)
     {
         this.Hide();
         frmManage mainForm = new frmManage(txtAccount.Text, pwd);
         mainForm.StartPosition = FormStartPosition.CenterScreen;
         mainForm.Show();
     }
     else
     {
         MessageBox.Show("账号或密码错误!!!");
     }
 }

(2)注册模块设计

在这里插入图片描述

5-1.2注册窗口

此窗体界面用于用户注册。

注册界面设计如下:

private void btnRegister_Click_1(object sender, EventArgs e)
{
    if (!ver.IsAccountCode(txtNo.Text))//验证帐号是否正确
    {
        MessageBox.Show("请输入4位账号!!!");
        return;
    }
    if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
    {
        MessageBox.Show("请输入中文姓名吧!!!");
        return;
    }
    if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
    {
        MessageBox.Show("身份证至少为18位哦!!!");
        return;
    }
    
    if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
    {
        MessageBox.Show("请输入正确手机号!!!");
        return;
    }
    string no = txtNo.Text;
    string name = txtName.Text;
    string id = txtID.Text;
    string place = txtPlace.Text;
    string phone = txtPhone.Text;
    string pwd = txtPwd.Text;
    string pwdmd5 =ToMD5(pwd);
    if (no == "" || name == "" || id == "" || place == "" || phone == "" || pwd == "")
    {
        MessageBox.Show("请输入完整信息!");
        return;
    }
    User user = new User { Mno = no, Mname = name, Mid = id, Mplace = place, Mphone = phone, Mpwd = pwdmd5 };
    bool result = ma.Register(user);
     if (result)
    {
        MessageBox.Show("注册成功");
    }
    else
    {
        MessageBox.Show("账号重复!注册失败!");
    }
}

5.2用户信息模块设计

在这里插入图片描述

5-2用户信息窗口

此窗体界面用于用户信息的更改,可按照需求更改。

用户信息界面设计如下:

private void btnSubmit_Click(object sender, EventArgs e)
{
    Verification ver = new Verification();
    if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
    {
        MessageBox.Show("请输入中文姓名吧!!!");
        return;
    }
    if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
    {
        MessageBox.Show("身份证至少为18位哦!!!");
        return;
    }

    if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
    {
        MessageBox.Show("请输入正确手机号!!!");
        return;
    }
    string no = txtNo.Text;
    string name = txtName.Text;
    string Id = txtID.Text;
    string place = txtPlace.Text;
    string phone = txtPhone.Text;
    
    User user = new User {Mno=no,Mname=name,Mid=Id,Mplace=place,Mphone=phone};
    bool result = ma.Update(user);
    if (result)
    {
        MessageBox.Show("修改成功");
        
    }
    else
    {
        MessageBox.Show("修改失败");
    }
}

5.3用户修改密码模块设计

在这里插入图片描述

5-3修改密码窗口

此窗体界面用于管理员密码修改

修改密码界面设计如下:

private void skinButton1_Click(object sender, EventArgs e)
{
    if(txtPwd.Text == ""||txtNewPwd.Text == "")
    {
        MessageBox.Show("请输入密码!!!");
        return;
    }
    string str= ma.SelectOne(SendAccount).DataSet.Tables[0].Rows[0]["密码"].ToString();
    if (str == ToMD5(txtPwd.Text))
    {
        string newpwd = ToMD5(txtNewPwd.Text);
        string no = txtaccount.Text;
        User user = new User { Mno = no, Mpwd = newpwd };
        bool result = ma.UpdatePwd(user);
        if (result)
        {
            MessageBox.Show("修改成功,请重新登录");
            this.Hide();
            Login mainForm = new Login();
            mainForm.StartPosition = FormStartPosition.CenterScreen;
            mainForm.Show();
        }
        else
        {
            MessageBox.Show("修改失败");
        }
    }
    else
    {
        MessageBox.Show("原密码错误!!!");
    }
    
}

5.4添加学生信息管理模块设计

在这里插入图片描述

5-4添加学生窗口

此窗体界面用于学生信息的添加,实现对学生信息的添加

学生信息的添加界面设计如下:

private void btnA_Click(object sender, EventArgs e)
{
    Verification ver = new Verification();
    if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
    {
        MessageBox.Show("请输入中文姓名吧!!!");
        return;
    }
    if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
    {
        MessageBox.Show("身份证至少为18位哦!!!");
        return;
    }

    if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
    {
        MessageBox.Show("请输入正确手机号!!!");
        return;
    }

    try
    {
        
        string name = txtName.Text;
        string sex;
        if (rdobtn男.Checked)
        {
            sex = rdobtn男.Text;
        }
        else
        {
            sex = rdobtn女.Text;
        }
        string id = txtID.Text;
        string Cla = cboxClass.Text;
        string phone = txtPhone.Text;
        string place = txtPlace.Text;
        Student stu = new Student {stuName = name, stuSex = sex, stuID = id, stuClass = Cla, stuPhone = phone, stuPlace = place };
        bool result = stuma.Add(stu);
        if (result)
        {
            MessageBox.Show("添加成功");
            getAll();
        }
        else
        {
            MessageBox.Show("添加失败");
        }
        Clearbox();
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }
}

5.5删除学生信息模块设计

在这里插入图片描述

5-5删除学生信息窗口

此窗体界面用于学生信息的删除。

窗口设计如下:

private void btnSubmitDelect_Click(object sender, EventArgs e)
{
    int no =int.Parse( txtDeleteNo.Text);

    Student stu = new Student { stuNo = no};
    bool result = stuma.Delete(stu);
    if (result)
    {
        MessageBox.Show("删除成功");
    }
    else
    {
        MessageBox.Show("删除失败");
    }
    getAll();
    txtDeleteNo.Text = "";
    Clearbox();
}

5.6查询学生信息模块设计

在这里插入图片描述

5-6查询学生信息窗口

此窗体界面用于查询学生的信息。

窗口设计如下:

 private void btnSelectNo_Click(object sender, EventArgs e)
{
    try
    {
        DataGridView1.DataSource = stuma.SelectOne(txtSelectNo.Text);
    }
    catch (Exception ex)
    {

    }
}

private void btnSelectSure_Click(object sender, EventArgs e)
{
    DataGridView1.DataSource = stuma.SelectOnes(txtSelectName.Text);
}

5.7修改学生信息模块设计

在这里插入图片描述

5-7修改学生信息窗口

此窗体界面用于修改学生的信息。

窗口设计如下:

private void btnSubmitUpdate_Click_1(object sender, EventArgs e)
{

    Verification ver = new Verification();
    if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
    {
        MessageBox.Show("请输入中文姓名吧!!!");
        return;
    }
    if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
    {
        MessageBox.Show("身份证至少为18位哦!!!");
        return;
    }

    if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
    {
        MessageBox.Show("请输入正确手机号!!!");
        return;
    }
    int no = int.Parse(stuNo);
        string name = txtName.Text;
        string sex = "";
        if (rdobtn男.Checked)
        {
            sex = rdobtn男.Text;
        }
        else
        {
            sex = rdobtn女.Text;
        }
        string Id = txtID.Text;
        string bj = cboxClass.Text;
        string phone = txtPhone.Text;
        string place = txtPlace.Text;
        Student stu = new Student { stuNo = no,stuName = name, stuSex = sex, stuID = Id, stuClass = bj, stuPhone = phone, stuPlace = place };
        bool result = stuma.Update(stu);
        if (result)
        {
            MessageBox.Show("修改成功");
            getAll();
        }
        else
        {
            MessageBox.Show("修改失败");
        }
        Clearbox();


}

6.测试

6.1测试计划

6.2测试用例设计及执行

6.3测试小结

7. 总结

Logo

快速构建 Web 应用程序

更多推荐