简单聊天室采用各种内部对象不适用数据库实现。

一个聊天室要实现的基本功能是:

        1.用户登录进入聊天室,

   2.用户发言

   3.用户可以看见别人发言

刚才算是简单的需求分析了,现在就应该是进行mvc结构的设计:

  1.视图,有登陆页面login.jsp,聊天页面chat.jsp,其中chat.jsp利用框架实现,包括两部分,用户发言sendMessage.jsp和聊天信息的查看content.jsp;

  2.模型,包括聊天信息的显示(类Message)和聊天信息的管理(类MessageService);

  3.控制器,登录功能的控制器LoginServlet,添加消息的控制器AddMessageServlet。

  整个程序实现的大致流程是这样的:每当一个用户登录聊天室,根据用户的userid把用户添加进application对象的ArrayList中,在application中保存的是当前所有在聊天的用户;用户登陆成功之后,通过控制器LoginServlet把application对象遍历,输出所有的消息,消息存储在application(消息格式:用户名+消息);用户发言,通过控制器AddMessageServlet,先在session中取出用户名,把当前消息放在application中,保存更新后的消息,跳转到聊天页面。

精简源代码:

1.登陆界面login.jsp

 <body>
<h1>欢迎进入聊天室</h1>
<form action="login">
用户名:<input type="text" name="userid"><br> <input type="submit" value="进入"> <input type="reset" value="重写"> </form> </body>

2.聊天界面整体框架chat.jsp

<frameset rows="*,20%">
<frame name="content" src="content.jsp">
<frame name="sendMessage" target="content" src="sendMessage.jsp">
<noframes>
<body>
<p>此网页使用了框架,但你的浏览器不支持框架</p>
</body>
</noframes>
</frameset>

3.用户发言sendMessage.jsp

 <body>
<form action="addmessage" target="content">
发言:<input type="text" name="info"> <input type="submit"
value="确定">
</form>
</body>

4.显示聊天信息

 <body>
<%
//页面每隔1秒自动刷新一遍
response.setHeader("refresh","1");
%> <c:forEach items="${allMessage}" var="message">
${message.userid }
在${message.time }说:<font color="green">${message.info }</font>
<br>
</c:forEach>
</body>

5.登录控制器LoginServlet

 public class LoginServlet extends HttpServlet {

     public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// 获取用户输入
String userid = request.getParameter("userid");
userid = new String(userid.getBytes("utf-8")); // 获取application对象
ServletContext application = this.getServletContext();
// 获取application对象中user
ArrayList<String> users = (ArrayList<String>) application
.getAttribute("users"); // 判断用户名是否存在
if (users != null && users.contains(userid)) {
request.setAttribute("errorinfo", "用户" + userid + "已经存在");
RequestDispatcher rd;
rd = request.getRequestDispatcher("login.jsp");
rd.forward(request, response);
} else {
if (users == null)// 如果当前application中没有user,初始化user对象
{
users = new ArrayList<String>();
}
users.add(userid);
application.setAttribute("users", users); // 为每一个用户设置一个session
HttpSession session = request.getSession(true);
session.setAttribute("userid", userid); response.sendRedirect("chat.jsp"); } } public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
} }

6.添加消息的控制器AddMessageServlet

 public class AddMessageServlet extends HttpServlet {

     public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { // 从request中取出用户的个人信息 HttpSession session = request.getSession(true);
String userid = (String) session.getAttribute("userid"); // 从request对象中取出用户新增的聊天信息 String info = request.getParameter("info");
info = new String(info.getBytes("utf-8")); // 取出所有的聊天信息
ServletContext application = this.getServletContext();
ArrayList<Message> allMessage = (ArrayList<Message>) application
.getAttribute("allMessage"); // 创建消息对象
Message message = new Message(userid, info); // 创建业务对象
MessageService service = new MessageService(allMessage); // 调用业务逻辑
service.addMessages(message); // 保存更新后的消息
application.setAttribute("allMessage", service.getAllMessages()); // 转向聊天页面
response.sendRedirect("content.jsp"); } public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
} }

7.聊天信息Message.java

 //聊天信息的表示
public class Message {
private String userid; private String info; public Message(String userid,String info)
{
this.userid = userid;
//this.sex=sex;
this.info=info;
this.time=(new SimpleDateFormat("hh:mm:ss")).format(new Date());//将时间格式化 }
public String getUserid() {
return userid;
}
public void setUserid(String userid) {
this.userid = userid;
} public String getInfo() {
return info;
}
public void setInfo(String info) {
this.info = info;
}
public String getTime() {
return time;
}
public void setTime(String time) {
this.time = time;
}
private String time; }

8.聊天信息管理MessageService.java

 public class MessageService {
private ArrayList<Message> allMessages;
public MessageService(ArrayList<Message> allMessages)
{
this.allMessages=allMessages;
}
public ArrayList<Message> getAllMessages()
{
return allMessages;
} public void addMessages(Message message)
{
//先判断聊天信息列表是否为空,为空则新建聊天列表
if(allMessages==null)
{
allMessages=new ArrayList<Message>();
}
else
{
allMessages.add(0,message);//将指定的元素插入此列表中的指定位置。向右移动当前位于该位置的元素(如果有)以及所有后续元素(将其索引加 1)。
}
} }

收获:通过这么一个小小的web程序,加深了对mvc模式的理解。

mvc的传值方式(个人理解):视图层通过表单提交的方式把信息放在request对象中,在控制器中通过request对象获取视图层的数据,获取的数据经过模型层的业务逻辑处理,把相应的结果放在response对象中传回浏览器显示在视图中。

  小知识点:

    application对象只有一个,每一个用户都有自己的session,每个用户的每个请求都对应着一个新的request对象(request只能在一次请求时共享信息)。

    标准标签库的使用:循环输出<c:forEach var="变量名" items="集合对象">循环体</c:forEach>

   最后,部署自己的应用到服务器下就可以使用了。 

java web利用mvc结构实现简单聊天室功能的更多相关文章

  1. Java利用TCP编程实现简单聊天室

    前言: 本文是我在学习尚学堂JAVA300集第二季网络编程部分仿照视频内容实现而成 具体可以去尚学堂官网观看视频学习 一.实现思路 实现聊天室的最核心部分就是JAVA的TCP网络编程. TCP 传输控 ...

  2. (ASP.net)利用Application对象制作简单聊天室

    1.共四个页面,Default.aspx默认主页,Default2.aspx聊天室 default3.aspx显示用户列表,default4.aspx显示聊天内容,添加一个Global.asax全局程 ...

  3. Java Web利用POI导出Excel简单例子

    采用Spring mvc架构: Controller层代码如下 @Controller public class StudentExportController{ @Autowired private ...

  4. ASP.NET SingalR + MongoDB 实现简单聊天室(一):搭建基本框架

    ASP.NET SingalR不多介绍.让我介绍不如看官网,我这里就是直接上源代码,当然代码还是写的比较简单的,考虑的也少,希望各位技友多多提意见. 先简单介绍聊天室功能: 用户加入聊天室,自动给用户 ...

  5. 利用socket.io+nodejs打造简单聊天室

    代码地址如下:http://www.demodashi.com/demo/11579.html 界面展示: 首先展示demo的结果界面,只是简单消息的发送和接收,包括发送文字和发送图片. ws说明: ...

  6. 基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍。最后我们将会实现一个基于Server-Sent Event和Flask简单的在线聊天室。

    基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍.最后我们将会实现一个基于S ...

  7. 如何利用WebSocket实现网页版聊天室

    花了将近一周的时间终于完成了利用WebSocket完成网页版聊天室这个小demo,期间还走过了一段"看似弯曲"的道路,但是我想其实也不算是弯路吧,因为你走过的路必将留下你的足迹.这 ...

  8. SpringBoot 搭建简单聊天室

    SpringBoot 搭建简单聊天室(queue 点对点) 1.引用 SpringBoot 搭建 WebSocket 链接 https://www.cnblogs.com/yi1036943655/p ...

  9. C#基于Socket的简单聊天室实践

    序:实现一个基于Socket的简易的聊天室,实现的思路如下: 程序的结构:多个客户端+一个服务端,客户端都是向服务端发送消息,然后服务端转发给所有的客户端,这样形成一个简单的聊天室功能. 实现的细节: ...

随机推荐

  1. .Net 特性分析与妙用

    一.特性是什么 1.想象很多小伙伴们都看过在一个类上方.或者在控制器见过类似的东东,加上之后就可以标识这个类或者方法就具备了某些特点 ,那我们就进入它的内心一探究竟吧. 2.我们进入某个特性之后,可以 ...

  2. 进阶之路 | 奇妙的Thread之旅

    前言 本文已经收录到我的Github个人博客,欢迎大佬们光临寒舍: 我的GIthub博客 需要已经具备的知识: Thread的基本概念及使用 AsyncTask的基本概念及使用 学习清单: 线程概述 ...

  3. sonarqube配置全指南,集成阿里巴巴p3c规范

    环境准备 内置数据库 Sonar安装成功后,默认内置H2数据库,用于记录单次的扫描结果,对同一个project重复扫码,会覆盖之前的扫描记录,所以H2 数据库只应用于测试,不可以用于生产环境,那如果你 ...

  4. vue基础回顾 router

    vue-router 1. 底层原理 hash 或者h5 histroy(有兼容性) 2. 使用的时候Vue需要引入VueRouter Vue.use(VueRouter) //VueRouter 底 ...

  5. js 随机产生100个0~1000之间的整数

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. el-select下拉加载(实现懒加载)

    情况:项目出现了下拉数据量过大,出现页面卡死问题,反馈到我这:当时实现思路1.使用render函数去渲染下拉框 试了发现卡死情况依然存在,所以尝试方法2 2.使用原生js去添加下拉框的<opti ...

  7. 小白学 Python 数据分析(16):Matplotlib(一)坐标系

    人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 小白学 Python 数据分析(2):Pandas (一)概述 小白学 Python 数据分析(3):P ...

  8. 第3章 C++中的C

    用union节省内存 使用场合:有时一个程序会使用同一个变量处理不同的数据类型,对于这种情况,有两种选择:可以创建一个struct,其中包含所有可能的不同类型的数据:也可以使用联合union,它能把所 ...

  9. <keep-alive> 大量异步数据嵌入在循环体内,会有大量相同异步请求,可以缓存下拉用。

    <keep-alive> 大量异步数据嵌入在循环体内,会有大量相同异步请求,可以缓存下拉用.

  10. Codeforces Round #200 (Div. 2)E

    Read Time 题意:有一个数组,很多指针指在这个数组上,每次每个指针可以向左或向右移动一个位置.给出一些需要访问的位置,问访问用的最少时间. 一个指针只可能转一次方向.二分答案. #includ ...