空指针: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");
    }
}
相关推荐
Penge6662 小时前
Go 接口编译期断言
后端
我是一颗柠檬2 小时前
【MySQL全面教学】MySQL面试高频考点汇总Day15(2026年)
数据库·后端·mysql·面试
拽着尾巴的鱼儿3 小时前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
Ceelog3 小时前
久坐党自救指南:屏幕前 8 小时,身体到底在经历什么
前端·后端
XS0301064 小时前
并发编程 六
java·后端
雪宫街道4 小时前
synchronized 锁的范围:对象锁、类锁与代码块锁
java·jvm·后端·面试
XS0301065 小时前
Spring Bean 作用域 & 生命周期
java·后端·spring
彦为君5 小时前
JavaSE-07-异常机制
java·开发语言·后端·python·spring
我是一颗柠檬6 小时前
【MySQL全面教学】MySQL性能优化实战Day13(2026年)
数据库·后端·sql·mysql·性能优化·database