文档章节

在线交流系统的实现

c
 chuiyuan
发布于 2014/06/18 19:47
字数 738
阅读 300
收藏 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
海淀
开源中国2010年10款热门教学相关的开源软件

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

红薯
2010/12/29
6.7K
18
零起飞/FLY-CMS

#CMS-07FLY 你还在为没人写后台程序烦恼吗? 你还在为招不到合适的程序员而烦恼吗? 你还在为写后台源码浪费了大量的时间而烦恼吗? 现在你将不在为此而烦恼,只要你拥有了07FLY企业建站系统,...

零起飞
2014/12/01
0
0
远程教育平台--BigBlueButton

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

匿名
2010/03/04
68.1K
4
shuzheng/zhengAdmin

zhengAdmin 基于bootstrap实现的响应式Material Design风格的通用后台管理系统 交流QQ群:133107819🈵、284280411🈵、305155242🈵、528049386🈵、157869467🈵、570766789♨️ 在线...

shuzheng
2017/03/13
0
0
基于Java企业门户网站设计(一)

开始 第一章 绪论 1.1 课题背景及意义 1.2 开发环境与技术简介 1.2.1 B/S架构 1.2.2 jsp 1.2.3 SQL server 2000 第二章 需求分析 2.1系统功能需求 2.2系统功能建模 第三章 总体设计 3. 1 系统...

请叫我赵小宝
2014/11/23
0
3

没有更多内容

加载失败,请刷新页面

加载更多

一个可能的NEO链上安全随机数解决方案

0x00 困境 链上安全随机数生成应该算是一个比较蛋疼的问题,哪怕你的系统再牛逼,合约程序困在小小的虚拟机里,哪怕天大的本事也施展不开。 更悲催的是,交易执行的时候,是在每一个节点都执...

暖冰
今天
1
0
【大福利】极客时间专栏返现二维码大汇总

我已经购买了如下专栏,大家通过我的二维码你可以获得一定额度的返现! 然后,再给大家来个福利,只要你通过我的二维码购买,并且关注了【飞鱼说编程】公众号,可以加我微信或者私聊我,我再...

飞鱼说编程
今天
1
0
Spring5对比Spring3.2源码之容器的基本实现

最近看了《Spring源码深度解析》,该书是基于Spring3.2版本的,其中关于第二章容器的基本实现部分,目前spring5的实现方式已有较大改变。 Spring3.2的实现: public void testSimpleLoad(){...

Ilike_Java
今天
1
0
【王阳明心学语录】-001

1.“破山中贼易,破心中贼难。” 2.“夫万事万物之理不外于吾心。” 3.“心即理也。”“心外无理,心外无物,心外无事。” 4.“人心之得其正者即道心;道心之失其正者即人心。” 5.“无...

卯金刀GG
今天
2
0
OSChina 周三乱弹 —— 我们无法成为野兽

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @ _刚刚好: 霸王洗发水这波很骚 手机党少年们想听歌,请使劲儿戳(这里) hahahahahahh @嘻酱:居然忘了喝水。 让你喝可乐的话, 你准忘不了...

小小编辑
今天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部