WebSocket实现简单的web聊天室

WebSocket实现简单的web聊天室WebSocket实现简单的web聊天室1.需要Tomcat7.0所以服务器2.需要JDK7.03.手工加入Tomcat7.0中lib目录下的一下三个包catalina.jar、tomcat-coyote.jar、websocket-api.jar4.项目部署后,请将服务器中当前项目下的catalina.jar、tomcat-coyote.jar、websocket-api

大家好,又见面了,我是你们的朋友全栈君。

WebSocket实现简单的web聊天室
1.需要Tomcat7.0所以服务器

2.需要JDK7.0
3.手工加入Tomcat7.0中lib目录下的一下三个包catalina.jar、tomcat-coyote.jar、websocket-api.jar
4.项目部署后,请将服务器中当前项目下的catalina.jar、tomcat-coyote.jar、websocket-api.jar三个包删除。
5.项目目录结构如下


图片

Servlet代码

package com.yc.websockets;

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import javax.websocket.OnClose;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;

import org.apache.catalina.websocket.MessageInbound;
import org.apache.catalina.websocket.StreamInbound;
import org.apache.catalina.websocket.WebSocketServlet;
import org.apache.catalina.websocket.WsOutbound;

@SuppressWarnings({“deprecation”,”unused”, “serial”})
public class WebSocketTest extends WebSocketServlet {
private static List<MyMessageInbound> userList = new ArrayList<MyMessageInbound>();
private HttpSession session;

    @Override
    protected StreamInbound createWebSocketInbound(String str, HttpServletRequest request) {
    
session=request.getSession();
        return new MyMessageInbound();
    }

    private class MyMessageInbound extends MessageInbound {
        WsOutbound myoutbound;

        /**
         * 当用户登录时,WebSocket握手完成,创建完毕,WsOutbound用于向客户端发送数据
         */
public void onOpen(WsOutbound outbound) {
            try {
                System.out.println(“Open Client.”);
                this.myoutbound = outbound;
                userList.add(this); //添加当前用户
                
                //向客服端发送信息
                outbound.writeTextMessage(CharBuffer.wrap(“Hello!”));
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

/**
 * 用户退出时,WebSocket关闭事件,参数status应该来自org.apache.catalina.websocket.Constants
 * 中定义的几个常量,可以参考文档或者核对一下Tomcat的源码
 */
        @Override
        public void onClose(int status) {
            userList.remove(this); //移除当前用户
        }

       /**
        * 接受用户发过来的信息,有文本消息数据到达
        */
        @Override
        public void onTextMessage(CharBuffer cb) throws IOException {
            for (MyMessageInbound mmib:userList){ //循环向所有在线用户发送当前用户的信息
                CharBuffer buffer = CharBuffer.wrap(cb);
                mmib.myoutbound.writeTextMessage(buffer); //调用指定用户的发送方法发送当前用户信息
                mmib.myoutbound.flush(); //清空缓存
            }
        }

        /**
         * 有二进制消息数据到达,暂时没研究出这个函数什么情况下触发,js的WebSocket按理说应该只能send文本信息才对
         */
        @Override
        public void onBinaryMessage(ByteBuffer bb) throws IOException {
        }
    }
}

web.xml配置文件


 
<?xml version=”1.0″ encoding=”UTF-8″?>

<web-app version=”3.0″ xmlns=”
http://java.sun.com/xml/ns/javaee
xsi:schemaLocation=”
http://java.sun.com/xml/ns/javaee ;
<display-name></display-name>
  
<servlet>
<servlet-name>webServlet</servlet-name>
<servlet-class>com.yc.websockets.WebSocketTest</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>webServlet</servlet-name>
<url-pattern>/webServlet</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>


index.html


<!DOCTYPE html>
<html>
<head>
<meta charset=UTF-8>
<title>Tomcat WebSocket Chat</title>
<script>
//设定WebSocket,注意协议是ws,请求是指向对应的WebSocketServlet的
/*设定WebSocket,注意协议是ws,请求是指向对应的WebSocketServlet的
var url = “ws://127.0.0.1:8080/j2ee6/echo.ws”;
// 创建WebSocket实例,下面那个MozWebSocket是Firefox的实现
if (‘WebSocket’ in window) {
ws = new WebSocket(url);
} else if (‘MozWebSocket’ in window) {
ws = new MozWebSocket(url);
} else {
alert(‘Unsupported.’);
return;
}*/
var ws = new WebSocket(“ws://218.196.14.208:8080/webSocket/webServlet”);

//WebSocket握手完成,连接成功的回调
//有个疑问,按理说new WebSocket的时候就会开始连接了,如果在设置onopen以前连接成功,是否还会触发这个回调
ws.onopen = function() {
//请求成功
};

//收到服务器发送的文本消息, event.data表示文本内容
ws.onmessage = function(message) {
document.getElementById(“talkInfo”).innerHTML+=message.data+”<hr style=’border: 1px dashed #CCC’/>”;
};

//关闭WebSocket的回调
ws.onclose = function() {
//alert(‘Closed!’);
};

// 通过WebSocket想向服务器发送一个文本信息
function postToServer() {
ws.send(document.getElementById(“content”).value);
document.getElementById(“content”).value = “”;
}

//关闭WebSocket
function closeConnect() {
ws.close();
}
</script>
<style>
* {
margin: 0 auto;
padding: 0px;
font-size: 12px;
font-family: “微软雅黑”;
line-height: 26px;
}

#bigbox {
margin:0px auto;
padding:0px;
width:70%;
}

#talkInfo{
width:100%;
height:500px;
border:1px solid red;
overflow: scorll;
}

#operation{
width:100%;
height:30px;
margin-top:10px;
}

#content{
height:30px;
line-height:30px;
}
</style>
</head>
<body>
<div id=”bigbox”>
<div id=”talkInfo”></div>
<div id=”operation”>
<center>
<input type=”text” name=”content” id=”content” size=”100″/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type=”button” value=” &nbsp;发送&nbsp; ” οnclick=”postToServer()” />&nbsp;&nbsp;
<input type=”button” value=” &nbsp;我闪 &nbsp; ” οnclick=”closeConnect()” />
</center>
</div>
</div>
</body>

</html>
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152190.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 高精度快速阶乘算法

    高精度快速阶乘算法    我在业余时间开发了一套《超大整数完全精度快速算法库》HugeCalc,可快速计算超大整数的加、减、乘、除(商/余)、乘方、开方,也可快速计算大数的Fibonacci数列、(双)阶乘、排列、组合等,还可完成超大整数数组的最大公约数、最小公倍数等数论运算,现在,该套软件已被华军、天空、电脑之家、天天等下载站点收录。    自在网上公开以来,广受网友关注,经常有网友来联系,想交流一些算法心

    2022年7月24日
    6
  • 个人对json的一些简单理解「建议收藏」

    个人对json的一些简单理解「建议收藏」在最近的学习中,查阅了很多资料,了解了一些关于json的基本知识,下面做一个简单的总结:json是什么没有.json结尾的这种文件,json(JavaScriptObjectNotation)是一种简单的数据交换格式,在此之前我也不知道这个东西其实没有想象的那么抽象,看看后面的例子会更清晰json中的数据结构json中只有两种数据基本结构,一种是MAP,或者叫对象,另一种是Ar…

    2022年6月9日
    38
  • java random函数用法_JAVA的Random类的用法详解[通俗易懂]

    java random函数用法_JAVA的Random类的用法详解[通俗易懂]Random类主要用来生成随机数,本文详解介绍了Random类的用法,希望能帮到大家。Random类(java.util)Random类中实现的随机算法是伪随机,也就是有规则的随机。在进行随机时,随机算法的起源数字称为种子数(seed),在种子数的基础上进行一定的变换,从而产生需要的随机数字。相同种子数的Random对象,相同次数生成的随机数字是完全相同的。也就是说,两个种子数相同的Random…

    2022年5月28日
    40
  • golang激活码2021(JetBrains全家桶)

    (golang激活码2021)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~0UY7RF7AC5-eyJsaWNlb…

    2022年3月28日
    154
  • 2021年PyCharm激活码破解方法

    2021年PyCharm激活码破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    41
  • 比太钱包使用方法及冷钱包存储方案-2

    拖更一个月的我又开始更新了。过完年,恰逢数字货币开始上涨,正好是聊聊钱包的好时候。上文说到比太钱包的冷热模式,这次接上文写冷钱包模式下的发币及公钥监控操作。先从冷钱包模式下发币说起吧:1,打开钱包,点击发送按钮。2,输入收款地址和金额,并点击发送。这里无论是输入比特币金额还是法币金额,钱包会自动换算出另一种货币金额。3,输入钱包密码,准备冷钱包签名。4,生成未签名的交易信息二维码,需使用装有对应…

    2022年4月5日
    152

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号