当前位置: 首页 > news >正文

武汉 开发 公司 网站建设网站seo报价

武汉 开发 公司 网站建设,网站seo报价,国外网络推广公司,龙岩天宫山索道多少钱前言 此前已经编写了一版后端的im,此次就用其作为服务端,可查看参考资料1 代码 使用WebStorm创建React项目 安装依赖包 PS C:\learn-demo\front\chatroom> npm installadded 183 packages, and audited 184 packages in 16s43 packages are looki…

前言

此前已经编写了一版后端的im,此次就用其作为服务端,可查看参考资料1

代码

使用WebStorm创建React项目

安装依赖包

PS C:\learn-demo\front\chatroom> npm installadded 183 packages, and audited 184 packages in 16s43 packages are looking for fundingrun `npm fund` for detailsfound 0 vulnerabilities

创建ChatRoom.tsx

import React, { useState, ChangeEvent } from 'react';const ChatRoom: React.FC = () => {const [message, setMessage] = useState('');const [messages, setMessages] = useState<string[]>([]);const [socket, setSocket] = useState<WebSocket | null>(null);const [userName, setUserName] = useState('');const handleSendMessage = () => {if (socket && message) {socket.send(message);setMessage('');}};const handleConnected = () => {if (userName) {setUserName(userName);createWebSocket(userName);}};const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {setMessage(event.target.value);};const handleInputName = (event: ChangeEvent<HTMLInputElement>) => {setUserName(event.target.value);};const createWebSocket = (userName: string) => {setMessages(prevMessages => [...prevMessages, `welcome 【${userName}】`])if (userName){setUserName(userName);}else {return;}//关闭已有websocket连接if (socket){socket.close()}const newSocket = new WebSocket(`ws://localhost:18080/ws?userName=${userName}`);newSocket.onopen = () => {console.log('Connected to the WebSocket server');};newSocket.onmessage = (event: MessageEvent) => {setMessages(prevMessages => [...prevMessages, event.data]);};newSocket.onclose = () => {console.log('Disconnected from the WebSocket server');};setSocket(newSocket);}return (<div><ul>{messages.map((msg, index) => (<li key={index}>{msg}</li>))}</ul><inputtype="text"value={userName}onChange={handleInputName}/><button onClick={handleConnected}>Connected</button><br/><inputtype="text"value={message}onChange={handleInputChange}/><button onClick={handleSendMessage}>Send</button></div>);
};export default ChatRoom;

修改main.tsx

import { StrictMode } from 'react'
import { createRoot } from 'react-dom/client'
import './index.css'
import ChatRoom from "./component/ChatRoom.tsx";createRoot(document.getElementById('root')!).render(<StrictMode><ChatRoom /></StrictMode>,
)

测试

  • 运行项目,打开三个http://localhost:5173/的页面

分别以不同用户名(test1、test2、test3)连接websocket,步骤是第一行输入框输入用户名,然后点击Connected按钮

  • test1发送全体消息

第二行输入框输入消息,点击Send按钮

test2、test3均收到消息

  • test1发送消息给test2

test2收到消息

test3未收到消息

调整后端代码

上述消息分不清到底是谁发给用户的,调整下im服务的代码

SendExecutorFactory

public void onMessage(String sendUserName, String message) {IBaseSendExecutor iBaseSendExecutor = Optional.ofNullable(executorConfiguration.getBaseSendExecutorMap().get(webSocketProperties.getCommunicationType())).orElse(new DefaultSendExecutor());message = String.format("【%s】: %s", sendUserName, message);//包含@发给指定人,否则发给全部人if (StringUtils.contains(message, webSocketProperties.getReceiverSeparator())) {iBaseSendExecutor.sendToUser(sendUserName, message);} else {iBaseSendExecutor.sendToAll(sendUserName, message);}
}

重新启动服务端,发送消息

页面上重新连接,test1发送全体消息

test2、test3均收到test1的消息

参考资料

[1].im后端代码

[2].chatroom前端项目

http://www.ds6.com.cn/news/111407.html

相关文章:

  • 西安制作网站公司关键词优化价格
  • 政府网站建设合同.doc网店运营推广平台
  • 网站模版更新公告今日十大头条新闻
  • 武汉做网站选华企加速器重庆网站推广软件
  • 建设论坛网站创建网站的流程
  • 网站图片水印东营优化路网
  • 网站排名数据武汉百度推广公司
  • wordpress短信宝天津seo外包平台
  • 遵义做网站的百度搜索页
  • 做设计的有什么网站知识搜索引擎
  • 政府门户网站建设任务百度贴吧网页入口
  • tk网站免费上海网站seo外包
  • 如何建设一个社交网站奖券世界推广网站
  • 网站建设价格热线网站建设费用多少钱
  • 武汉网站建设网站推广花西子网络营销案例分析
  • 鼠标放上去图片放大的网站全国各城市感染高峰进度查询
  • 优质网站建设报价优化方案官网
  • 商家网站建设模板淘宝客推广平台
  • 静态网站分页网推公司干什么的
  • 网站制作公司扬州百度seo
  • 工程师报考网站谷歌网站
  • 无聊网站建设seo网络培训学校
  • 怎样免费推广自己的网站青岛做网站的公司哪家好
  • 网站编辑工作免费域名注册查询
  • 北京建设工程二级市场网站淘数据官网
  • 做网站首页图片素材五种营销工具
  • 专业的营销网站seo建设者
  • 做学校的网站推广发展前景免费打广告平台有哪些
  • 个体工商户做网站能加地名吗阻断艾滋病的药有哪些
  • ps做网站图片水印天眼查企业查询入口