Springboot Controller 获取httpSession对应的websocket Session

Controller类

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;


@Controller
@RequestMapping("/api/v0")
public class MenuController {

    @ResponseBody
    @PostMapping("/test")
    public ResponseEntity<Object> test(){

            ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
            if(requestAttributes != null){
                HttpServletResponse response = requestAttributes.getResponse();
                HttpServletRequest request = requestAttributes.getRequest();
                HttpSession httpSession = request.getSession();
                System.out.println("SessionId:"+httpSession.getId());
            }
        return new ResponseEntity<>(null, HttpStatus.OK);
    }

}

在使用VUE+Springboot开发过程中,出现了一个SessionId不同的问题,导致获取到的sessionId无法找到对应的websocket Session。

这时候需要前后端进行一些配置。

前端封装axios文件中,对axios进行配置
axios.js

axios.defaults.withCredentials = true;//allowCredentials配置为true表示携带cookies信息,此时同一页面的httpsession不会改变
后端Springboot跨域配置

Webconfiguration.java

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpRequest;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import javax.servlet.ServletRequest;

@Configuration
public class WebConfiguration implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry){
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowedMethods("GET","HEAD","POST","PUT","DELETE","OPTIONS")
                .allowCredentials(true)//与前端保持一致
                .maxAge(3600);
    }
}
response设置

Filter.java

import org.springframework.stereotype.Component;
import org.springframework.web.filter.OncePerRequestFilter;

import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;


@Component
public class Filter extends OncePerRequestFilter {
    @Override
    protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,
                                    FilterChain filterChain) throws ServletException, IOException {
        httpServletResponse.addHeader("X-Frame-Options", "DENY");
        httpServletResponse.addHeader("Cache-Control", "no-cache, no-store, must-revalidate, max-age=0");
        httpServletResponse.addHeader("Cache-Control", "no-cache=set-cookie");
        httpServletResponse.addHeader("Pragma", "no-cache");
        httpServletResponse.setHeader("Access-Control-Allow-Origin",httpServletRequest.getHeader("origin"));//allowCredentials配置为true时,不能配置为“*”
        httpServletResponse.setHeader("Access-Control-Allow-Credentials","true");
        httpServletResponse.setHeader("Access-Control-Allow-Methods","OPTIONS,GET,PUT,POST,DELETE");
        httpServletResponse.setHeader("Access-Control-Allow-Max-Age","3600");
        filterChain.doFilter(httpServletRequest, httpServletResponse);

    }
}
经验分享 程序员 微信小程序 职场和发展