1、社团管理系统详细设计说明书详细设计说明书V1.0(版本号)拟 制 人 审 核 人 年 月 日 目录1.引言31.1编写目的31.2项目背景31.3定义31.4参考资料32.总体设计42.1需求概述42.2软件结构53.程序描述63.1功能63.2性能83.3运行环境及设备要求93.4算法93.5程序逻辑213.6数据库设计223.7测试要点251.引言1.1编写目的本说明书在概要设计的基础上,对信息发布系统的各模块、程序分别进行了实现层面上的要求和说明。1.2项目背景l 项目全称:厦门理工学院社团管理系统l 项目发起者:09软件工程2班DWLGY小组l 项目开发者:09软件工程2班DWLGY小
2、组l 项目用户:厦门理工的广大师生1.3定义USE CASE用例会员社团管理系统中合法的注册用户游客未注册或者未登录的社团管理系统平台浏览者管理员系统的管理者1.4参考资料1 天极网新技术研究室.ASP.NET完全入门.人民邮电出版社,2001.62 Sanjeev Rohilla等著,陈君等译.ADO.NET专业项目实例开发.中国水利水电出版社,2003.53 启明工作室编著.ASP.NET网络应用系统开发与实例.人民邮电出版社,2005.74 王华杰,李律松 孙一波等编著.C#数据库开发技术.清华大学出版社,2003.25 攀建编著.ASP.NET+ADO.NET项目开发实例.清华大学出版
3、社,2004.16 (美)A.Russell Jones著,高春蓉等译.ASP.NET从入门到精通.电子工业出版,2002.17 Scott Worley著,王文龙 刘湘宁译.ASP.NET技术内幕.人民邮电出版社,2002.48 Russ Basiura等著,杨浩译.ASP.NET Web 服务高级编程.清华大学出版社, 2003.29 (美)Angshuman Chakraborti等著,唐云深,赵世华等译.NET Framework专业项目实例开发.中国水利水电出版社,2003.6 10 Scott Allen等著.C#数据库入门.郝启堂 张哲峰译.清华大学出版社,2003.211 (美
4、)微软公司著.NET框架1.1类库参考手册.清华大学出版社,2004.112 Steve Walther著.ASP.NET:Tips,Tutorials,and Code.电子工业出版社,2003.713 (美)Jeffrey Richte著.Microsoft.NET Frameworks.清华大学出版社,2003.414 Alex Homer等.ASP.NET Web Forms Programming.清华大学出版社,2003.12.总体设计2.1需求概述社团管理系统需要满足来自三方面的需求,这三个方面分别是会员、社团和管理员。会员的需求是查询院系各社团的活动情况、会员参加的各个社团情况
5、及会员信息的修改;社团需对会员参加社团、注销社团的基本情况进行操作;社团管理系统的管理员的功能最为复杂,包括对会员、社团的活动等各方面的信息进行管理和统计,及系统状态的查看、维护并生成会员社团统计表。会员可以直接查看参加社团及社团活动情况,会员可以根据本人学号和密码登录系统,还可以进行对本人参加社团情况的查询和维护部分个人信息以及各社团的活动安排等相关信息。一般情况下,会员只应该查询和维护本人的参加社团情况和个人信息,若查询和维护其他会员的信息,就要知道其他会员的学号和密码。这些是很难得到的,特别是密码,所以不但满足了会员的要求,还保护了会员的个人隐私。社团工作人员有修改会员个人信息的权限,所
6、以需对工作人员登陆本模块进行更多的考虑。在此系统中,社团工作人员可以为会员加入社团或是登陆记录,并打印生成相应的报表给用户查看和确认院系管理人员功能的信息量大,数据安全性和保密性要求最高。本功能实现对会员参加各社团相关信息的查询和统计、工作人员和管理人员信息查看及维护。社团管理员可以浏览、查询、修改、统计社团的基本信息;浏览、查询、统计和修改会员参加社团活动的基本信息,设计不同用户的操作权限和登陆方法对所有用户开放的会员信息查询和个人部分信息维护查看个人情况信息维护会员个人密码根据注册的情况对数据库进行操作并生成报表。社团管理系统的数据流程:首先由社团工作人员或系统管理员等有录入权限的用户将各
7、自权限范围内的信息进行录入处理,然后保存信息到数据库中。有权限的人可以对这些库信息进行修改和删除处理。所有用户均可以进行信息查询和统计,没有权限用户还可以基于注册界面进行注册,来参加相应的社团。2.2软件结构本程序采用B/S架构,并使用了四层逻辑结果,如图1所示:数据层(DB)数据访问层(DAL)业务逻辑层(BLL)用户层(UI)图1 系统结构示意图 以下为用户社团管理系统流程图,也是我们的核心工作流程图,如图2所示:图2 系统流程图3.程序描述3.1功能工作流程为:打开该系统网站,普通浏览者能浏览、阅读和社团信息及新闻,能进行注册,注册后为网站准会员,系统管理员登录进入新闻后台管理区,可以进
8、行如下管理:l 社团信息管理u 删除和修改社团信息u 对已有社团进行部门管理u 对社团章程管理u 对社团的活动信息进行管理u 添加社团(注:授权码最为重要,它将在社团注册时为唯一识别码)l 管理员信息管理u 添加管理员u 修改或删除管理员信息l 新闻管理u 公告管理(添加、删除和修改)u 新闻管理(添加、删除和修改)l 用户管理u 个人用户管理(添加、删除和修改)u 协会用户管理(添加、删除和修改)l 下载管理u 表格管理(修改和删除)u 资料管理(删除和修改)u 添加信息(添加下载资料)l 留言管理u 个人留言管理(回复和删除留言)l 图片管理u 添加图片u 删除图片u 修改图片l 实用信息
9、管理u 添加使用信息l 系部管理(添加、删除和修改系部)3.2性能该系统操作简单、界面友好: 完全控件式的页面布局,使得社团信息及新闻的录入工作更简便,为用户提供方便快捷的社团管理及相关信息的发布,更将作为一个向外部展示本学校的社团建设成就。即时可见:对社团信息的处理(包括录入、修改、删除)将立即在主页的对应栏目显示出来,达到“即时发布、即时见效”的功能;系统运行应该快速、稳定、高效和可靠;在结构上应具有很好的可扩展性,便于将来的功能扩展和维护。3.3运行环境及设备要求设备客户机硬件要求:具有 Pentium III 处理器以上且满足以下要求的计算机:最低 64 MB 内存,最小 2.1 GB
10、 硬盘。服务器硬件要求:具有 Pentium III 处理器以上且满足以下要求的计算机:最低 256MB 内存,最小 8 GB 硬盘。支持程序 客户端操作系统:Windows 98/NT/2000/XP或更高版本浏览器:IE 5.0以上或Netscape同等版本以上 服务器操作系统:Windows 2000 Server或者Windows 2003 ServerWeb服务器:MS IIS应用服务器:IIS、COM+等企业级应用服务器数据库:SQL SERVER 3.4算法重要算法及部分代码Web用户控件该系统中创建了两个Web用户控件Foot.ascx和Head.ascx,在首页、新闻动态、社
11、联简介、资料下载等页面的HTML代码里都进行了引用,调用方式为: Register指令注册用户控件,同时把属性TagName(标签名)和TagPrefix(标签前缀)添加到 Register指令中,Src属性表示该用户控件相对于父页面的相对地址。用户控件也是服务器端控件,还必须在用户控件代码中添加Runat=server属性,用法如下:其中Head.ascx用户控件作用是显示导航栏Flash按钮,Foot.ascx用户控件作用是显示底部相关网站信息等。用户控件是非常易于代码重用的,可以把许多相关功能和用户界面封装在一个用户控件中,然后在任何需要该功能的地方重用此控件。通用类代码在所有相关页面显
12、示文件和Web用户控件的代码隐藏文件.aspx.cs或.ascx.cs中,通过对数据访问类的引用(以创建类实例方式),调用数据访问类里的相应函数完成相关功能,如建立数据库连接、打开和关闭数据库、对数据库执行查询、插入、删除和更新操作、页面登陆检验等。此处列举Dbhelp类(数据访问类)中主要函数的源码:using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebCont
13、rols;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;using System.Text;using System.Text.RegularExpressions;/ / Dbhelp 的摘要说明/ public class Dbhelp protected static string con = ConfigurationManager.ConnectionStringsconnstr.ToString(); public SqlCo
14、nnection conn = new SqlConnection(con); /public SqlConnection conn = new SqlConnection(Data Source=.;Initial Catalog=Studentdatabase;uid=sa;pwd=123456;); #region 用户登录验证 / / 验证用户是否是合法用户 / / 接受SQL语句 / public int CheckLogin(string sql) try SqlCommand cmd = new SqlCommand(sql, conn); if (conn.State = Co
15、nnectionState.Closed) conn.Open(); int result = (int)cmd.ExecuteScalar(); return result; catch (Exception ex) HttpContext.Current.Response.Write(ex.Message); throw; #endregion #region 用户信息提示 / / 对话框信息 / / 接受要显示给用户的信息 public void MessageShowBox(string TxtMessage) HttpContext.Current.Response.Write(al
16、ert( + TxtMessage + ); #endregion #region 查询数据库信息 / / 数据填充 / / 接受SQL语句 / 返回DataSet类型数据ds public DataSet GetData(string sql) try DataSet ds = new DataSet(); SqlDataAdapter da = new SqlDataAdapter(sql, conn); if (conn.State = ConnectionState.Closed) conn.Open(); da.Fill(ds, DataTable); return ds; catc
17、h (Exception ex) HttpContext.Current.Response.Write(ex.Message); throw; #endregion #region 数据库信息更新 / / 实现数据库的更新 / / 接受Sql语句 / 返回受影响行数 public int Exucte(string sql) try SqlCommand cmd = new SqlCommand(sql, conn); if (conn.State = ConnectionState.Closed) conn.Open(); int result = cmd.ExecuteNonQuery()
18、; return result; catch (Exception ex) HttpContext.Current.Response.Write(ex.Message); throw; #endregion #region 读取数据库数据 public DataSet Excute1(string sql) DataSet ds = new DataSet(); SqlDataAdapter da = new SqlDataAdapter(sql,conn); if (conn.State = ConnectionState.Closed) conn.Open(); da.Fill(ds,Ne
19、ws); if (conn.State = ConnectionState.Open) conn.Close(); return ds; #endregion #region Session传值判断注册身份 public void TeamAdd() HttpContext.Current.Sessionidentity = 团体注册; HttpContext.Current.Response.Redirect(Register.aspx); public void Person() HttpContext.Current.Sessionidentity = 个人注册; HttpContext
20、.Current.Response.Redirect(Register.aspx); #endregion #region 获取数据库字段 public SqlDataReader GetRed(string sql) SqlCommand cmd = new SqlCommand(sql,conn); if (conn.State = ConnectionState.Closed) conn.Open(); SqlDataReader red = cmd.ExecuteReader(); return red; red.Close(); conn.Close(); #endregion 前台
21、主要页面代码1. 首页1) 填充首页各信息控件模块:ApplicationUserInfor = string.Empty;/将用户登陆信息置空 GVNews.DataSource = dh.GetData(select top 6 * from News order by NewID desc);/读取最新前六条新闻 GVNews.DataBind(); TxtName.Focus(); GvDonload.DataSource = dh.GetData(select top 5 DName,Id from Download order by Id desc);/读取最新下载资料 GvDon
22、load.DataBind(); GvLeague.DataSource = dh.GetData(select top 5 * from League_Table order by ID desc);/填充协会信息模块 GvLeague.DataBind(); DataSet ds = dh.GetData(select top 1 Contents from Affiche order by Id desc);/填充通告模块 if(ds.Tables0.Rows.Count0) LblAd.Text = ds.Tables0.Rows00.ToString(); GVActivity.Da
23、taSource = dh.GetData(select top 5 Name,Activity,ID from League_Table where IntActivity=1 order by ID desc); GVActivity.DataBind();/填充社团活动新闻信息模块 ds = dh.GetData(select top 1 Viscera from News order by NewID desc); /填充专题报道信息模块 if(ds.Tables0.Rows.Count0) LblReport.Text = ds.Tables0.Rows00.ToString();
24、DataList1.DataSource = dh.GetData(select * from ShowImage); DataList1.DataKeyField = Id;/根据主键:Id读取数据库中新闻图片的存储路径用以动态填充图片新闻模块 DataList1.DataBind(); DataList2.DataSource = dh.GetData(select top 6 * from UrlMessege order by Id desc);DataList2.DataBind();/填充实用信息模块在HTML代码中对后台代码的Data数据集进行调用: &nb
25、sp; asp:Image id=ImageShow AlternateText=风景如画 Height=120 Width=90 runat=server ImageUrl= _designer:wfdid=w32. 下载页面代码:1) 实现下载功能代码:从数据库中读取文件路径: string num = ds.Tables0.Rows00.ToString(); string FilePath = ds.Tables0.Rows01.ToString(); 判断数据库文件类型: if (FilePath.Trim() = Word文件) filetype = DownLoad_Doc; f
26、ilepostfix = .doc; else if (FilePath.Trim() = Excel表格) filetype = DownLoad_xls; filepostfix = .xls; string fileName = num + filepostfix;/客户端保存的文件名 string filePath = Server.MapPath(filetype + / + fileName);/路径 /以字符流的形式下载文件 FileStream fs = new FileStream(filePath, FileMode.Open); byte bytes = new byte
27、(int)fs.Length; fs.Read(bytes, 0, bytes.Length); fs.Close(); Response.ContentType = application/octet-stream; /通知浏览器下载文件而不是打开 Response.AddHeader(Content-Disposition, attachment; filename= + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8); Response.BinaryWrite(bytes); Response.Flush(); Res
28、ponse.End();3.留言本实现代码: using System;using System.Data;using System.Configuration;using System.Collections;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClie
29、nt;public partial class Message : System.Web.UI.Page Dbhelp dh = new Dbhelp(); public string sql = select top 5 * from Massage order by Id desc;/从数据库中读取前五条最新留言 protected void Page_Load(object sender, EventArgs e) DLBinit(sql);#region 绑定数据 protected void DLBinit(string sql) /用数据适配器对DataSet数据集进行填充留言本内
30、容 if (dh.conn.State = ConnectionState.Closed) dh.conn.Open(); SqlDataAdapter da = new SqlDataAdapter(sql, dh.conn); DataSet ds = new DataSet(); da.Fill(ds, table); PagedDataSource ps = new PagedDataSource(); ps.AllowPaging = true;/允许分页功能 ps.PageSize = 5;/设置每页显示五条信息 ps.DataSource = ds.Tablestable.Def
31、aultView; DataList1.DataSource = ps; DataList1.DataBind(); #endregion protected void BtnMassage_Click(object sender, EventArgs e) /点击留言按钮跳转到留言界面 Response.Redirect(ReplyMassage.aspx); 后台主要页面代码1. 图片管理页面代码:填充图片信息代码:protected void DLBinit(string sql) /进行填充已上传的图片进行填充模块 if (dh.conn.State = ConnectionState
32、.Closed) dh.conn.Open(); SqlDataAdapter da = new SqlDataAdapter(sql, dh.conn); DataSet ds = new DataSet(); da.Fill(ds, table); PagedDataSource ps = new PagedDataSource(); ps.DataSource = ds.Tablestable.DefaultView; GridView1.DataSource = ps; GridView1.DataBind(); 删除图片信息代码:protected void GridView1_Ro
33、wDeleting(object sender, GridViewDeleteEventArgs e) /删除图片信息 int id = int.Parse(GridView1.DataKeyse.RowIndex.Value.ToString(); string sql = select * from ShowImage where Id= + id + ; DataSet ds = dh.GetData(sql); string filename = ds.Tables0.Rows01.ToString(); try string value = filename.Split(/); filename = value2.ToString(); catch (Exception) dh.MessageShowBox(删除失败!); return; 物理删除图片代码:string filepath = Server.MapPath()+/ShowImage/ + filename; if (File.Exists(filepath)/判断文件是否存在 File.Delete(filepath);/进行物理删除文件 sql = delete ShowImage where Id= + id + ;/删除数据库中文件信息 if (dh.Exucte(sql) 0)