文档章节

在线交流系统的实现

c
 chuiyuan
发布于 2014/06/18 19:47
字数 738
阅读 309
收藏 4

一。系统分析 

1. 页面结构 

      要用到两个界面 ,登录界面和聊天界面。应该写几个JSP 代码 呢?为了利于分工,我们将

界面显示和动作分开。

三个动作

(1)登录,为这个动作设计一个输入页面 loginForm.jsp ,显示登录表单;提交给 loginAction.jsp, 负责接收参数,处理请求

(2)聊天,为这个动作设计 一个输入页面chatForm.jsp. 显示聊天 界面表单;该表单提交 给 chatAction.jsp ,负责接受

聊天 信息,处理聊天请求。

    请求完毕 ,跳转到 chatForm.jsp,在chatForm.jsp中,信息内容的显示和在线名单可以另外写msgs.jsp ,通过 iframe 嵌入。

作用是显示用户的聊天信息,在线名单 ,这个页面每隔一会刷新一下。

(3)退出登录,为这个动作写一个 logoutAction.jsp ,负责 清空用户的状态,跳转到 loginForm.jsp。

2. 状态保存

消息内容和在线名单都是保存在  application 中。

用户的信息保存在session 中。


二、开发过程 

1. 准备数据 

创建 数据 库脚本为

create table t_customer(
 account varchar(40),
 password varchar(40),
 name varchar(40));

2. 编写 DAO 和VO

在DAO中验证用户的身份,用户的信息用VO封装。这里只写下DAO中的关键代码 。

public void initConnection() throws Exception{
		Class.forName("com.mysql.jdbc.Driver");  //指明驱动
		String url = "jdbc:mysql://localhost:3306/test";  
		connection= DriverManager.getConnection(url, "root","root");
	}
	
	public Customer getCustomerByAccount(String account)throws Exception{
		Customer customer= null;
		initConnection();
		String sql= "select *  from t_customer where account =?";
		PreparedStatement ps = connection.prepareStatement(sql);
		ps.setString(1, account);
		ResultSet rs= ps.executeQuery();
		
		if (rs.next()){
			customer= new Customer();
			customer.setAccount(rs.getString("account"));
			customer.setName(rs.getString("name"));
			customer.setPassword(rs.getString("password"));
		}
		closeConnection();
		return customer;
	}

3. 编写 loginForm.jsp 和loginAction.jsp 

对于登录界面来说 ,有两个页面。

loginForm是:

<%
    	//初始化application 
      	ArrayList customers = (ArrayList) application.getAttribute("customers");
    	if (customers == null) {
    		customers = new ArrayList();
    		application.setAttribute("customers", customers);
    	}

    	ArrayList msgs = (ArrayList) application.getAttribute("msgs");
    	if (msgs == null) {
    		msgs = new ArrayList();
		    application.setAttribute("msgs", msgs);
    	}
    %>
    
    欢迎登录在线交流系统 
    <form action="loginAction.jsp"  name ="form1" method ="post">
    输入帐号:<input name ="account"  type="text"><br>
    输入密码:<input name ="password"  type= "text"> <br>
    <input type ="submit"  value="登录">
    </form>

loginAction是

  <%
    request.setCharacterEncoding("gb2312");
    String account = request.getParameter("account");
    String password = request.getParameter("password");
    
    CustomerDAO cdao = new CustomerDAO();
    Customer customer= cdao.getCustomerByAccount(account);
    if (customer==null|| !customer.getPassword().equals(password)){
    %> 
    登录失败,<a href ="loginForm.jsp">返回页面</a>
    <%
    }
    else{
    session.setAttribute("customer", customer);
    ArrayList customers =(ArrayList) application.getAttribute("customers");
    ArrayList msgs = (ArrayList)application.getAttribute("msgs");
    customers.add(customer);
    msgs.add(customer.getName()+"上线啦");
    response.sendRedirect("chatForm.jsp");
    } 
     %>

4. 编写 chatForm.jsp 和chatAction.jsp 

chatForm.jsp .

 <%
  Customer customer=(Customer)session.getAttribute("customer");
   %>
   欢迎 <%=customer.getName() %>聊天<br>
   <form action="chatAction.jsp"  method ="post">
   输入聊天信息:<input name ="msg" type="text"  size="40">
   <input type ="submit" value ="发送">
   </form>
   <a href ="logoutAction.jsp">退出登录</a>
   <hr>
   <iframe src ="msgs.jsp" witdth ="100%"  height ="80%"  frameborder ="0"></iframe>

chatAction.jsp 

<%
		Customer customer = (Customer) session.getAttribute("customer");
	%>
	<%
		request.setCharacterEncoding("gb2312");
		String msg = request.getParameter("msg");
		ArrayList msgs = (ArrayList) application.getAttribute("msgs");
		if (msg != null && !msg.equals("")) {
			msgs.add(customer.getName() + "说:" + msg);
			response.sendRedirect("chatForm.jsp");
		}
	%>

msgs.jsp

<%response.setHeader("Refresh", "10");
     %>
    
     <table width ="80%"  border="0" align ="center">
     <tr bgcolor = "yellow"  align ="center">
     <td width ="75%" >消息</td>
     <td width ="25%">当前在线</td>
     </tr>
     
     <tr bgcolor= "pink">
     <td >
     <%
     	ArrayList msgs = (ArrayList) application.getAttribute("msgs");
       	if (msgs != null) {
     		for (int i = msgs.size() - 1; i >= 0; i--) {
     			out.println(msgs.get(i) + "<br>");
     		}
     	}
     %></td>
     <td valign="top">
     <%
     ArrayList customers = (ArrayList)application.getAttribute("customers");
     if (customers!=null){
     	for (int i=customers.size()-1; i>=0;i--){
    		 Customer customer= (Customer)customers.get(i);
     		out.println(customer.getAccount()+"("+customer.getName()+")"+"<br>");
     	}
     }
      %></td>
     </tr>
     </table>


© 著作权归作者所有

共有 人打赏支持
c
粉丝 9
博文 92
码字总数 40993
作品 0
海淀
私信 提问
如何通过 LeanCloud 快速开发实时对战小游戏?

实时对战是 LeanCloud 专门针对多人在线对战游戏推出的后端服务。开发者不需要自己搭建后端系统,利用云服务就可以轻松实现游戏内玩家匹配、在线对战消息同步等功能。本期直播课程我们将通过...

LeanCloud_通讯
10/29
0
0
远程教育平台--BigBlueButton

BigBlueButton 是一个使用 ActionScript 开发的在线视频会议系统或者是远程教育系统,主要功能包括在线PPT演示、视频交流和语音交流,还可以进行文字交流、举手发言等功能,特别适合用在网上...

匿名
2010/03/04
68.1K
4
名称:53KF网站客服系统 v3.0.1官方版

名称:53KF网站客服系统 v3.0.1官方版版本:3.0.1软件大小:107 KB软件语言:简体中文软件授权:免费版应用平台:Win7/Win2003/Vista/Win2000/WinXP 53KF网站客服系统用于企业内部人员之间、...

相心的泪
2016/08/03
23
0
BigBlueButton 0.9.0 RC 发布,远程教育系统

BigBlueButton 0.9.0 RC 发布,此版本改善了音频质量。对于 Firefox 和 Chrome 用户来说,通过网络实时协作协议(WebRTC)支持在线发送和接收音频。同时此版本可以设置公共聊天和私人聊天两种模...

oschina
2015/04/29
2.9K
9
开源中国2010年10款热门教学相关的开源软件

百年大计,教育为本。本文收录了 2010 年度开源中国社区最受欢迎的 10 款跟教学服务和教学管理相关的开源软件,这些软件多数采用PHP开发,也有Java的系统。 1. BigBlueButton BigBlueButton...

红薯
2010/12/29
6.8K
18

没有更多内容

加载失败,请刷新页面

加载更多

jquery通过id显示隐藏

var $div3 = $('#div3'); 显示 $div3.show(); 隐藏 $div3.hide();

yan_liu
今天
3
0
《乱世佳人》读书笔记及相关感悟3900字

《乱世佳人》读书笔记及相关感悟3900字: 之前一直听「荔枝」,后来不知怎的转向了「喜马拉雅」,一听就是三年。上班的时候听房产,买房了以后听装修,兴之所至时听旅行,分手后听亲密关系,...

原创小博客
今天
3
0
大数据教程(9.6)map端join实现

上一篇文章讲了mapreduce配合实现join,本节博主将讲述在map端的join实现; 一、需求 实现两个“表”的join操作,其中一个表数据量小,一个表很大,这种场景在实际中非常常见,比如“订单日志...

em_aaron
今天
3
0
cookie与session详解

session与cookie是什么? session与cookie属于一种会话控制技术.常用在身份识别,登录验证,数据传输等.举个例子,就像我们去超市买东西结账的时候,我们要拿出我们的会员卡才会获取优惠.这时...

士兵7
今天
3
0
十万个为什么之为什么大家都说dubbo

Dubbo是什么? 使用背景 dubbo为什么这么流行, 为什么大家都这么喜欢用dubbo; 通过了解分布式开发了解到, 为适应访问量暴增,业务拆分后, 子应用部署在多台服务器上,而多台服务器通过可以通过d...

尾生
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部