空指针:HttpSession异常,SpringBoot集成WebSocket

异常可能性:

  • 404 : 请检查拦截器是否将请求拦截
  • WebSocket握手期间HttpSession为空

HttpSession为空

方法一 :

网上参考大量的文档,有说跟前端请求域名有关系的。 反正对我来说,没啥用无法连接。

需使用 localhost,不能使用127.0.01

复制代码
    var host = window.location.host;
    var url = "ws://"+host+"/chatRoom/null";

方法二 :可以解决

添加监听配置 ,采用spring boot自动装配的方式,创建一个Session。

因为我需要存入数据,所以对我而言,不太ok。

其他原因看:WebSocket获取httpSession空指针异常的解决办法https://blog.csdn.net/csu_passer/article/details/78536060

java 复制代码
@WebListener
public class RequestListener implements ServletRequestListener {

    @Override
    public void requestDestroyed(ServletRequestEvent servletRequestEvent) {
    }

    @Override
    public void requestInitialized(ServletRequestEvent servletRequestEvent) {
        ((HttpServletRequest)servletRequestEvent.getServletRequest()).getSession();
    }
}

虽然有Session了,还是连接不上!

方法三 :成功解决

灵感 : 方法2通过监听创建Session。监听最牛逼的不应该是拦截器或者过滤器。

可以从拦截器中获取到我需要的数据,在request里面配置,应该更好。从request中getSession,存点东西进去试试。

java 复制代码
@WebFilter(urlPatterns = "/*")
public class ArticleFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException{
        long start = System.currentTimeMillis();

        // 存入session
        System.out.println("存入session");
        ((HttpServletRequest) request).getSession().setAttribute("name", 123);

        // 封装请求信息存储到请求上下文
        chain.doFilter(request, response);
        long end = System.currentTimeMillis();
        System.out.println("请求耗时:" + (end - start) + "ms");
    }
}
相关推荐
薛定谔的悦5 小时前
MQTT通信协议业务层实现的完整开发流程
java·后端·mqtt·struts
enjoy嚣士6 小时前
springboot之Exel工具类
java·spring boot·后端·easyexcel·excel工具类
无限大66 小时前
职场逻辑03:3步搞定高效汇报,让领导看到你的价值
后端
盐水冰7 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
紫丁香7 小时前
AutoGen详解一
后端·python·flask
小涛不学习7 小时前
Spring Boot 详解(从入门到原理)
java·spring boot·后端
Victor3569 小时前
MongoDB(51)什么是分片?
后端
Victor3569 小时前
MongoDB(50)副本集中的角色有哪些?
后端
IT_陈寒10 小时前
JavaScript开发者必看:5个让你的代码性能翻倍的隐藏技巧
前端·人工智能·后端
shengjk110 小时前
大数据工程师必看:为什么你的 IN 查询在 Flink/Spark 上慢到离谱?
后端