当前位置: 首页 > 工具软件 > java-requests > 使用案例 >

java获取response与request

程瑞
2023-12-01

java获取response与request

方式一
监听

web.xml

<listener>
      <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
</listener>

java类

HttpServletRequest request = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getRequest();

HttpServletResponse response = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getResponse();

HttpServletResponse response = ((ServletWebRequest)RequestContextHolder.getRequestAttributes()).getResponse();

ServletContext context = ContextLoader.getCurrentWebApplicationContext().getServletContext();

以上方式获取response编译通过,运行报错。
请求响应—若不是通过页面得到的请求不需要返回到页面,
方式二:
定时触发的接口,可以参考

@RestController
public class DemoController {
    @Autowired
    private HttpServletRequest request;
    @Autowired
    private HttpServletResponse response;
 
    @GetMapping("/test")
    public ResponseResult test() {
        Object userId = request.getAttribute("userId");
        ...
    }
}
 

  1. 啥时候注入的?

答:SpringMVC DispatcherServlet 每次处理 HTTP 请求时,会将 web 容器封装的 request 和 response 注入到 Spring 容器中。

  1. 这样在并发情况下会不会有问题?

答:不会有问题。内部其实存在一个 ThreadLocal ,不同进程的 request 和 response 是隔离的。

  1. 那我们以后是不是可以都这样写了?

答:理论上且实际上这样写都没有问题,但是一般认为接口形参上的 request 和 response 对应着一次 HTTP 请求,因此用注入的方式会让人感觉有点奇怪。

为什么注入的没有线程安全问题?

从ThreadLocal 中取出来的,这也就说明它是线程隔离的,因此通过注入方式得到的 request 和 response 是线程安全的。

参考:注入是否可行, Spring 容器中的 Bean 默认是单例的

https://blog.csdn.net/yuanlaijike/article/details/89930553

 类似资料: