ImageVerifierCode 换一换
格式:DOC , 页数:84 ,大小:1.49MB ,
资源ID:9728852      下载积分:16 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/9728852.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(项目实训-学生信息管理系统.doc)为本站上传会员【精***】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

项目实训-学生信息管理系统.doc

1、 项目实训 学生信息管理系统设计与实现 前言:项目概述 学生信息管理系统介绍 项目名称 学生信息管理系统 代码量 3000行 项目简介 该系统可以帮助教辅人员进行学生基本信息的日常管理和维护;进行学生选课模拟以及重要数据备份等功能。 项目目的 ① 掌握WinForm图形用户界面开发技术 ② 掌握ADO.NET数据库访问技术 涉及的主要技术 WinForm、ADO.NET、SQL Server 数据库环境 Microsoft SQL Server 2000 编程环境 Visual Studio 2005 项目特点 ① 基于.NET采用C#语言开发

2、 ② 项目属于C/S结构程序 技术重点 ① WinForm窗体主要控件的应用 ② 数据库各类对象的应用,例如:存储过程、触发器等 技术难点 ADO.NET数据库访问技术 1 项目需求以及分析设计 1.1 项目需求分析 随着学校规模的不断扩大,每个院系的专业、班级、学生的数量急剧增加,有关学生选课的各种信息量也成倍增长,而很多高校的学生信息管理工作仍停留在复杂的人工操作上,重复工作较多,工作量大,效率低。因此,迫切需要开发学生信息管理系统来提高管理工作的效率。 经过详细调研,我们确定了一个简易的学生信息管理系统的基本需求。 ① 需要进行身份认证登录 系统只允许合法用户

3、进行登陆操作,并且该系统主要面向教学管理人员提供服务(例如教学秘书、辅导员等)。合法用户登陆后可以进行系统的主要功能操作。 ② 数据查询服务 系统需要为服务对象提供两种服务:一是进行学生基本信息的浏览;二是进行学生成绩信息查询服务。 ③ 数据添加服务 系统根据需要可以添加学生基本信息以及添加学生的选课信息等操作。 ④ 数据更新服务 系统根据需要可以更新学生的基本信息。 ⑤ 数据删除服务 系统根据需要可以删除学生的基本信息,但是要求备份删除学生的所有信息。 ⑥ 系统扩展服务 本项目限于篇幅等,在后面主要描述并实现了系统登录、学生基本信息浏览、成绩信息查询、学生基本信息的添加、

4、更新和删除以及学生选课的功能。有关其他实体信息的管理,例如:成绩信息、课程信息等维护功能没有实现。但是大家完全可以根据后面系统提供的框架来扩展系统的其他功能。 此外,根据需要,我们采用基于C/S结构来开发学生信息管理系统。 1.2 项目功能描述 根据需求分析,学生信息管理系统为用户提供的功能主要分为以下几类: 系统管理服务:系统系统登录、注销以及系统退出功能。 数据查询和统计服务:学生基本信息浏览和查询、学生成绩信息查询等功能。 数据添加服务:学生基本信息添加、学生选课、其他可以扩展的功能(院系信息添加、课程信息添加、成绩信息添加、管理员账户信息添加等未实现)。 数据更新服务:学

5、生基本信息更新、其他可以扩展的功能(院系信息更新、课程信息更新、成绩信息更新、管理员密码修改功能等未实现)。 数据删除服务:学生基本信息删除、其他可以扩展的功能(院系信息删除、课程信息删除、成绩信息删除、管理员删除等功能未实现)。 系统介绍服务:系统基本信息介绍、系统使用帮助(未实现)等。 根据以上系统功能描述,绘制学生信息管理系统的功能模块划分如图14.1.2-1所示。 系统登录 系统管理 注销 退出 学生基本信息浏览 学生成绩信息查询 其他功能扩展 学生基本信息添加 学生选课 其他功能扩展 学生基本信息更新 其他功能扩展 学生基本信息删除 其他功能

6、扩展 关于本系统 其他功能扩展 数据查询和统计 数据添加 数据更新 数据删除 帮助 学 生 信 息 管 理 系 统 图1.2-1:“学生信息管理系统”功能模块图 1.3 数据库设计 本系统后台数据库采用的是SQL Server 2000,根据系统的功能描述以及系统的详细设计,学生成绩信息管理系统中各种数据信息之间的关系如图1.3-1所示。 图1.3-1:“学生成绩信息管理系统”数据库关系图 下面针对图1.3-1中的数据库基本表的具体设计进行详细介绍。 表名:admin(管理员表),如表1.3-1所示。 字段名称 数据类型 字段说明 字段属

7、性 userName Varchar(20) 用户名 主键 password Varchar(20) 密码 限制最低6位,不能为空 表1.3-1:管理员表设计说明 表名:Dept(院系表),如表1.3-2所示。 字段名称 数据类型 字段说明 字段属性 deptID Char(4) 院系编号 主键 deptName Nvarchar(30) 院系名称 不许为空且唯一 phone Varchar(12) 联系电话 表1.3-2:院系表设计说明 表名:stu(学生表),如表1.3-3所示。 字段名称 数据类型 字段说明 字段属性 s

8、tuID Char(12) 学号 主键 stuName Nvarchar(20) 姓名 不许为空 stuSex Nchar(1) 性别 只能输入:男、女 stuBirth Datetime 出生日期 要求年龄不能大于30岁 stuPolitic Tinyint 政治面貌 只能输入1、2、3(其中1表示党员,2表示团员,3表示其他) stuDept Char(4) 所属院系 参照院系表院系编号取值 stuResume Ntext 简历 stuPhoto Image 照片 stuPcard Char(18) 身份证编号

9、表1.3-3:学生表设计说明 表名:course(课程表),如表1.3-4所示。 字段名称 数据类型 字段说明 字段属性 courseID Char(6) 课程编号 主键 courseName Nvarchar(30) 课程名称 不许为空,唯一 Credit Tinyint 学分 其值不能大于5 courseTime Varchar(30) 上课时间 stuLimited Tinyint 限选人数 默认值:250 stuPreSelect Tinyint 已选人数 默认值:0,并且不能大于stuLimited 表1.3-4:课程表设

10、计说明 表名:grade(成绩表),如表1.3-5所示。 字段名称 数据类型 字段说明 字段属性 stuID Char(12) 学号 参照学生表学号字段取值 courseID Char(6) 课程编号 参照课程表课程编号字段取值 grade Decimal(5,2) 成绩 成绩必须介于0和100之间 说明:stuID和courseID联合主键 表1.3-5:成绩表设计说明 2 项目详细设计以及功能实现 本章主要任务是从实际应用出发,使学生能够掌握SQL Server 等大型数据库技术,掌握C#+SQL Server等大型数据库软件进行大型数据库桌面应用

11、程序开发的基本过程和基本方法,并能够运用C#进行简单的办公自动化系统编程。 在进行项目详细设计之前,首先创建一个名为StuInfoManage的windows应用程序项目。 2.1 数据库通用访问类的创建 考虑到整个项目中多个窗体的很多位置都需要涉及到数据库的访问操作,所以我们将数据库操作频繁使用的部分代码抽取出来,组合而成数据库访问类,从而避免重复编写相同代码的工作。 常见的数据库访问操作主要有:更新操作(包括插入数据、修改数据和删除数据)、查询操作(指直接执行SQL语句进行数据库操作)、存储过程的执行操作(主要包括返回结果集的存储过程以及使用返回值的存储过程)等。 在StuIn

12、foManage项目中进行以下操作: ① 添加一个类:将其中创建的Class1.cs重命名为SqlHelper.cs。 ② 在该类中添加如下代码: public class abstract class SqlHelper { //获取数据库连接字符串,其属于静态变量且只读,项目中所有文档可以直接使用,但不能修改 public static readonly string ConnectionString = "server = .;database=stuInfoManage;Integrated Security = true;"; ///

13、 执行一个不需要返回值的SqlCommand命令,通过指定专用的连接字符串。 public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters) { SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection

14、connectionString)) { //通过PrePareCommand方法将参数逐个加入到SqlCommand的参数集合中 PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); //清空SqlCommand中的参数列表 cmd.Parameters.Cle

15、ar(); return val; } } /// 执行一条返回SqlDataReader的SqlCommand命令,通过专用的连接字符串。 public static SqlDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters) {

16、 SqlCommand cmd = new SqlCommand(); SqlConnection conn = new SqlConnection(connectionString); try { PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnectio

17、n); cmd.Parameters.Clear(); return rdr; } catch { conn.Close(); throw; } /// 执行一条返回DataSet的SqlCommand命令,通过专用的连接字符串。 public static DataSet ExecuteDataset(string connec

18、tionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters) { SqlCommand cmd = new SqlCommand(); using (SqlConnection cn = new SqlConnection(connectionString)) { cn.Open(); Prepare

19、Command(cmd, cn, (SqlTransaction)null, commandType, commandText, commandParameters); SqlDataAdapter da = new SqlDataAdapter(cmd); DataSet ds = new DataSet(); da.Fill(ds); cmd.Parameters.Clear();

20、 return ds; } } /// 为执行命令准备参数 private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, CommandType cmdType, string cmdText, SqlParameter[] cmdParms) { //判断数据库连接状态 if (conn.St

21、ate != ConnectionState.Open) conn.Open(); cmd.Connection = conn; cmd.CommandText = cmdText; //判断是否需要事物处理 if (trans != null) cmd.Transaction = trans; cmd.CommandType = cmdType; if (cmdParms

22、 != null) { foreach (SqlParameter parm in cmdParms) cmd.Parameters.Add(parm); } } /* * 功能:调用存储过程,并返回存储过程返回值的通用方法 * 要执行的存储过程的名称 *

23、执行的存储过程中参数的集合 * 区分是查询(1)操作还是更新(2)操作 * 返回存储过程的返回值 */ public int ProcReturnValue(string procName, SqlParameter[] cmdparam,int DataOpType) { SqlConnection sqlconn=new SqlConnect

24、ion(ConnectionString); try { if (sqlconn.State != ConnectionState.Open) { sqlconn.Open(); } SqlCommand sqlcmd = new SqlCommand(); sqlcmd.Connection = sqlconn;

25、 sqlcmd.CommandText = procName; sqlcmd.CommandType = CommandType.StoredProcedure; if (cmdparam != null) { foreach (SqlParameter param in cmdparam) sqlcmd.Parameters.Add(param);

26、 } sqlcmd.Parameters.Add(new SqlParameter("@ReturnValue",SqlDbType.TinyInt)); sqlcmd.Parameters["@ReturnValue"].Direction = ParameterDirection.ReturnValue; if (DataOpType == 1) { sqlcmd.ExecuteScalar();

27、 } if(DataOpType == 2) { sqlcmd.ExecuteNonQuery(); } return Convert.ToByte(sqlcmd.Parameters["@ReturnValue"].Value); } catch

28、 { throw; } finally { sqlconn.Close(); } } } 至此,数据库通用访问类创建完毕。我们可以用此类完成几乎所有的数据库操作。 2.2 系统主界面设计与功能实现 (1)界面设计的基本要求 ① 界面设计要完整的体现用户的功能需求,并且美观大方。 ② 界面设计的交互操作过程符合用户的习惯性工作过程。 (2)系统主界面设计 在stuInfoManage

29、项目中将Form1.cs重命名为MainForm.cs,并参照表格2.2-1的说明设置MainForm窗体的属性。 属性名 设置 IsMdiContainer True Text 学生信息管理系统 StartPosition CenterScreen WindowState Maximized 表格2.2-1:主窗体主要参数设置 (3)系统菜单设计 根据需求,系统需要在主窗体上创建一个菜单系统来引导用户的操作,至于菜单系统中的各级菜单显示字符以及命名参见表格2.2-2说明。 主菜单 子菜单 命名 系统管理 SystemManageMenuItem

30、系统登陆 LoginInMenuItem 注销 LoginOutMenuItem 退出 SystemExitMenuItem 数据查询 DataQueryMenuItem 学生基本信息浏览 StuBasicInfoQueryMenuItem 学生成绩信息查询 StuGradeInfoQueryMenuItem 课程成绩信息查询 CourseGradeQueryMenuItem 数据添加 DataAddMenuItem 学生基本信息添加 StuBasicInfoInsertMenuItem 数据更新 DataUpdateM

31、enuItem 学生基本信息更新 StuBasicInfoUpdateMenuItem 数据删除 DataDeleteMenuItem 学生基本信息删除 StuBasicInfoDeleteMenuItem 帮助 HelpMenuItem 关于本系统 AboutSystemMenuItem 表格: 2.2-2 菜单系统主要参数设置 (4)系统菜单功能初始状态的设定 由于该系统需要合法用户登陆成功后才能操作相应的系统主要功能,所以系统的主要功能的初始状态是不可用的。此外,当系统登录成功后需要打开系统主要功能锁定。为了实现该功能以及方便以后操作,首

32、先在MainForm类中添加以下两个私有方法: //将系统主要功能调用的菜单锁定的方法 private void MenuStatusOFF() { DataQueryMenuItem.Enabled = false; DataAddMenuItem.Enabled = false; DataUpdateMenuItem.Enabled = false; DataDeleteMenuItem.Enabled = false; } //打开系统主要功能锁定状态的方法 private void MenuStatusOn() { DataQueryMenuItem.En

33、abled = true; DataAddMenuItem.Enabled = true; DataUpdateMenuItem.Enabled = true; DataDeleteMenuItem.Enabled = true; } 然后,双击MainForm窗体类的Load事件,在该事件中添加如下代码: MenuStatusOFF(); (5)“注销”功能的实现 功能:将系统主要功能设置为锁定状态,以方便其他用户登陆使用。 具体操作:选中“注销”菜单,在注销菜单的Click事件中添加如下代码。 MenuStatusOFF(); (6)“退出”功能的实现 当系统退出时

34、需要提示是否真的退出等提示选项等,实现该功能在MainForm窗体类中进行如下操作: ① 在“退出”菜单的Click事件中添加如下代码: this.Close(); ② 在MainForm窗体类的FormClosing事件中添加如下代码: DialogResult mgr = MessageBox.Show("您确定要退出学生信息管理系统吗?", "信息提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question, MessageBoxDefaultButto

35、n.Button1); if (mgr == DialogResult.Cancel) e.Cancel = true; 至此,系统主界面以及菜单系统的主要设计任务已经完毕。 2.3 登录窗体的设计与功能实现 (1)功能描述 该步骤要实现两个功能: 1、点击“系统管理”主菜单下“系统登录”功能选项,打开“系统登陆”窗体;在该窗体处于打开状态时,我们不能操作主界面包括系统菜单的所有功能,除非关闭该窗体以后,才能继续操作; 2、系统启动完成后,系统主要功能处于不可用状态,当登陆成功后,打开功能锁定。 在本案例中,解决第一个问题的方法是使用模式对话框,解决第二个问题的方法是在

36、登陆窗体中设置一个“系统菜单状态”变量(SysMenuStatus),通过该变量的真假来判断是否打开系统的功能锁定。 (2)流程图 针对功能描述,我们绘制系统登录功能的操作流程图如图2.3-1所示。 启动主窗体 主菜单:系统管理 子菜单:系统登陆菜单 输入用户名和密码 信息提示 数据验证 提示登录成功信息,打开功能菜单锁定并结束 登陆 成功 失败 图2.3-1:“系统登录”功能实现流程图 (3)数据库设计 本窗体主要功能的实现所涉及的用户登陆合法性验证采用带返回值的存储过程来实现。具体操作过程为:在SQLServer查询分析器中输入以下代码后并运行,创建存储过

37、程LoginJudge,用于判断登陆用户的合法性验证。 Use stuInfoManage If exists(select * from sysobjects where name = ‘LoginJudge’ and type = ‘P’) Drop procedure LoginJudge go create procedure LoginJudge ( @userName nvarchar(100), @passWord varchar(100) ) as if not exists(select * from admin where userNam

38、e = @userName) return 1 -- 表示不存在该用户 else begin if not exists(select * from admin where userName = @userName and [password]=@passWord ) return 2 --表示密码错误 else return 3 --表示登陆成功 end GO 代码输入完毕后点击运行按钮,生成LoginJudge存储过程。 (4)界面设计 首先,在stuInfoManage项目中添

39、加一个Windows窗体,将其窗体类名改为:SystemLoginForm,设置该窗体的属性Text为“系统登录”,并添加一个公共数据成员: public Boolean SysMenuStatus = false; 其次,在该“系统登录”窗体上添加必要控件并设置相关属性,具体设置参照表格14.2.3-1说明。 控件类型 命名 属性 Lable1 采用系统默认 Text:系统登陆 Lable2 采用系统默认 Text:用户名: Lable3 采用系统默认 Text:密码: ComboBox UserNameComboBox 无 TextBox Passw

40、ordTextBox PasswordChar:* Button LoginButton Text:登陆 Button ResetButton Text:重置 Button ExitButton Text:退出 表格14.2.3-1:“系统登录”窗体上面控件的主要属性设置表格 其他显示样式以及效果可以根据实际情况具体调节,例如字体的大小和颜色等。具体设计效果可以参照图2.3-2。 图2.3-2:“系统登录”窗体设计效果图 (5)代码实现 5.1 菜单功能调用的实现 首先,在系统主界面类MainForm类中添加一个私有数据成员,该成员为系统登陆窗体的一个实例,

41、即在MainForm类中添加如下代码: SystemLoginForm LoginForm = new SystemLoginForm(); 其次,双击“系统登陆”菜单,在“系统登陆”菜单的Click事件中添加以下代码: //判断该对象是否存在,如果不存在,就创建它 if (LoginForm.IsDisposed) { LoginForm = new SystemLoginForm(); } //以模式对话框的形式显示LoginForm窗体 LoginForm.ShowDialog(); //登陆窗体运行完毕后,判断登陆窗体的属性SysMenuStatus的取值 /

42、/如果登陆窗体中系统菜单状态变量的值为真,打开系统菜单主要功能的锁定状态 if (LoginForm.SysMenuStatus == true) { MenuStatusOn(); } 至此,登录窗体的功能调用已经实现。 5.2 “登陆窗体”相应功能的实现 ① “用户名”组合框的数据初始化 系统界面启动后,自动加载数据库中合法的管理员的用户名,在用户名组合框中列示以便选择,当然也允许用户自行输入个人的用户名。 实现该功能需要在SystemLoginForm窗体类的Load事件中添加以下代码,为UserNameComboBox数据进行初始化操作: string sqls

43、tr = "select userName from admin"; DataSet userNameDS = SqlHelper.ExecuteDataset(SqlHelper.ConnectionString,CommandType.Text,sqlstr); UserNameComboBox.DataSource = userNameDS.Tables[0]; UserNameComboBox.DisplayMember = "userName"; ② “系统登陆”窗体的初始化 我们在启动系统登录窗体后,要

44、使各个控件处于数据选择或输入状态。要实现该功能,首先,我们需要在SystemLoginForm窗体类中添加私有方法用于控件初始状态设定: private void ComponentReset() { UserNameComboBox.Text = ""; PasswordTextBox.Text = ""; UserNameComboBox.Focus(); } 然后在SystemLoginForm窗体的载入事件中添加该方法的调用: ComponentReset(); ③ “重置”按钮功能的实现 重置功能主要实现清空已经输入或选择的数据,以便用户重新输入。完成此功能,需要

45、在“重置”按钮的Click事件中添加以下代码实现控件状态重置: ComponentReset(); ④ “退出”按钮功能的实现 在“退出”按钮的Click事件中添加以下代码: this.Close(); ⑤ “登陆”按钮功能的实现 点击登陆按钮后,首先要根据需要判断用户名和密码是否非空,密码长度是否大于6位。如果违反这些基本条件,直接给出相应提示信息。如果具备这些基本条件,则调用存储过程LoginJudge判断用户的合法性,并根据返回值进行应有的操作和相应的提示信息。 实现该功能,需要在“登陆”按钮的Click事件中添加如下代码: private void LoginButt

46、on_Click(object sender, EventArgs e) { string userName = UserNameComboBox.Text.Trim(); string passWord = PasswordTextBox.Text.Trim(); if (userName.Length == 0) { MessageBox.Show("用户名不能为空!请重新输入!!!", "信息提示", MessageBoxButtons.OK,MessageBoxIcon.Warning); UserNameComboBox.Focus(); } else {

47、 if (passWord.Length == 0) { MessageBox.Show("密码不能为空!请重新输入!!!","信息提示", MessageBoxButtons.OK,MessageBoxIcon.Warning); PasswordTextBox.Text = ""; PasswordTextBox.Focus(); } else if (passWord.Length < 6) { MessageBox.Show("密码长度不能短于6位,请重新输入!!!", "信息提示", MessageBoxButtons.OK,MessageBoxIcon.War

48、ning); PasswordTextBox.Text = ""; PasswordTextBox.Focus(); } else { SqlParameter[] cmdparam = new SqlParameter[]{ new SqlParameter("@userName",userName), new SqlParameter("@passWord",passWord) }; int loginFlag = SqlHelper.ProcReturnValue("LoginJudge", cmdparam,1); switch (loginFlag)

49、 { case 1: MessageBox.Show("不存在该用户,请重新输入或者选择你要登陆的用户名!!!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); ComponentReset(); break;

50、 case 2: MessageBox.Show("用户名存在,但密码输入密码错误!!!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); PasswordTextBox.Clear(); PasswordTextBox.Focus();

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服