《《Web开发》课程设计报告--聊天室22925.pdf》由会员分享,可在线阅读,更多相关《《Web开发》课程设计报告--聊天室22925.pdf(33页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 Web 开发 课程设计报告(2011 2012 学年 第 2 学期)题 目:聊 天 室 专 业:计算机网络技术 班 级:1 班 姓名学号:xxx(1007052139)指导教师:楚 志 凯 成 绩:商丘职业技术学院计算机系 2012 年 6 月 5 日 目 录 目 录.II 1 概 述.1 1.1 设计目标.1 1.2 项目规划.1 1.3 开发工具的选择.2 2 需求分析.3 2.1 需求分析.3 2.2 数据库表设计.4 3 系统总体设计.6 3.1 系统结构.6 4 系统功能模块实现.7 4.1 登录和注册界面模块.7 4.2 选择聊天室界面模块.10 4.3 聊天室主界面模块.12
2、4.4 用管理员高级功能管理模块.20 5 调试分析.28 6 心得体会.29 致 谢.30 参 考 文 献.31 1 1 概 述 1.1 设计目标 从功能角色上来讲,在线聊天室可以有两种类型的用户,普通用户和管理员。其中,普通用户在登录后,可以选择性的进入不同的聊天室,并通过聊天界面,向一人或多人发送聊天消息,进行聊天交流。如果是第一次进入到该聊天室,还可以通过本模块提供的注册功能,提交注册信息,成为本聊天室的用户。管理员在登陆后,除了可以聊天外,还可以拥有各种管理的权限,比如查看所有在线用户信息,还可以把一些不遵守聊天规则的用户赶出聊天室,甚至从数据库里把一些恶意聊天用户除名。1.2 项目
3、规划 本聊天室需要提供如下的界面和功能。1、需要提供支持用户登陆以及身份验证的 WEB 界面和实现后台对应功能的模块。在这个模块中,能根据登入者拥有的权限,分别开放不同的权限。2、需要一个支持用户注册的界面和对应的后台模块。3、需要为普通用户和管理员提供一个浏览所有聊天室的界面和对应后台功能模块。在这个界面中,用户可以选择性的进入不同的聊天室。4、需要为普通用户和管理员提供一个支持多人聊天的界面和对应的后台模块。在这个界面中用户和管理员可以选择聊天对象,也可以想聊天对象发送信息。5、需要为管理员提供一个查询所有用户的界面和对应的功能模块,这个界面其实就是管理员实现其管理功能的界面,在这个界面里
4、,管理员可以实现“赶人”的功能,也可以实现“删除聊天用户”的动作。1.3 开发工具的选择 JSP(JavaServer Pages)是由 Sun Microsystems 公司倡导、许多公司参与一起建立的一种动态网页技术标准。JSP 技术有点类似 ASP 技术,它是在传统的网页 HTML 文件(*.htm,*.html)中插入 Java 程序段(Scriptlet)和 JSP 标记(tag),从而形成 JSP 文件(*.jsp)。用 JSP 开发的 Web 应用是跨平台的,即能在 Linux 下运行,也能在其他操作系统上运行。JSP 技术使用 Java 编程语言编写类 XML 的 tags 和
5、 scriptlets,来封装产生动态网页的处理逻辑。网页还能通过 tags 和 scriptlets 访问存在于服务端的资源的应用逻辑。JSP 将网页逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于 Web 的应用程序的开发变得迅速和容易。Web 服务器在遇到访问 JSP 网页的请求时,首先执行其中的程序段,然后将执行结果连同 JSP 文件中的 HTML 代码一起返回给客户。JSP 与 Java Servlet 一样,是在服务器端执行的,通常返回该客户端的就是一个 HTML 文本,因此客户端只要有浏览器就能浏览。JSP 的 1.0 规范的最后版本是 1999 年 9 月推出的,1
6、2 月又推出了 1.1 规范。目前较新的是 JSP1.2 规范,JSP2.0 规范的征求意见稿也已出台。JSP 页面由 HTML 代码和嵌入其中的 Java 代码所组成。服务器在页面被客户端请求以后对这些 Java 代码进行处理,然后将生成的 HTML 页面返回给客户端的浏览器。Java Servlet 是 JSP 的技术基础,而且大型的 Web 应用程序的开发需要 Java Servlet 和 JSP 配合才能完成。JSP 的优势(1)一次编写,到处运行。在这一点上 Java 比 PHP 更出色,除了系统之外,代码不用做任何更改。(2)系统的多平台支持。基本上可以在所有平台上的任意环境中开发
7、,在任意环境中进行系统部署,在任意环境中扩展。相比 ASP/PHP 的局限性是显而易见的。(3)强大的可伸缩性。从只有一个小的 Jar 文件就可以运行 Servlet/JSP,到由多台服务器进行集群和负载均衡,到多台 Application 进行事务处理,消息处理,一台服务器到无数台服务器,Java 显示了一个巨大的生命力。(4)多样化和功能强大的开发工具支持。这一点与 ASP 很像,Java 已经有了许多非常优秀的开发工具,而且许多可以免费得到,并且其中许多已经可以顺利的运行于多种平台之下。3 2 需求分析 2.1 需求分析 21 世纪是网络的时代,Internet 的普及已经影响了传统的交
8、流方式。网络聊天室系统是计算机网络发展的产物,是最为常见、最受广大互联网使用者所认可的基于 Web 的网络应用系统。随着互联网的发展,人们通过网络可以更方便快捷地进行信息交流和学习,聊天系统可以为大家提供一个更好的交流平台,在这个平台上,人们可以通过文字与符号进行实时的交谈、聊天,它是一个向整个因特网开放的地方,是提供给网民一个交友与娱乐的场所,在聊天室里网民可选择自已的聊天对象,与其进行对话交流,是网民之间相互沟通、交流情感的最佳方式之一。从传播方式上讲,聊天室传播是非线性传播。非线形传播指聊天室传播的信息是为无数的共享空间的网络用户所发出的,任何拥有网络传播权利的人都可以得到,网络打破了传
9、统媒体单向传送信息的格局,信息传播者与接收者之间的互动变得切实可行。从传播的信息内涵上讲,聊天室的消息结构是无中心的。聊天室所给受 众带来的信息与感受作为一种现代生活资源,在实现了从传统大众传播的单向传播向多向传播的转变后,极大地拓展了现代生活空间,使传播者与受众之间的直接连通成为可能。这一转变使整个传播结构与传播效果发生了巨大变化,是传统媒体无法比拟的。根据 CNNIC 发布的第十五次中国互联网络发展状况统计报告,有 3.5%的商业网站提供网络聊天。热衷于网上聊天的人群大部分集中于 1624 年龄段上,经济上没有独立,又缺乏网上支付手段的特点也是聊天室不为商业网站看好的重要理由之一。目前经营
10、商获得收益的渠道有两条:在线广告和电子商务。青少年在经济上没有自立,经营商通常很难通过电子商务获得收入;而在在线广告方面,各商业网站目前的广告客户主要目标人群锁定中、高收入的白领阶层,面向青少年消费市场的网上广告几乎没有,无法通过网上广告获得收益。因此,对于青少年聚集的网上聊天室,网络公司自然没有太高的热情。实际上,青少年的消费市场一向是规模可观、利润丰厚的一块大蛋糕。无论流行音乐、新潮服饰、娱乐场所,青少年消费都是其中的主力。论市场规模,全国青少年消费市场的总规模不低于一千亿。我们看到,并非聊天的人群本身缺乏商业价值,而是目前没有好的办法将这种价值加以发掘。在线广告理应成为聊天室获得商业收益
11、的主要手段。随着研发技术的进步,qq.msn 等聊天软件的面世,取代了聊天室。同时,聊天室内用户过激,不法等言辞,也是聊天室逐渐没落的原因。但是,聊天软件的局限性,不比聊天室开放性强,面向广。只有真正了解聊天室的主要使用人群,才能更好地设置聊天室的主题、话题、页面风格等。要重视聊天室产品的氛围经济效益,可以成为各种汽车俱乐部、攀岩俱乐部、自行车俱乐部等的合作伙伴,吸引更多会员,成为网上会所。聊天室还应注意自身形象的塑造,只有个性化、特色化才能使聊天室产品脱颖而出。要注意适当的广告宣传。在以上的种种因素下,本课题的研究方向就是运用 JSP 技术营造一个简单,友好的网络聊天室,为互联网使用者提供学
12、习,讨论和交流的平台。2.2 数据库表设计 在 ChatRoom 数据库中建一个名为 userinfo 的表,如表 3.2 所示。表 3.2userinfo 数据表 在 ChatRoom 数据库中新建一个名为 msginfo 的表,用来保存聊天信息。在显示聊天记录时,可以通过查询语句对不同的用户显示不同的信息。如表 3.3 所示。表 3.3msginfo 表 列名 数据类型 长度 可否为空 说明 ID int 11 NOT NULL 索引号,主键,自增 nickName varchar 50 NOT NULL 用户昵称、用户昵称 userPassword Varchar 50 NOT NULL
13、 用户密码 role tinyint 1 NOT NULL 用户权限 0 代表普通会员,1 代表管理员 lastLoginTime date NULL 用户最后登陆时间 列名 数据类型 长度 可否为空 说明 ID int 11 NOT NULL 索引号,主键,自增 chatRoom varchar 50 NOT NULL 聊天信息对应的房间 msgFrom varchar 50 NOT NULL 聊天信息发言人 msgTo varchar 50 NOT NULL 聊天信息发表对象 chatTime datetime NOT NULL 聊天信息发表时间 chatAction varchar 50
14、 NULL 聊天信息的动作和表情 msgContent varchar 200 NOT NULL 聊天信息的内容 secret tinyint 1 NOT NULL 0 代表非悄悄话,1 代表悄悄话 5 在 ChatRoom 数据库表中新建一个名为 onlineUser 的表,用来保存在线用户信息。如表 3.4 所示。表 3.4 onlineUser 表 列名 数据类型 长度 可否为空 说明 ID int 20 NOT NULL 索引号、主键、自增 chatRoom varchar 50 NOT NULL L 用户所在的房间 nickName varchar 50 NOT NULL 用户的昵称
15、 lastChatRoom dateTime NULL 用户最后发言时间 denyRoom varchar 255 NULL 用户被封的时间 3 系统总体设计 3.1 系统结构 本系统将分为四大模块,即数据库通用模块、用户登录与注册模块、聊天主模块、管理员模块,具体描述如表 3.1 所示。表 3.1 系统结构表 模块名 文件名 功能描述 数据库通用管理描述 BaseConn.jsp 连接和数据的查询更新操作 用户登录与注册模块 login.jsp 用户登入界面 chklogin.jsp 用户登录后台处理界面 Checklogin.java 封装登陆后的 javabean 聊天室模块 chkSe
16、ssion.jsp 检查 session信息判断用户是否登陆 chatRoomList.jsp 聊天房间选择界面 chatRoomList.java 封装选择聊天房间的 javabean chatRoom.jsp 聊天框架界面 redirectChatRoom.jsp 转向聊天室中转界面 input.jsp 聊天室输入界面 sendMsg.jsp 聊天信息发送界面 userList.jsp 在线用户列表界面 dataValue.jsp 聊天信息显示界面 logout.jsp 离开聊天室 changeRoom.jsp 切换聊天房间 Message.java 聊天信息封装 javabean Cha
17、tRoom.java 封装聊天功能的 Javabean 管理员模块 advanced.jsp 管理员管理高级界面 kick.jsp 踢人功能 delete.jsp 删除用户 7 4 系统功能模块实现 4.1 登录和注册界面模块 登录界面模块是通过访问数据库中的 userinfo 表中的Name和Password两个字段来判断用户名和密码是否匹配,如果匹配就登入成功,否则登入失败,如果用户是第一次登录该聊天室,则自动注册。如图 4.1 所示。图 4.1 登录界面 核心代码:package net.chat;import java.sql.*;import java.util.*;import j
18、ava.text.SimpleDateFormat;public class CheckLogin public String checklogin(String userName,String userPassword)throws SQLException,ClassNotFoundException BaseConn conn=null;try conn=new BaseConn();String sql=select*from userInfo where nickName=?;PreparedStatement ps=conn.preparedStatement(sql);ps.se
19、tString(1,userName);ResultSet rs=conn.executeQuery();if(rs.next()if(rs.getString(userPassword).equals(userPassword)SimpleDateFormat cal=new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);String time=cal.format(new java.util.Date();sql=update userInfo set lastLoginTime=?where nickName=?;ps=conn.preparedStatem
20、ent(sql);ps.setString(1,time);ps.setString(2,userName);conn.executeUpdate();return SUCCESS_LOGIN;else return WRONG_PASSWORD;else return NONE_USER;catch(SQLException ex)ex.printStackTrace();throw ex;catch(ClassNotFoundException ex)ex.printStackTrace();throw ex;finally 9 conn.closeDB();public boolean
21、saveToDataBase(String userName,String userPassword)throws SQLException,ClassNotFoundException BaseConn conn=null;try conn=new BaseConn();SimpleDateFormat cal=new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);String time=cal.format(new java.util.Date();String sql=insert into userInfo(nickName,userPassword,la
22、stLoginTime,role)values(?,?,?,?);PreparedStatement ps=conn.preparedStatement(sql);ps.setString(1,userName);ps.setString(2,userPassword);ps.setString(3,time);ps.setInt(4,0);conn.executeUpdate();return true;catch(SQLException ex)ex.printStackTrace();throw ex;catch(ClassNotFoundException ex)ex.printSta
23、ckTrace();throw ex;finally conn.closeDB();4.2 选择聊天室界面模块 如果登录成功则进入选择聊天室界面的模块,如图 4.2 所示:图 4.2 选择聊天室 核心代码:聊天室列表 欢迎您:希望您在这里聊得愉快!11 情感倾诉 人 交友天地 人 龙门客栈 人 var x=50,y=60 var xin=true,yin=true var step=1 var delay=10 var obj=document.getElementById(ad)function floatAD()var L=T=0 var R=document.body.clientWid
24、th-obj.offsetWidth var B=document.body.clientHeight-obj.offsetHeight obj.style.left=x+document.body.scrollLeft obj.style.top=y+document.body.scrollTop x=x+step*(xin?1:-1)if(x R)xin=false;x=R y=y+step*(yin?1:-1)if(y B)yin=false;y=B var itl=setInterval(floatAD(),delay)obj.onmouseover=function()clearIn
25、terval(itl)obj.onmouseout=function()itl=setInterval(floatAD(),delay)4.3 聊天室主界面模块 此界面由三个用户输入模块、聊天信息显示模块和在线用户列表等三个模块组成,如图 4.3 所示。13 图 4.3 聊天室主窗体 核心代码:package net.chat;import java.text.SimpleDateFormat;import java.sql.*;public class Message private String chatRoom;private String msgFrom;private String
26、msgTo;private String chatAction;private String msgContent;private int secret;public void setChatRoom(String chatRoom)this.chatRoom=chatRoom;public void setMsgFrom(String msgFrom)this.msgFrom=msgFrom;public void setMsgTo(String msgTo)this.msgTo=msgTo;public void setChatAction(String chatAction)this.c
27、hatAction=chatAction;public void setMsgContent(String msgContent)this.msgContent=msgContent;public void setSecret(int secret)this.secret=secret;15 public boolean saveToDataBase()throws SQLException,ClassNotFoundException BaseConn conn=null;try conn=new BaseConn();SimpleDateFormat cal=new SimpleDateF
28、ormat(yyyy-MM-dd HH:mm:ss);String time=cal.format(new java.util.Date();String sql=insert into msgInfo(chatRoom,msgFrom,msgTo,chatTime,chatAction,msgContent,secret)values(?,?,?,?,?,?,?);PreparedStatement ps=conn.preparedStatement(sql);ps.setString(1,chatRoom);ps.setString(2,msgFrom);ps.setString(3,ms
29、gTo);ps.setString(4,time);ps.setString(5,chatAction);ps.setString(6,msgContent);ps.setInt(7,secret);conn.executeUpdate();sql=update onlineUser set lastChatTime=?where nickName=?and chatRoom=?;ps=conn.preparedStatement(sql);ps.setString(1,time);ps.setString(2,msgFrom);ps.setString(3,chatRoom);conn.ex
30、ecuteUpdate();return true;catch(SQLException ex)ex.printStackTrace();throw ex;catch(ClassNotFoundException ex)ex.printStackTrace();throw ex;/javascript函数,每融2000毫秒(2秒)刷新一次页面 function GetData()var timeoutid=setTimeout(window.location.reload(),2000)%String msgString=;try String sql=select*from msgInfo
31、where ID in(select top 30 ID from msgInfo where chatRoom=?Order by chatTime DESC)order by chatTime;String userName=session.getAttribute(_USER).toString();PreparedStatement ps=conn.preparedStatement(sql);ps.setString(1,session.getAttribute(_CHAT_ROOM).toString();ResultSet rs=conn.executeQuery();/下面wh
32、ile循环里的程序就是实现控制聊天信息显示格式的功能 while(rs.next()String msgFrom=rs.getString(msgFrom);/获取聊天信息发送者 String msgTo=rs.getString(msgTo);/获取聊天信息接收者 String action=rs.getString(chatAction);/获取聊天表情 String msgContent=rs.getString(msgContent);/获取聊天信息内容 int secret=rs.getInt(secret);/获取是否悄悄话 /判断是否系统公告 if(msgFrom.equals(
33、系统公告)msgString=msgString+系统公告:+msgContent+;/判断是否悄悄话 else if(secret=0)/判断是否使用聊天表情 if(action=null|action.equals(no)msgString=msgString+msgFrom+对+msgTo+说:+msgContent+;17 else msgString=msgString+msgFrom+action.replaceAll(B,+msgTo+)+msgContent+;/如果是悄悄话只在发送者和接收者的页面中显示 else if(msgFrom.equals(userName)|msg
34、To.equals(userName)if(action=null|action.equals(no)msgString=msgString+悄悄话 +msgFrom+对+msgTo+说:+msgContent+;else msgString=msgString+悄悄话 +msgFrom+action.replaceAll(B,+msgTo+)+msgContent+;catch(Exception ex)ex.printStackTrace();out.println(系统维护);finally conn.closeDB();%parent.loadContent.innerHTML=;pa
35、rent.location.hash=position;/javascript函数,实现用户选择特定聊天用户发送消息 function PerformSubmit(user)parent.inputFrame.chatForm.msgTo.value=user;return false;%/检查当前用户是否已经被踢出聊天室,如果已经被踢出聊天室后面程序不再执行 if(chatRoomObj.denyUser(session.getAttribute(_USER).toString(),session.getAttribute(_CHAT_ROOM).toString()out.println(
36、alert(对 不 起,你 已 经 被 踢 出 本 聊 天 室);out.println(parent.document.location.href=chatRoomList.jsp);/response.sendRedirect(chatRoomList.jsp);return;String userName=session.getAttribute(_USER).toString();/断用户是否已经和聊天室断开连接 if(userName=null)out.println(alert(你已经和聊天室断开);out.println(parent.document.location.href
37、=login.jsp);return;String chatRoom 19=(String)session.getAttribute(_CHAT_ROOM).toString();%在线人员 所有人 a href=#class=l1 onClick=PerformSubmit()4.4 管理员高级管理功能界面 如果是管理员登录,则可通过高级功能进入高级管理界面,可以实现踢人、删除用户以及查看所有用户的功能,如图4.4所示 21 23 图 4.4 管理员高级管理界面 核心代码:高级管理页面 /javascript函数,实现踢人功能 function kick()document.form1.ac
38、tion=kick.jsp;document.form1.submit();/javascript函数,实现删除用户功能 function del()document.form1.action=delete.jsp;document.form1.submit();/javascript函数,实现列出所有注册会员列表 function list()document.location.href=advanced.jsp?list=true;用户 最后发言时间 最近登录时间 25 input type=checkbox name=userName value=用户 最近登录时间 input type
39、=checkbox name=userName value=27%else /如果不是管理员用户弹出无权限对话框,并关闭页面 out.println(alert(你 不 是 管 理,不 能 操 作 此 项);location.href=javascript:window.close();catch(Exception ex)out.println(系统维护);finally conn.closeDB();%5 调试分析 在本次jsp网络编程课程设计中遇到了很多实际性问题在实际设计中才发现,书本上理论性的东西与在实际运用中的还是有一定的出入的,所以有些问题不但要深入地理解,而且要不断地更正以前的
40、错误思维。以下是我在设计系统时的三个阶段中遇到的问题:1.JSP设计阶段 JSP设计界面及逻辑功能时,遇到了前所未有的困难,开始设计的时候,是想为了简单起见,把系统的功能和界面都放在jsp中来写,也就不用java程序了,可是没写几个jsp页面就写不下去了,处处是错误,而且还看不懂错在什么地方,想了好久,最后决定,系统功能在java中写,界面的设计在jsp中写,这样jsp里面的东西就显得简单一些了,更具逻辑性。各种复杂的问题也就慢慢的迎刃而解了!2.数据库设计阶段 数据库表建成后,各个表要有一个字增的非空主键,在建立表与表之间的相互联系时会出现错误。另外,数据库建成后,在为数据库创建用户时,创建
41、的用户不能映射到此数据库!3.JSP连接数据库阶段 这是数据库最后一个阶段了,可是也遇到了很大的问题。开始在JSP中连接数据库时,总是连接不成功,显示一些看不懂的错误,通过上网查资料才知道要对sql server 2005进行设置,开启远程连接以及TCP/IP服务,还要重启服务才可以。这个问题一直纠结了我好久,最终经过我的不懈努力下,终于把它解决了。29 6 心得体会 课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.随着科学技术发展的日新日异,网站设计已经成为当今计算机应用中空前活跃的领域,在生活中可以说得是
42、无处不在。因此作为二十一世纪的大学来说掌握网站的开发技术是十分重要的。通过本次课程设计,我感受颇多,尽管上课时也认真听了老师的讲课,但是已开始面对自己的题目时,还是有些不知所措,都不知道如何下手,后来去图书馆借了几本相关的书籍,心里在感觉有了一些底。经过这差不多四个星期来的学习与编码,总算还是收获不少,对 jsp 的认识也更加的深刻了。在这个过程中,我感觉就像人生的一个缩影,充满了酸甜苦辣。当一个问题想了好久也无法解决时,我感到沮丧与无助。当经过努力解决了一个程序上的难题时,我感到无比的喜悦。当经过每天为了编写代码一坐就是四五个小时,晚上还要写到凌晨一两点钟的时候,我感到无比的痛苦。但艰难痛苦
43、已成往事,灿烂的明天向我走来,今天我总算迎接了胜利的果实,以前的辛酸与痛苦化作我坚强的力量,将在我将来的人生历程中,为我的美好明天打下坚实的基础。经过了这次磨练,我又一次感受到只有付出才能有收获,成功永远是属于不懈努力的人们的。不过经过这几个星期来的不断拼搏,虽然有一点成功的喜悦,但是我依然感受到我的这个在线电子商城依然还有很多不足的地方,我将在以后的时间好好完善它,以求能使我的这个聊天室系统能达到一个更加高的水平,同时也能从中获得更加多的宝贵的经验。这次课程设计终于顺利完成了,在设计中遇到了很多编程问题,最后在唐老师的辛勤指导下,终于游逆而解。同时,在唐老师的身上我学得到很多实用的知识,在次
44、我表示感谢!同时,对给过我帮助的所有同学和各位指导老师再次表示忠心的感谢!致 谢 在本次课程设计实践中,指导教师以对学生认真负责的态度,提供了非常有益的指导意见,给予我很大的帮助,使我得到实质性的提高。这对于我以后的工作和学习是巨大的财富。我会珍惜这次课设中学到的大量知识和经验,为以后的工作学习提供必要的帮助。在做这个系统的过程中,程序调试给我留下最深的印象,在调试上花的时间最多,这说明了我在平时学习的时候学的不够扎实,对错误研究不够,编写代码的时候不够仔细,还有就是缺乏足够的耐心。经过课程设计的训练,我学到很多,也成熟许多。在整个课程设计的过程中指导老师和同学都帮助我很多,特别是老师严谨的治
45、学作风、深厚的理论水平、热情的待人态度给我留下了深刻的印象。他为我提出一些关键性的问题和宝贵的意见,这些关键性的问题和宝贵的意见,对我的作业的成功完成起了决定性作用!我再次感谢您的帮助!31 参 考 文 献 1 范芸.JSP 动态网站开发基础与上机指导.清华大学出版社,2010 年 6 月 2 JSP 网站开发逐步深入中文版.第一版.电子工业出版社,2006 年:P56 3 刘韬,楼兴华.JSP系统开发实例导航.第一版.北京:人民邮电出版社,2004年:P197 4 李保春,曾慧.JSP网络开发教程.第一版.北京:清华大学出版社,2006年:P69 5 张跃廷,JSP 系统开发完全手册.第一版.人民邮电出版社,2006 年:P44 6 JSP 程序设计.第一版.高等教育出版社,2006 年:P201 7 SQL Server 实验指导.第 3 版.清华大学出版社,2010 年