留言板系统的设计与实现(共19页).doc

上传人:飞****2 文档编号:14989075 上传时间:2022-05-10 格式:DOC 页数:19 大小:268KB
返回 下载 相关 举报
留言板系统的设计与实现(共19页).doc_第1页
第1页 / 共19页
留言板系统的设计与实现(共19页).doc_第2页
第2页 / 共19页
点击查看更多>>
资源描述

《留言板系统的设计与实现(共19页).doc》由会员分享,可在线阅读,更多相关《留言板系统的设计与实现(共19页).doc(19页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上目 录一、设计目的留言板管理系统主要是提供大众一个操作系统,便于网上交流,谈论。功能块的响应操作分别由对应的子模块实现。通过互联网把你想说的话及想问的事发表出去,方便大家交流。同时,留言板的后台通过一个简化的自动的信息管理系统,使网友留言管理工作系统化,规范化,自动化,从而达到提高网络作用和管理的目的。本设计研究的留言板是一种电子便签管理系统,是用ASP和SQL Sever编写的网络应用程序,留言操作相对简单,在进入网站后,可看到留言内容。留言板提供完备的信息发布功能,在网络用户交流中有很大的作用。而我们这个留言板仅仅是简单的留言和管理员对留言进行操作的工具,该留言板

2、简单实用,而且具备了大多数留言板的基本功能。科学技术在不断地提高,计算机网络技术也日渐成熟,器强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用,现在许多国外和国内的网站均实现了网上注册、网上查询、网上发表信息等一系列的网上信息服务。通过计算机网络实现了足不出户就可以了解各种信息、咨询问题、搜索资料等,有了这样的一个网络平台,节省了大量的人力物力。二、需求分析对于一个系统,我们要从其性能、功能、用户界面、安全性等反面考虑,系统必须完成的功能如下:1.留言板管理系统前端的主要功能是:(1)用户注册。(2)用户登录。(3)用户发表内容。(4)用户修改密码。(5)用户浏览

3、留言内容。2.留言板管理系统后台管理的主要功能:(1)管理员登陆。 (2)管理员删除用户发帖信息。3.留言板管理系统性能要求:(1)页面响应速度快。(2)页面美观整洁。三、 模块分析及设计模块分析与设计是对一定范围内的不同功能或相同功能不同性能、不同规格的产品进行功能分析的基础上,划分并设计出一系列功能模块,通过模块的选择和组合构成不同的顾客定制的产品,以满足市场的不同需求。在上节内容中,已对本系统的所需求的功能进行了设计,结合其功能,制作出本系统的功能模块图,如图所示:留言板系统普通用户管理员登陆修改密码留言查看留言注册用户登陆删除留言四、数据库设计4.1系统概念结构设计4.1.1数据字典数

4、据字典是系统中各类数据描述的集合,是进行详细的数据收集和数据分析所获得的主要成果,数据字典是对系统所用到的所有表结构的描述。login表基本信息序号字段别名1Uname用户名2Upass密码3Email邮箱4Phone电话5Addr地址management表基本信息序号字段别名1Uname账号2Upass密码messages表基本信息序号字段别名1ID序号2Uname用户名3Title主题4Content内容5Times时间4.1.2系统E-R图E-R图提供了表示实体(即数据对象)、属性和联系的方法,用来描述现实世界的概念模型。n1用户用户名密码邮箱电话地址留言内容序号用户名主题内容时间发表留

5、言账号密码管理员删除4.1.3系统流程图流程图是由一些图框和流程线组成的,其中图框表示各种操作的类型,图框中的文字和符号表示操作的内容,流程线表示操作的先后次序。留言内容修改初始密码提交登陆登陆?留言是留言否留言内容新用户注册密码4.2逻辑结构设计逻辑结构设计就是把概念结构设计阶段所设计好的基本E-R图转换为与SQL数据库所支持数据模型相符合的逻辑结构。关系模型如下所示:a) login表(用户名,密码,邮箱,电话,地址)b) messages表(序号,用户名,主题,内容,时间)c) management表(账号,密码)五、制作过程及要点5.1 类库建立public class dbpubli

6、c db() public static SqlConnection CreateConnection() SqlConnection con = new SqlConnection(server=(Local);database=message;Integrated Security=True); return con; 5.2验证码 protected void Page_Load(object sender, EventArgs e) this.GenImg(this.GenCode(4); Sessionimage = this.GenCode(4); private string G

7、enCode(int num) string source = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z ; string code = ; Random rd = new Random(); for (int i = 0; i num; i+) code += sourcerd.Next(0, source.Length); return code; private void GenImg(string code)

8、Bitmap myPalette = new Bitmap(60, 20); Graphics gh = Graphics.FromImage(myPalette); Rectangle rc = new Rectangle(0, 0, 60, 20); gh.FillRectangle(new SolidBrush(Color.Blue), rc); gh.DrawString(code, new Font(宋体, 16), new SolidBrush(Color.White), rc); myPalette.Save(Response.OutputStream, System.Drawi

9、ng.Imaging.ImageFormat.Jpeg); gh.Dispose(); myPalette.Dispose(); 5.3留言内容界面图(一) 打开网站后,首先浏览到留言内容(图一),当用户要留言的时候,则跳转到留言页面(图二)。 留言事件代码:protected void Button3_Click(object sender, EventArgs e) Response.Redirect(messages.aspx); 5.4留言页面图(二) 在跳转到该页面之前,系统会检测用户是否登录,如果用户未登录,则直接跳转到用户登录页面(图三),如果用户登录,则可提交留言。在此页面,可

10、统计注册会员的人数,用户名为用户登陆时,系统用session对象传递自动显示。 留言事件代码: protected void Page_Load(object sender, EventArgs e) try this.Label1.Text = SessionUname.ToString(); SqlConnection con = db.CreateConnection(); con.Open(); string strsql = select count(*) from login; SqlCommand cmd = new SqlCommand(strsql, con); SqlDat

11、aReader rd = cmd.ExecuteReader(); while (rd.Read() this.Label2.Text = rd0.ToString(); rd.Close(); con.Close(); catch Response.Write(alert(用户未登录成功!); Response.Redirect(login.aspx); protected void Button1_Click(object sender, EventArgs e) SqlConnection con = db.CreateConnection(); con.Open(); string s

12、trsql=insert into messages values(+Label1 .Text +,+TextBox2.Text +,+TextBox3 .Text +,+DateTime .Now .ToString ()+); SqlCommand cmd =new SqlCommand (strsql ,con ); cmd .ExecuteNonQuery(); con.Close (); Response.Write(alert(留言成功!); Response .Redirect (messageout.aspx);取消事件代码: protected void Button2_Cl

13、ick(object sender, EventArgs e) TextBox2.Text = ; TextBox3.Text = ; 5.5登录界面图(三) 在登录界面,用户首先选择角色,用户则跳转到留言内容界面(图一),管理员则进入管理界面(图六)。在此页面,用户还可以注册用户、修改密码。注册用户则进入注册界面(图四),修改密码则进入修改密码界面(图五)。登录事件代码:protected void Page_Load(object sender, EventArgs e) this.ImageButton1.ImageUrl = image.aspx; protected void But

14、ton1_Click(object sender, EventArgs e) if (this.TextBox1.Text = ) Label1.Text = 用户名不能为空!; if (this.TextBox2.Text = ) Label1.Text += 密码不能为空!; if (this.TextBox3.Text = ) Label1.Text += 请输入验证码!; else SqlConnection con = db.CreateConnection(); con.Open(); if (RadioButtonList1.SelectedItem.Value.ToString

15、().Trim() = 用户) string strsql = select Upass from login where Uname= + this.TextBox1.Text + and Upass= + this.TextBox2.Text + ; SqlCommand cmd = new SqlCommand(strsql, con); DataSet ds = new DataSet(); SqlDataReader dr = cmd.ExecuteReader(); try if (dr.Read() string aa = this.TextBox3.Text.ToString(

16、); if (aa = Convert.ToString(Sessionimage) SessionUname = this.TextBox1.Text.ToString(); Response.Redirect(messageout.aspx); else Label1.Text = 验证码错误,注意大小写!; else Label1.Text = 用户名或者密码错误!; catch Label1.Text = 输入的用户名不存在!; con.Close(); else if (RadioButtonList1.SelectedItem.Value.ToString().Trim() = 管

17、理员) string strsql1 = select Upass from management where Uname= + this.TextBox1.Text + and Upass= + this.TextBox2.Text + ; SqlCommand cmd = new SqlCommand(strsql1,con); DataSet ds = new DataSet(); SqlDataReader dr = cmd.ExecuteReader(); try if (dr.HasRows) string aa = this.TextBox3.Text.ToString(); i

18、f (aa = Convert.ToString(Sessionimage) SessionUname = this.TextBox1.Text.ToString(); Response.Redirect(management.aspx); else Label1.Text = 验证码错误,注意大小写!; else Label1.Text = 用户名或者密码错误!; catch Label1.Text = 输入的用户名不存在!; con.Close(); 5.6 注册页面图(四) 用户注册成功后,将跳转到登录界面(图三)。注册事件代码: protected void Button1_Click

19、(object sender, EventArgs e) try SqlConnection con = db.CreateConnection(); con.Open(); SqlCommand cmd = con.CreateCommand(); string strsql = string.Format ( insert into login (Uname,Upass,Email,Phone,Addr) values(0,1,2,3,4) , TextBox1.Text,TextBox2.Text,TextBox4.Text,TextBox5.Text,TextBox6.Text); c

20、md.CommandText = strsql; cmd.ExecuteNonQuery(); Response.Write(alert(注册用户成功!); Response.Redirect(login.aspx); con.Close(); catch Response.Write(alert(用户名存在,请选择其它用户名); 5.7修改密码界面图(五) 用户修改密码成功后,不在进行登录,直接进入留言板内容界面(图一)确认事件:protected void Button1_Click1(object sender, EventArgs e) SqlConnection con = db.C

21、reateConnection(); SqlCommand cmd = con.CreateCommand(); con.Open(); string strsql1 = select Upass from login where Uname= + this.TextBox1.Text + and Upass= + this.TextBox4.Text + ; cmd.CommandText = strsql1; DataSet ds = new DataSet(); SqlDataReader dr1 = cmd.ExecuteReader(); if (dr1.Read() dr1.Clo

22、se(); SqlCommand cmd2 = con.CreateCommand(); string strsql = string.Format(update login set Upass= + TextBox2.Text + where Uname= + TextBox1.Text + ); cmd2.CommandText = strsql; cmd2.ExecuteNonQuery(); Response.Write(alert(修改密码成功!); Response.Redirect(messageout.aspx); SessionUname = this.TextBox1.Te

23、xt.ToString(); else Response.Write(alert(用户名或原始密码错误!); con.Close(); 5.8管理员界面图(六) 在此界面,只授予管理员删除留言的权限。设计总结经过近一个星期的努力,终于设计出一个基本达到要求的设计。其功能比较完整,用户界面良好,但是也存在着一些缺陷:(1)仅授予管理员删除留言的权限(2)不能针对性的回复留言(3)留言内容仅支持一般汉字等等。这一段时间的努力,最后的结果固重要,但更重要的是它让自己了解了设计的一般过程。在做一个项目的时候,首先是进行需求分析,既各种功能需求以及系统结构都要在需求分析中做出来。接下来做的就是逻辑结构设

24、计,通过逻辑结构设计出数据库。然后就是详细设计,通过需求分析中对各种功能的描述,利用自己所学的知识编写出相应的功能模块界面,这是个比较繁琐的阶段,需要大量的编写和修改各部分代码,以确保系统整体的可运行性。最后就到了验收成果的阶段,通过系统的运行测试,了解系统的一些问题和不足,并做出一定的修改,最终得到了现在的成果。这个学期的学习中,我终于体会到Asp.Net和SQL Server 2005功能的功能丰富,表达能力强,使用灵活方便,应用面广。随着社会的发展,人类需要处理的数据越来越多,对数据管理的要求也越来越重要。软件的发展也从面向程序发展成为面向数据。附录参考文献:1、 陈志泊主编数据库原理及应用教程人民邮电出版社2、 闫洪亮主编ASP.NET程序设计 上海交通大学出版社 专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁