基于NET的同学录系统的设计与实现Word格式.docx
- 文档编号:19896936
- 上传时间:2023-01-12
- 格式:DOCX
- 页数:46
- 大小:1.33MB
基于NET的同学录系统的设计与实现Word格式.docx
《基于NET的同学录系统的设计与实现Word格式.docx》由会员分享,可在线阅读,更多相关《基于NET的同学录系统的设计与实现Word格式.docx(46页珍藏版)》请在冰豆网上搜索。
根据我国IT行业发布的报告表明,近年来,我国互联网发展呈快速增长趋势,网民的数量已达8700万,逼近世界第一,与此同时,交流社区应用被广泛接受,这些社区的存在都是为了加强。
同学录系统的成功在很大程度上是因为它是一个真实的社交网络,用户是网络应用的中心。
计算机和网络技术的不断进步和提升,使人类的信息传播方式和生活方式都得到了很大的改变,而各个产业都在自己的领域中不同程度的融入了计算机及网络技术,对行业的发展起了很大的推动作用。
基于B/S模式的同学录系统克服了传统联系方式所带来的消息陈旧、更新困难、不便于实时联系等种种弊端,通过提供完善的同学录服务和规范同学录的管理,为班级同学之间的交流和联系提供一个平台,达到增进同学与母校之间的感情,方便同学们联系的目的。
本课题设计利用C#、.NET和SQLServer2005技术实现,要到达的预期效果主要有:
(1)友好的人机交互界面。
(2)实现用户注册、用户登录、资料修改、上传图片、留言等功能。
(3)实现班级注册、班级管理功能。
第二章程序技术相关知识
Csharp(又被简称为"
C#"
)是微软公司在2006年6月发布的一种完全面向对象和可视化的编程语言。
而XML(即可扩展标记语言)与HTML一样,都是SGML(StandardGeneralizedMarkupLanguage,标准通用标记语言)。
XML是跨平台的、依赖于内容的技术,是当前处理结构化文档信息的有力工具;
又是一种简单的数据存储语言,使用一系列简单的标记描述数据。
2.1C#简介
C#是微软公司推出的一种由事件驱动,完全面向对象和可视化的编程语言。
开发人员可以通过C#编写在.NETFramework上运行的各种安全、可靠的应用程序。
使用C#可以创建传统的Windows客户端应用程序、XMLWebServices、分布式组件、客户端/服务器应用程序、数据库应用程序等。
2.2ASP.NET简介
A是建立在通用语言运行时刻库(CLR)上的应用程序框架。
他用来在服务器端构建功能强大的web应用程序。
A提供了几个超越以前web开发模式的优点:
(1)增强的性能
A是运行在服务器端的编译后的CLR代码,而不是像ASP那样解释执行。
A利用提前绑定,即时编译,本地优化和缓存服务来提高性能。
所有这一切,性能远远大于你以往写的每一行代码。
(2)世界级水平的开发工具支持
在VisualStudio.net的集成开发环境(IDE)中,A框架由丰富的工具箱和设计器组成。
所见即所得的(WYSIWYG)编辑方式、拖放服务器控件、以及自动部署,仅仅是这一强大工具所提供的一少部分功能。
(3)强大而富有弹性
由于是基于(CLR)的,因此整个.net平台的强大和富有弹性,同样可以应用于web应用程序开发者。
.net框架的类库、消息以及数据访问解决方案,都可以无缝集成到web。
A也是语言中立的,因此你可以选择你最熟悉的语言,或者通过几种语言来共同完成一个应用。
而且,CLR的互用性可以保证你升级到asp.ent的时候,现存的基于COM的开发投资依然保留。
(4)简单
A使执行常用的工作变得很容易,比如从简单的表单提交、客户端验证,到部署和站点配置。
例如,允许你建立用户接口,实现页面和逻辑代码的分离,同时,就像vb的表单执行模式那样来处理事件(也就是说,由页面驱动模式变成了事件驱动模式)。
此外,CLR简化了部署,用来管理代码服务,例如自动参照和垃圾回收。
(5)易于管理
A使用一个基于文本的、分层次的配置系统,它简化了服务器端环境和web应用程序的设置。
由于配置信息用纯文本格式保存,新的设置不需要本地管理工具的支持。
这种“零本地支持”的理念也同样应用到了部署应用程序。
A应用程序部署到服务器,简化为复制必要的文件到服务器。
在部署,甚至替换正在运行的变异代码的时候,也不需要重新启动服务器。
(6)可伸缩性和有效利用性
A被设计成可伸缩的,能为集群和多处理器环境设计提高性能。
而且,运行时刻密切监视和管理进程,这样,如果发生了错误的行为,例如漏洞和死锁,新的进程会在当前位置建立,来帮助你的应用程序继续处理事件请求。
(7)可订制和扩展
A提供一种良好的扩充结构,允许开发者在适当的级别“插入”他们的代码。
事实上,使用自己的编写的组件可以扩展或者替换运行时刻的任何子组件。
执行自定义验证或状态服务变得前所未有的容易。
(8)安全性
内建的windows验证和每一个应用程序的独立配置,你可以认为你的应用程序是安全的。
第三章需求分析
同学录系统是指以互联网形式接入,通过搭建系统服务,向互联网接入用户提供同学之间联系交流的平台。
通过同学录系统,用户可以将自己最近的所得所失,生活感悟与同学朋友分享交流。
通过该平台,用户可以实现注册登陆、个人信息修改、注册班级、图片上传、发表留言、聊天等功能。
3.1功能需求
本系统主要是给同学朋友之间提供一个联系交流的平台。
如果是非注册会员,只能浏览校友录首页和校友搜索。
如果已经注册但没有班级,可以在非注册会员的基础上查看并修改个人信息,创建班级或者申请加入班级。
如果已经有班级,可以登录班级主页、查看班级通讯录、修改资料、上传图片、发表留言和聊天室聊天。
如果是管理员,不仅可以实现普通班级成员的功能,还可以进行班级管理。
同学录系统是以B/S构架为基础的用来联系交流的网站。
网站前台使用C#语言开发,后台连接数据库。
总体分布如图3.1所示:
图3.1系统流程图
3.1.1前台功能需求
网站前台是使用者最直接接触的东西,包括是否能够让客户很轻松,方便地登录和注册,请求响应时间、主机连接时间、页面布局等。
用户注册:
使用同学录之前必须先注册成为网站用户,每个用户都有一个独立的ID号,注册时需要提供一些基本信息,便于管理人员管理,也便于同学朋友之间的联系。
用户登录:
输入用户名和密码登录。
班级注册:
如果班级不存在,需要创建班级;
如果已经有班级,申请加入班级等待管理员审核。
班级通讯录:
查看班级成员的基本资料和联系方式。
上传图片:
上传图片,与同学朋友分享。
发表留言:
用户可以在班级留言薄发表自己的所得所失,生活感悟。
聊天室:
用户与用户之间可以通过聊天室聊天交流。
3.1.2后台功能需求
后台的作用是为前台运行必要的数据支持和供网站管理员对网站进行管理。
个人信息管理:
注册用户可以对自己的基本资料和联系方式进行修改。
班级管理:
管理员可以对申请加入本班的用户进行审核,保证班级中的用户身份都是真实的,还可以委任班长。
班长可以更改班级宣言。
同学录功能使用图如图3.2所示:
图3.2同学录功能使用流程图
第四章网站概要设计
本系统功能可分为前台与后台两个功能模块。
前台存在四种用户角色(非注册用户、注册用户、班级待定成员与班级成员),非注册用户只能浏览首页及校友搜素;
注册用户,可以创建班级或申请加入班级;
班级待定成员等待管理员审核;
班级成员,可以实现各种班级功能。
后台主要实现网站注册用户个人信息管理和班级管理。
4.1模块的划分与功能设计
通过对用户需求调研并分析,确定系统应具备的功能,包括:
注册登录,班级注册,班级通讯录,上传图片,班级留言,班级聊天室,班级管理,修改信息,校友搜索。
各模块的具体功能设计如下:
(1)注册登录功能
该系统需要用户注册成为会员,才能使用同学录。
(2)班级注册
注册登录成功后,需要创建班级或申请加入班级才能实现各种班级功能,比如查看班级通讯录、上传图片、留言等功能。
(3)班级通讯录
班级成员可互相查看联系方式。
(4)上传图片
(5)班级留言
与同学朋友交流所得所示,生活感悟。
(6)班级聊天室
可以对大家或是某个同学聊天。
(7)班级管理
管理员对申请加入的同学审核身份还可以委任班长;
(8)修改资料
用户可以根据自身需要对原有资料进行修改。
(9)校友搜索
不同身份的用户都能够进行校友搜索,查找校友。
用户管理功能结构图如图4.1所示:
图4.1用户管理功能结构图
4.2功能模块的初步设计
为了配合模块的划分和实现预期的功能,将功能模块按照网站的页面划分为17个:
校友录首页、用户注册页面、确认信息页面、注册成功页面、用户登陆页面,个人信息页面、校友资料页面、班级注册页面、班级主页、班级通讯录页面、上传图片页面、班级留言页面、班级聊天室页面、管理员管理页面、审核同学页面、委任班长页面、班长管理页面。
各个页面后写实现功能的代码,在App_Code里面写定义一些数据访问对象,以及连接数据库和操作或者访问数据库的方法。
模块组织结构图如图4.2所示:
图4.2模块组织结构
4.3数据库设计
同学录系统使用SQLServer2005作为系统后台数据库。
系统共有5个表,分别是用户表、班级表、图片表、留言表和聊天表。
用户管理:
系统管理员能够对系统中的用户进行维护,包括用户注册、修改、删除和查看等操作。
审核同学,委任班长,班级宣言修改。
4.3.1users用户表
用户表包含所有在同学录系统中注册的用户的信息,包括用户名、密码、真实姓名、性别等信息,字段说明如表4.1:
表4.1users字段描述
名称
类型
大小
是否允许为空
描述
用户编号
Int
4
否
用户编号,自增1,表主键
用户名
Varchar
50
真实姓名
Char
6
是
用户真实姓名
密码
用户密码
生日
用户生日
电子邮件
Text
16
用户电子邮件
性别
用户性别
头像
用户头像
主页地址
用户主页地址
用户QQ
电话
用户电话
移动电话
用户移动电话
邮政编码
用户邮政编码
通信地址
用户通信地址
格言
用户格言
身份
用户身份
注册日期
Datetime
8
用户注册日期
积分
用户积分
班级号
用户班级号
已有班级
用户已有班级
审核状态
10
用户审核状态
id
用户id
isadmin
Bit
1
是否为管理员
isonline
用户是否在线
lastinfo
最新信息
4.3.2class班级表
班级表表包含班级号、班级名、入学年份、注册日期、班级主页、班级创始人、管理员、注册人数、宣言和班长,它的字段说明如表4.2:
表4.2class字段描述
班级编号,自增1,表主键
班级名
班级名称
入学年份
班级注册日期
班级主页
班级创始人
管理员
班级管理员
宣言
100
班级宣言
班长
注册人数
班级注册人数
4.3.3image图片表
图片表包含图片id、图片、上传者、班级号和上传时间,它的字段如表4.3:
表4.3image字段描述
Id
照片Id,自增1,表主键
图片
图片地址
上传者
上传时间
4.3.4classly留言表
留言表包含主题、内容、发表时间、留言人、班级号、用户编号和ly_top,它的描述字段如表4.4:
表4.4classly字段描述
主题
留言主题
内容
500
留言内容
发表时间
留言人
ly_top
排序
4.3.5Chatinfo聊天表
聊天表包含id、user_from、user_to、content、expression、color、ispublic和sendtime,它的字段说明如表4.5:
表4.5Chatinfo字段描述
聊天记录Id,自增1,表主键
user_from
聊天发送人
user_to
聊天接收人
content
聊天内容
expression
255
聊天表情
color
聊天文字颜色
ispublic
聊天是否公开
sendtime
聊天发送时间
第五章网站详细设计
这一章节主要讲述了网站的各个模块的详细设计,如用户注册、用户登录、资料修改、图片上传等模块的设计。
5.1校友录主页(Default.aspx)
系统主页采用静、动相结合的方式,即静态的主画面和动态的内容相结合,体现班级的勃勃生气。
静态主页方式介绍校友录公告、最近加入同学、校友搜索、在线信息、登陆系统,管理功能,相册功能,聊天室功能,就利用ASP.NET语言与SqlServer数据库相结合的技术建立数据库查询管理系统,采用交互式的动态的web画面来实现。
校友录主页界面如图5.1所示:
图5.1校友录主页界面
5.2用户注册页面(注册.aspx)
5.2.1功能描述
登录到用户注册页面,输入用户名,点击“测试用户名”按钮,弹出一个对话框,如果用户名可用,输入密码。
用户注册界面如图5.2所示。
点击“下一步”按钮,显示用户信息页面,填写具体信息。
界面如图5.3所示。
输入完成后点击“确认”,显示确认信息页面,页面显示用户填写的具体信息,界面如图5.4所示。
用户点击“确认”按钮,显示用户注册成功页面,用户注册成功。
界面如图5.4所示:
图5.2用户注册界面
图5.3填写具体信息界面
图5.4确认信息界面
图5.5注册成功界面
5.2.2代码设计
首先判断用户名是否可用,如果用户名没有被人使用过,弹出“恭喜你,该用户名可以使用!
”对话框,如果用户名被人使用,弹出“"
用户名已被占用!
”。
主要代码如下所示:
代码1判断用户名有效性
protectedboolIfHaveName()
{
Class2c1=newClass2();
DataTabledt=c1.rt();
DataRow[]dr=dt.Select("
用户名="
+"
'
"
+Text1.Text+"
);
if(dr.Length>
0)
{
Response.Write("
<
script>
alert(\"
\"
/script>
returntrue;
}
else
returnfalse;
}
5.3登录页面(Default.aspx)
5.3.1功能描述
输入用户名和密码,点击登录按钮,若为网站注册用户则可成功登录校友录主页,并且能够显示用户名、用户身份、所在班级等信息,若密码错误或是用户名错误,则登录失败。
登录界面如图5.6示:
图5.6用户登录界面
5.3.2代码设计
登录时首先判断该用户是否为网站的注册用户,若已在网站中注册的用户且密码与用户名都填写正确,点击“登录”按钮可成功跳转到校友录首页,并且在页面中显示用户名、用户身份、所在班级等信息,否则会跳出“用户名或密码错误!
”的对话框。
代码如下所示:
代码2登录代码
cmd.Connection.Close();
stringt="
;
t3.Visible=false;
stringm="
if(Session["
usernum"
]!
=null)
table1.Visible=false;
table2.Visible=true;
stringc=@"
DataSource=.;
InitialCatalog=TONGXUE;
IntegratedSecurity=True"
m="
select*fromclasswhere班级号=@class"
stringb="
select*fromuserswhere用户名=@users"
SqlConnectionconn=newSqlConnection(c);
SqlCommandcmd=newSqlCommand(b,conn);
SqlCommandcmd1=newSqlCommand(m,conn);
cmd.Parameters.Add("
@users"
SqlDbType.VarChar,50).Value=Convert.ToString(Session["
]);
conn.Open();
SqlDataReaderdf=cmd.ExecuteReader();
if(df.Read())
Session["
已有班级"
]=df["
].ToString();
真实姓名"
].ToStri
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 NET 同学录 系统 设计 实现