2024年前端最新若依集成 WebSocket,2024年最新阿里电子面单

总结

前端资料汇总

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 框架原理真的深入某一部分具体的代码和实现方式时,要多注意到细节,不要只能写出一个框架。

  • 算法方面很薄弱的,最好多刷一刷,不然影响你的工资和成功率😯

  • 在投递简历之前,最好通过各种渠道找到公司内部的人,先提前了解业务,也可以帮助后期优秀 offer 的决策。

  • 要勇于说不,对于某些 offer 待遇不满意、业务不喜欢,应该相信自己,不要因为当下没有更好的 offer 而投降,一份工作短则一年长则 N 年,为了幸福生活要慎重选择!!!
    喜欢这篇文章文章的小伙伴们点赞+转发支持,你们的支持是我最大的动力!

  • 参考链接

由于若依模块划分的很清楚,建议将 WebSocket 配置代码放到 framework 模块中,

将 WebSocket 控制器的代码放到用到的模块中。

引入依赖

=======================================================================

xxx-framework 下的 pom.xml 中引入 websocket 的依赖:

org.springframework.boot

spring-boot-starter-websocket

创建 WebSocket 配置类,开启 WebSocket 支持

===================================================================================================

xxx-framework 下的 com.xxx.framework.config 包下添加该类:

package com.lrjas.framework.config;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

import org.springframework.web.socket.server.standard.ServerEndpointExporter;

/**

  • 开启WebSocket支持

*/

@Configuration

public class WebSocketConfig {

@Bean

public ServerEndpointExporter serverEndpointExporter() {

return new ServerEndpointExporter();

}

}

添加 WebSocketServer 类,创建 webSocket 端点

=======================================================================================================

package com.lrjas.framework.ws;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

import javax.websocket.*;

import javax.websocket.server.PathParam;

import javax.websocket.server.ServerEndpoint;

import java.io.IOException;

import java.util.concurrent.CopyOnWriteArraySet;

// @ServerEndpoint 声明并创建了webSocket端点, 并且指明了请求路径

// id 为客户端请求时携带的参数, 用于服务端区分客户端使用

@ServerEndpoint(“/WebSocketServer/{sid}”)

@Component

public class WebSocketServer {

// 日志对象

private static final Logger log = LoggerFactory.getLogger(WebSocketServer.class);

// 静态变量,用来记录当前在线连接数。应该把它设计成线程安全的。

private static int onlineCount = 0;

// concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。

private static CopyOnWriteArraySet webSocketSet = new CopyOnWriteArraySet<>();

// private static ConcurrentHashMap<String,WebSocketServer> websocketList = new ConcurrentHashMap<>();

// 与某个客户端的连接会话,需要通过它来给客户端发送数据

private Session session;

// 接收sid

private String sid = “”;

/*

  • 客户端创建连接时触发

  • */

@OnOpen

public void onOpen(Session session, @PathParam(“sid”) String sid) {

this.session = session;

webSocketSet.add(this); // 加入set中

addOnlineCount(); // 在线数加1

log.info(“有新窗口开始监听:” + sid + “, 当前在线人数为” + getOnlineCount());

this.sid = sid;

try {

sendMessage(“连接成功”);

} catch (IOException e) {

log.error(“websocket IO异常”);

}

}

/**

  • 客户端连接关闭时触发

**/

@OnClose

public void onClose() {

webSocketSet.remove(this); // 从set中删除

subOnlineCount(); // 在线数减1

log.info(“有一连接关闭!当前在线人数为” + getOnlineCount());

}

/**

  • 接收到客户端消息时触发

*/

@OnMessage

public void onMessage(String message, Session session) {

log.info(“收到来自窗口” + sid + “的信息:” + message);

// 群发消息

for (WebSocketServer item : webSocketSet) {

try {

item.sendMessage(message);

} catch (IOException e) {

e.printStackTrace();

}

}

}

/**

  • 连接发生异常时候触发

*/

@OnError

public void onError(Session session, Throwable error) {

log.error(“发生错误”);

error.printStackTrace();

}

/**

  • 实现服务器主动推送(向浏览器发消息)

*/

public void sendMessage(String message) throws IOException {

log.info(“服务器消息推送:”+message);

this.session.getBasicRemote().sendText(message);

}

/**

  • 发送消息到所有客户端

  • 指定sid则向指定客户端发消息

  • 不指定sid则向所有客户端发送消息

  • */

public static void sendInfo(String message, @PathParam(“sid”) String sid) throws IOException {

log.info(“推送消息到窗口” + sid + “,推送内容:” + message);

for (WebSocketServer item : webSocketSet) {

try {

// 这里可以设定只推送给这个sid的,为null则全部推送

if (sid == null) {

item.sendMessage(message);

} else if (item.sid.equals(sid)) {

item.sendMessage(message);

}

} catch (IOException e) {

continue;

}

}

}

public static synchronized int getOnlineCount() {

return onlineCount;

}

public static synchronized void addOnlineCount() {

WebSocketServer.onlineCount++;

}

public static synchronized void subOnlineCount() {

WebSocketServer.onlineCount–;

}

public static CopyOnWriteArraySet getWebSocketSet() {

return webSocketSet;

}

}

创建 controller,用于模拟服务端消息发送

============================================================================================

package com.lrjas.web.wms.controller;

import com.lrjas.common.core.controller.BaseController;

import com.lrjas.framework.ws.WebSocketServer;

import org.apache.shiro.authz.annotation.RequiresPermissions;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.PathVariable;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.ResponseBody;

import java.io.IOException;

import java.util.HashMap;

import java.util.Map;

@Controller

@RequestMapping(“/wms/websocket”)

public class WebSocketController extends BaseController

{

private String prefix = “wms/websocket”;

@RequiresPermissions(“wms:websocket:view”)

@GetMapping()

public String socket() {

return prefix + “/websocket”; // 页面的访问路径

}

@RequiresPermissions(“wms:websocket:edit”)

//推送数据接口

@ResponseBody

@RequestMapping(“/push/{cid}”)

public Map<String, Object> pushToWeb(@PathVariable String cid, String message) {

总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总

JavaScript

性能

linux

前端资料汇总

前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值