iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在HTML5中利用WebSocket实现点对点聊天
  • 278
分享到

怎么在HTML5中利用WebSocket实现点对点聊天

2023-06-09 15:06:48 278人浏览 薄情痞子
摘要

这期内容当中小编将会给大家带来有关怎么在HTML5中利用websocket实现点对点聊天,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。首先在系统启动的时候调用InitServlet方法public&nbs

这期内容当中小编将会给大家带来有关怎么在HTML5中利用websocket实现点对点聊天,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

首先在系统启动的时候调用InitServlet方法

public class InitServlet extends httpservlet {    private static final long serialVersionUID = -3163557381361759907L;      private static HashMap<String,MessageInbound> SocketList;        public void init(ServletConfig config) throws ServletException {            InitServlet.socketList = new HashMap<String,MessageInbound>();            super.init(config);            System.out.println("初始化聊天容器");        }        public static HashMap<String,MessageInbound> getSocketList() {            return InitServlet.socketList;        }    }

 这里你可以跟自己的系统结合,对应的WEB配置代码如下:

<?xml version="1.0" encoding="UTF-8"?><web-app version="3.0" xmlns="Http://java.sun.com/xml/ns/javaee"    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee     http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">    <servlet>        <servlet-name>websocket</servlet-name>        <servlet-class>socket.MyWebSocketServlet</servlet-class>    </servlet>    <servlet-mapping>        <servlet-name>websocket</servlet-name>        <url-pattern>*.do</url-pattern>    </servlet-mapping>    <servlet>        <servlet-name>initServlet</servlet-name>        <servlet-class>socket.InitServlet</servlet-class>        <load-on-startup>1</load-on-startup><!--方法执行的级别-->    </servlet>    <welcome-file-list>        <welcome-file>index.jsp</welcome-file>    </welcome-file-list></web-app>

这就是最普通的前台像后台发送请求的过程,也是很容易嵌入到自己的系统里

MyWebSocketServlet:

public class MyWebSocketServlet extends WebSocketServlet {    public String getUser(HttpServletRequest request){        String userName = (String) request.getSession().getAttribute("user");        if(userName==null){            return null;        }        return userName;      }      protected StreamInbound createWebSocketInbound(String arg0,            HttpServletRequest request) {        System.out.println("用户" + request.getSession().getAttribute("user") + "登录");        return new MyMessageInbound(this.getUser(request));     }}

MyMessageInbound继承MessageInbound

package socket;import java.io.IOException;import java.NIO.ByteBuffer;import java.nio.CharBuffer;import java.util.HashMap;import org.apache.catalina.websocket.MessageInbound;import org.apache.catalina.websocket.WsOutbound;import util.MessageUtil;public class MyMessageInbound extends MessageInbound {    private String name;    public MyMessageInbound() {        super();    }    public MyMessageInbound(String name) {        super();        this.name = name;    }    @Override      protected void onBinaryMessage(ByteBuffer arg0) throws IOException {      }      @Override      protected void onTextMessage(CharBuffer msg) throws IOException {         //用户所发消息处理后的map        HashMap<String,String> messageMap = MessageUtil.getMessage(msg);    //处理消息类        //上线用户集合类map        HashMap<String, MessageInbound> userMsgMap = InitServlet.getSocketList();        String fromName = messageMap.get("fromName");    //消息来自人 的userId        String toName = messageMap.get("toName");         //消息发往人的 userId        //获取该用户        MessageInbound messageInbound = userMsgMap.get(toName);    //在仓库中取出发往人的MessageInbound        MessageInbound messageFromInbound = userMsgMap.get(fromName);        if(messageInbound!=null && messageFromInbound!=null){     //如果发往人 存在进行操作            WsOutbound outbound = messageInbound.getWsOutbound();             WsOutbound outFromBound = messageFromInbound.getWsOutbound();            String content = messageMap.get("content");  //获取消息内容            String msGContentString = fromName + "说: " + content;   //构造发送的消息            //发出去内容            CharBuffer toMsg =  CharBuffer.wrap(msgContentString.toCharArray());            CharBuffer fromMsg =  CharBuffer.wrap(msgContentString.toCharArray());            outFromBound.writeTextMessage(fromMsg);            outbound.writeTextMessage(toMsg);  //            outFromBound.flush();            outbound.flush();        }    }      @Override      protected void onClose(int status) {          InitServlet.getSocketList().remove(this);          super.onClose(status);      }      @Override    protected void onOpen(WsOutbound outbound) {          super.onOpen(outbound);          //登录的用户注册进去        if(name!=null){            InitServlet.getSocketList().put(name, this);//存放客服ID与用户        }    }    @Override    public int getReadTimeout() {        return 0;    }  }

在onTextMessage中处理前台发出的信息,并封装信息传给目标

还有一个messageutil

package util;import java.nio.CharBuffer;import java.util.HashMap;public class MessageUtil {    public static HashMap<String,String> getMessage(CharBuffer msg) {        HashMap<String,String> map = new HashMap<String,String>();        String msgString  = msg.toString();        String m[] = msgString.split(",");        map.put("fromName", m[0]);        map.put("toName", m[1]);        map.put("content", m[2]);        return map;    }}

当然了,前台也要按照规定的格式传信息

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>Index</title><script type="text/javascript" src="js/Jquery-1.7.2.min.js"></script><%session.setAttribute("user", "小化");%><script type="text/javascript">var ws = null;function startWebSocket() {    if ('WebSocket' in window)        ws = new WebSocket("ws://localhost:8080/WebSocketUser/websocket.do");    else if ('MozWebSocket' in window)        ws = new MozWebSocket("ws://localhost:8080/WebSocketUser/websocket.do");    else        alert("not support");    ws.onmessage = function(evt) {        //alert(evt.data);        console.log(evt);       // $("#xiaoxi").val(evt.data);        setMessageInnerHTML(evt.data);    };    function setMessageInnerHTML(innerHTML){        document.getElementById('message').innerHTML += innerHTML + '<br/>';    }    ws.onclose = function(evt) {        //alert("close");        document.getElementById('denglu').innerHTML="离线";    };    ws.onopen = function(evt) {        //alert("open");        document.getElementById('denglu').innerHTML="在线";        document.getElementById('userName').innerHTML='小化';    };}function sendMsg() {    var fromName = "小化";    var toName = document.getElementById('name').value;  //发给谁    var content = document.getElementById('writeMsg').value; //发送内容    ws.send(fromName+","+toName+","+content);//注意格式}</script></head><body onload="startWebSocket();"><p>聊天功能实现</p>登录状态:<span id="denglu" style="color:red;">正在登录</span><br>登录人:<span id="userName"></span><br><br><br>发送给谁:<input type="text" id="name" value="小明"></input><br>发送内容:<input type="text" id="writeMsg"></input><br>聊天框:<div id="message" style="height: 250px;width: 280px;border: 1px solid; overflow: auto;"></div><br><input type="button" value="send" onclick="sendMsg()"></input></body></html>

上述就是小编为大家分享的怎么在HTML5中利用WebSocket实现点对点聊天了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: 怎么在HTML5中利用WebSocket实现点对点聊天

本文链接: https://www.lsjlt.com/news/256440.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在HTML5中利用WebSocket实现点对点聊天
    这期内容当中小编将会给大家带来有关怎么在HTML5中利用WebSocket实现点对点聊天,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。首先在系统启动的时候调用InitServlet方法public&nbs...
    99+
    2023-06-09
  • 怎么利用html5的websocket实现websocket聊天室
    小编给大家分享一下怎么利用html5的websocket实现websocket聊天室,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!     什么是websocket ...
    99+
    2022-10-19
  • 怎么在HTML5中使用WebSocket实现一个聊天室
    本篇文章给大家分享的是有关怎么在HTML5中使用WebSocket实现一个聊天室,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1)注册注册要处理几个事情,分别是注册完成后获取当...
    99+
    2023-06-09
  • SpringBoot中怎么使用WebSocket实现点对点消息
    本篇内容介绍了“SpringBoot中怎么使用WebSocket实现点对点消息”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、添加依赖,配...
    99+
    2023-06-08
  • PHP中怎么利用WebSocket实现一个在线聊天通讯系统
    今天就跟大家聊聊有关PHP中怎么利用WebSocket实现一个在线聊天通讯系统,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。新建WebSocket....
    99+
    2022-10-18
  • nodejs中怎么利用websocket实现一个实时聊天系统
    nodejs中怎么利用websocket实现一个实时聊天系统,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。client.html:<!D...
    99+
    2022-10-19
  • 在SpringBoot中利用Websocket实现一个网页聊天功能
    这篇文章将为大家详细讲解有关在SpringBoot中利用Websocket实现一个网页聊天功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。导入websocket的包。通过使用SpringB...
    99+
    2023-05-31
    springboot websocket bs
  • C#中怎么用websocket实现简易聊天功能
    本篇内容主要讲解“C#中怎么用websocket实现简易聊天功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#中怎么用websocket实现简易聊天功能”吧!前言使用C#语言进行开发,基于....
    99+
    2023-06-29
  • 怎么在Django中使用channels和websocket实现一个在线聊天室
    本篇文章为大家展示了怎么在Django中使用channels和websocket实现一个在线聊天室,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Channels是Django团队研发的一个给Djan...
    99+
    2023-06-15
  • 怎么在SpringBoot中利用WebSocket实现一个群聊功能
    本篇文章为大家展示了怎么在SpringBoot中利用WebSocket实现一个群聊功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。消息群发创建新项目:添加依赖:<dependency>...
    99+
    2023-06-06
  • 怎么在HTML5中实现实时语音通话聊天
    本篇文章为大家展示了怎么在HTML5中实现实时语音通话聊天,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。(1)数据传输github demo中考虑到减少对服务器的依赖,因此采用了WebRTC P2P...
    99+
    2023-06-09
  • 怎么在android中利用Socket实现一个聊天小程序
    本篇文章为大家展示了怎么在android中利用Socket实现一个聊天小程序,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。具体内容如下服务器端:package org.hwq.echo; impo...
    99+
    2023-05-31
    android socket roi
  • 怎么在HTML5中使用websocket实现直播功能
    这篇文章给大家介绍怎么在HTML5中使用websocket实现直播功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。录像页面HTML结构<video autoplay id="sou...
    99+
    2023-06-09
  • 怎么在Mac M1中利用Nginx实现多站点配置
    本篇文章为大家展示了怎么在Mac M1中利用Nginx实现多站点配置,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。第一步 : 设置 IP 与 域名 映射 (也就是增加 hosts)# 终端...
    99+
    2023-06-14
  • 怎么在HTML5中实现一个3D焦点图动画
    怎么在HTML5中实现一个3D焦点图动画?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。HTML代码<div class="dg-wrapper&quo...
    99+
    2023-06-09
  • 怎么在Java中使用Socket实现一个多人聊天室
    本篇文章给大家分享的是有关怎么在Java中使用Socket实现一个多人聊天室,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。流程首先建立一个服务器端,构建ServerSocket...
    99+
    2023-06-14
  • python中怎么利用numpy.dot实现点乘运算
    python中怎么利用numpy.dot实现点乘运算,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。说明对于两个一维数组,计算这两个数组对应下标元素的乘积和(数学...
    99+
    2023-06-20
  • Winform中怎么利用TreeView实现节点定位
    Winform中怎么利用TreeView实现节点定位,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Winform里面的TreeView节点定位是一种常见的、功能强大的控件,一般...
    99+
    2023-06-17
  • 怎么在Html5中实现百度地图的点击事件
    怎么在Html5中实现百度地图的点击事件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。根据百度地图官方解释,在移动端 H5 页面中可监听下面这 4 个事件:touchsta...
    99+
    2023-06-09
  • Android中的点击事件怎么利用Kotlin实现
    本篇文章为大家展示了Android中的点击事件怎么利用Kotlin实现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在android中,点击事件大致分为三种写法: 匿名内部类。 Activity实现...
    99+
    2023-05-31
    android kotlin roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作