1、第一章 绪论1.1 课题的提出原因及意义越来越多的网络用户希望能够在网络平台上更多地展现自己的个性,更方便地与人互动交流,在传统的 WEB1.0 时代,无论是论坛、社区还是个人网站,都试图在这些方面进行努力,随着 WEB2.0 时代的到来,一个新的概念出现了-博客。随着计算机网络的飞速发展,博客已经成为写网络日志必不可少的一种工具,也是一种简单有效的提供网络用户之间进行在线交流的网络平台,通过其可以结交更多的朋友,表达更多的想法,它随时可以发布日志,方便快捷。个人博客的发展,也已经成为广告商业务拓展的重要领域。本实验研究了一种基于数据关联规则的个人博客网站。其开发主要包括后台数据库的建立、后台
2、管理以及前台页面的 Web 设计。系统使用 Microsoft 公司以 C#为核心语言的 ASP.NET 开发工具,再结合 SQL Server 2005 建立数据连接关系。利用其提供的各种组件,在短时间内建立数据库,对数据库进行分析与建立 ASP.NET 页面,不断改进,直到功能基本实现的可行系统。本文的研究在一定程度上借鉴了互联网上博客的发展经验成果,系统的最终目的是通过为博客提供优质的互动交流平台,提高网站的知名度和访问量,从而获得为企业提供更多的产品介绍及发展的机会,提升自己的网络价值。 本实验报告主要介绍了本课题的开发背景、完成的功能和开发过程,并着重说明了开发设计的思想、技术难点和
3、解决方案。1.2 博客网站简介在 Internet 飞速发展的今天,互联网成为人们快速获取、发布和传递信息的重要渠道,它在人们政治、经济、生活等各个方面发挥着重要的作用。Internet上发布信息主要是通过网站来实现的,获取信息也是要在 Internet 中按照一定的检索方式将所需要的信息从网站上下载下来。因此网站建设在 Internet 应用上的成绩地位显而易见,它已成为政府、企事业单位信息化建设中的重要组成部分,从而倍受人们的重视。根据个人喜好开发了博客网站。个人博客是当今网络的热点,个人博客技术的出现使得每个人可以零成本、零维护地创建自己的网络媒体,Blog 站点所形成的网状结构促成了不
4、同于以往社区的 Blog 文化,Blog 技术缔造了“博客”文化。1.3 博客需求问题分析对课题所研究的问题不是很明确,如其应用范围,用户群体等。通过老师的讲解及指导和查相关资料得以解决。对于信息的安全性合法性的控制,原设为普通用户发布文章成功后,管理员后期发现非法的信息就可以撤除。普通用户发布文章后也可以对自己的文章进行编辑、删除等操作,而其他人只可以查看该文章,不具有对文章的修改,删除权利。1.3 博客代码实现问题通过业务层的对象类调用数据库的存储过程,此过程中,因编程规范及其他各种语法问题出现了很多错误,通过查阅资料学习得以解决。第二章 系统分析本课题为实现更加实用的网站,对网站做了详细
5、的系统分析。包括系统的需求分析、对开发用到的关键技术的介绍以及系统的可行性分析 普通用户 浏览文章 发表留言、评论2.1 采用的关键技术介绍2.1.1 ASP.NET 简介ASP.NET 是一个 Web 开发平台,提供了构建企业级应用所需的服务、编程模型和软件基础结构。虽然 ASP.NET 的语法基本上与其前辈 ASP(Active Server Page)兼容,但是 ASP.NET 是一个全新的编程框架,旨在用于快速开发Web 应用程序。作为 Microsoft.NET 平台的一部分,ASP.NET 提供了一种基于组件的、可扩展的且易于使用的方法,用于购建、部署和运行供所有在浏览器或移动设备
6、中使用的 Web 应用。同 ASP 和其他 Web 开发环境一样,ASP.NET 也是建立在 HTTP 协议之上的,它利用 HTTP 命令和策略进行双向的、浏览器到服务器的通信和协作。真正使ASP.NET 有别于其他 Web 开发技术的是它提供的抽象编程模型,即 Web 窗体模型。此外,整个 ASP.NET 平台是 Microsoft.NET Framework 的一部分。ASP.NET应用是一些已编译的代码部件,由一些可重用且可扩展的组件组成,可以用第一类语言(包括、C#、Microsoft Visual Basic.NET、Microsoft Jscript.NET和 J#)创建,并且可以
7、访问.NET Framework 中整个类的层次结构。2.1.2 MySQL 数据库简介MySQL 是一种开放源代码的关系型数据库管理系统(RDBMS),MySQL 数据库系统使用最常用的数据库管理语言-结构化查询语言(SQL)进行数据库管理。由于 MySQL 是开放源代码的,因此任何人都可以在 General Public License 的许可下下载并根据个性化的需要对其进行修改。MySQL 因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL 是管理内容最好的选择。MySQL 这个名字,起源不是很明确。一个比较有影响的说法是,基本指南和大量的库和工具
8、带有前缀“my”已经有 10 年以上,而且不管怎样,MySQL AB创始人之一的 Monty Widenius 的女儿也叫 My。这两个到底是哪一个给出了MySQL 这个名字至今依然是个迷,包括开发者在内也不知道。MySQL 的海豚标志的名字叫“sakila”,它是由 MySQL AB 的创始人从用户在“海豚命名”的竞赛中建议的大量的名字表中选出的。获胜的名字是由来自非洲斯威士兰的开源软件开发者 Ambrose Twebaze 提供。根据 Ambrose 所说,Sakila 来自一种叫 SiSwati 的斯威士兰方言,也是在 Ambrose 的家乡乌干达附近的坦桑尼亚的 Arusha 的一个小
9、镇的名字。MySQL,虽然功能未必很强大,但因为它的开源、广泛传播,导致很多人都了解到这个数据库。它的历史也富有传奇性。2.2 可行性分析采用 asp 技术进行开发,Asp 技术相对于传统的 html 技术有着绝对的优势,支持数据库的读取大大减化了程序员的代码量,对程序员开发 WEB 应用程序提供了完备的技术支持。也使得开发出来的 WEB 应用程序具有更好的扩展性,能够运行于不同的操作平台之下。后台数据库采用 MySQL 数据库,该数据库是一种开放源代码的关系型数据库管理系统, 因此任何人都可以在 General Public License 的许可下下载并根据个性化的需要对其进行修改。MyS
10、QL 因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL 是管理内容最好的选择。所以本次设计选择 MySQL 数据库。2.3 操作可行性网站运行于 Windows 环境,其用户操作页面友好,设置功能栏便于用户操作。网站的基本操作如下: 普通用户 浏览博客文章 发表博客留言 发表对文章的评论 查询博客文章第三章 系统设计概要3.1 系统总体设计31.1 运行环境 操作系统:Windows NT/2000/XP/2003 安装 Access2003 安装 Visual Studio.NET 20053.1.2 系统功能模块我的博客系统浏览日志文章添加评论日志
11、管理日志列表目录管理评论管理文章管理3.2 数据库结构的设计博客系统的数据库功能主要体现在对各种信息的提供、保存、更新和查询操作上,包括文章信息、文章目录信息和评论信息,各个部分的数据内容又有内在联系。针对该系统的数据特点,可以总结如下的需求:1) 文章信息记录作者发表的日志信息。2) 文章目录信息记录了文章所在的目录分类。3) 评论信息对应某个文章浏览者发表的评论。经过上述需求总结,得出如下数据项和数据结构:1) 文章信息,包括数据项有:文章内容、标题等。2) 文章目录信息,包括数据项有:目录名称、目录描述等。评论信息,包括数据项有:评论编号、文章编号、评论内容等。3.3 数据库逻辑结构的设
12、计在博客系统中,首先要创建系统数据库,然后在数据库中创建需要的表和字段。数据库命名为 Blog,在这个数据库中管理系统中要建立 5 个表,分别是,用户信息表(dbo.Users),文章信息表(dbo.article),分类信息表(dbo.type),评论信息表(ment).博客表(dbo.blog)。(1) 用户信息表(Users)记录了用户的账号和密码,如下图所示:(2) 文章信息表(dbo.article)记录了文章的标题,内容,发表时间,发表人等信息,如下图所示(3) 分类信息表(dbo.type),记录了文章的分类信息,如下图所示:(4) 评论信息表(ment),记录了其他用户对于该文
13、章的评论内容,评论时间,评论人等信息,如下图所示:(5) 博客表(dbo.blog),如下图 所示:第四章 系统的展示4.1 系统开发环境 系统:Microsoft Windows 8.1 编程环境:Microsoft Visual Studio 2013 开发语言:C# 数据库:MySQL 20084.2 系统的页面设计4.2.1 登陆页面:4.2.2 首页的设计:4.2.3 文章内容显示页面:4.2.4 留言显示部分:4.2.5 文章内容编辑页面:4.2.6 博客注册页面4.3 系统部署4.3.1 数据库设置(1)附加数据库文件 本课题的网站根目录下(DBblog)有数据库文件,运行前将.
14、mdf 文件附加上即可(2) 创建登陆用户用户在页面注册进行注册即可。4.3.2 服务器端运行设置步骤(1)将文件目录复制到硬盘任意位置。(2)用 MySQL 数据库附加数据库文件。(3)用 Visual Studio 20013 打开博客网站,按 Ctrl+F5 查看运行。第五章 博客设计的部分源码展示5.1 主页代码:using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data;using System.Text.RegularExpressions;u
15、sing System.Data.SqlClient;namespace BLLpublic class indexDAL.DB db = new DAL.DB();public Model.article artc;public DataSet dsuser()string sql = “select * from article where“+artc.Auserid;return db.FillDataset(sql);public DataSet dsall()string sql = “select * from article “;return db.FillDataset(sql
16、);public DataSet dstype()string sql = “select * from article where Atid=“ + artc.Atid;return db.FillDataset(sql);public string Uid()string sql=“select * from article where Aid=“+artc.Aid;SqlDataReader read = db.ExceRead(sql);return db.ExceString(read, “Auserid“);public bool delete()string sql = “del
17、ete from article where Aid=“+artc.Aid;return db.ExceSql(sql);public SqlDataReader DataReader()string sql = “select * from article where Aid=“ + artc.Aid+“;return db.ExceRead(sql);#region 截取字符串/ 名称:FixLengthString / 功能:截取指定长度的字符串 / 源文本/ 截取的长度/ 按长度截取后的字符串/ public static string FixLengthString(string o
18、Text, int length)string returnString = oText.Length length ? oText.Substring(0, length) : oText;return returnString;#endregion#region 去掉html 标记public static string NoHTML(string Htmlstring)/Regex.Replace从输入字符串中的第一个字符开始,用指定的替换字符串替换由指定的正则表达式定义的模式的所有匹配项。可指定选项来修改匹配的行为。Regex htmlReg = new Regex(“+“, Rege
19、xOptions.Compiled | RegexOptions.IgnoreCase);Regex htmlSpaceReg = new Regex(“, RegexOptions.Compiled | RegexOptions.IgnoreCase);Regex spaceReg = new Regex(“s2,| ;“, RegexOptions.Compiled | RegexOptions.IgnoreCase);Regex styleReg = new Regex(“, RegexOptions.Compiled | RegexOptions.IgnoreCase);/删除脚本Re
20、gex scriptReg = new Regex(“, RegexOptions.Compiled | RegexOptions.IgnoreCase);Htmlstring = styleReg.Replace(Htmlstring, string.Empty);Htmlstring = scriptReg.Replace(Htmlstring, string.Empty);Htmlstring = htmlReg.Replace(Htmlstring, string.Empty);Htmlstring = htmlSpaceReg.Replace(Htmlstring, “ “);Htm
21、lstring = spaceReg.Replace(Htmlstring, “ “);return Htmlstring.Trim();#endregion5.2 博客登陆以及注册代码:namespace BLLpublic class Registerpublic Model.Users Users;public Model.Commonality Commonality;DAL.DB db = new DAL.DB();#region 检查用户名是否存在/ / 检查用户名是否存在/ / public int CheckName()string sql = “select count(*)
22、 from Users where Uname=“ + Commonality.CheckName + “;DataTable dt = db.reDt(sql);if (dt.Rows00.ToString() != “0“)return -1;elsereturn 2;#endregion#region MD5加密/ / MD5加密/ / / public string GetMD5(string strPwd)string pwd = “;/实例化一个md5对象MD5 md5 = MD5.Create();/ 加密后是一个字节类型的数组,这里要注意编码 UTF8/Unicode等的选择b
23、yte s = md5.ComputeHash(Encoding.UTF8.GetBytes(strPwd);/翻转生成的MD5码 s.Reverse();/通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得/只取MD5码的一部分,这样恶意访问者无法知道取的是哪几位for (int i = 3; i s.Length - 1; i+)/将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符/进一步对生成的MD5码做一些改造pwd = pwd + (si 198 ? si + 28 : si).ToString(“X“);r
24、eturn pwd;#endregionpublic bool InsertUser()string sql = “INSERT INTO blog.dbo.Users(Uname,Upwd,Uimg)VALUES(“+Users.Uname+“,“+Users.Upwd+“,“+Users.Uimg+“)“;return db.ExceSql(sql);public SqlDataReader DataReader()string sql = “select * from Users where Uname=“ + Users.Uname + “and Upwd=“ + Users.Upwd
25、 + “;return db.ExceRead(sql);/读取用户IDpublic String Uid()string sql = “select * from Users where Uname=“ + Users.Uname + “;SqlDataReader read = db.ExceRead(sql);return db.ExceString(read, “Uid“);/读取用户图片public String Uimg()string sql = “select * from Users where Uid=“ + Users.Uid + “;SqlDataReader read
26、 = db.ExceRead(sql);return db.ExceString(read, “Uimg“);5.3 文章内容显示代码:public class ArticleDAL.DB db = new DAL.DB();public Model.article atcl = new Model.article();public Mment comment = new Mment();public Model.Users Users = new Model.Users();public bool addArticlenoimg()string sql = “INSERT INTO blog
27、.dbo.article(Aname,Adetail,Atime,Auserid,Atid)VALUES(“ + atcl.Aname + “,“ + atcl.Adetail + “,“ + atcl.Atime + “,“ + atcl.Auserid + “,“ + atcl.Atid + “)“;return db.ExceSql(sql);public bool addArticle()string sql = “INSERT INTO blog.dbo.article(Aname,Adetail,Aimg,Atime,Auserid,Atid)VALUES(“ + atcl.Ana
28、me + “,“ + atcl.Adetail + “,“ + atcl.Aimg + “,“ + atcl.Atime + “,“ + atcl.Auserid + “,“ + atcl.Atid + “)“;return db.ExceSql(sql);public bool editArticle()string sql = “UPDATE blog.dbo.articleSET Aname = “ + atcl.Aname + “,Adetail = “ + atcl.Adetail + “,Aimg = “ + atcl.Aimg + “,Atime = “ + atcl.Atime
29、 + “, Atid = “ + atcl.Atid + “WHERE Aid =“ + atcl.Aid;return db.ExceSql(sql);public bool editArticlenoimg()string sql = “UPDATE blog.dbo.articleSET Aname = “ + atcl.Aname + “,Adetail = “ + atcl.Adetail + “,Atime = “ + atcl.Atime + “, Atid = “ + atcl.Atid + “WHERE Aid = “ + atcl.Aid;return db.ExceSql
30、(sql);public DataSet ArticlDetail()string sql = “select * from article where Aid=“ + atcl.Aid;return db.FillDataset(sql);public DataSet ArticlComment()string sql = “select * from comment,Users where CAid=“ + atcl.Aid + “ and comment.Cuserid=Users.Uid “;return db.FillDataset(sql);public string Cid()s
31、tring sql = “select * from comment,Users where CAid=“ + atcl.Aid + “ and comment.Cuserid=Users.Uid“;SqlDataReader read = db.ExceRead(sql);return db.ExceString(read, “Cid“);public bool AddComment()string sql = “INSERT INTO ment(Cuserid,Cdetail,Ctime,CAid)VALUES(“ + Users.Uid + “,“ + comment.Cdetail +
32、 “,“ + comment.Ctime + “,“ + comment.CAid + “)“;return db.ExceSql(sql);/public DataSet 第六章 课程设计总结经过 3 个周的努力,系统终于按预期的结果顺利完成了。从系统最初的需求分析、设计,到最后实现的过程中,经过多次反复的修改,功能逐渐完善,已经基本达到了实用,方便等预期目标,但距离完美还有好多不足之处。6.1 不足之处由于自己的分析设计和经验不足,该系统设计和实现过程中,还有许多没有完善的地方,比如页面结构,色彩搭配不和谐,还有部分代码不够完善。开始编写时就遇到了登录界面与数据库连接的困难,借助平时实训的
33、仔细分析和探讨完成了开始的登录界面. 在之后的过程中遇到了连接数据库失败等问题,在参考了相关的书籍和查阅了网上相关资料而解决的6.2课程设计体会通过这本课程设计,不仅学到了很多专业知识,而且提高了动手能力和解决实际问题的能力,真的受益匪浅。 课题完成到现在,从该开始连业务流程都不怎么熟悉,到现在完成基本需求功能,遇到了不少问题。本次课程设计是对大学所学知识的总结。在开发过程中,常常由于自己的一点失误,导致整个程序的无法运行,这时,只有细心的跟踪调试、阅读相关书籍、向老师咨询,仔细检查才能通过。整个过程中,我逐渐学会了当遇到问题时应该如何面对,如何寻找最有效的解决方案。学习了系统化的开发思想。相信对我以后的学习工作有很大的帮助。