Spring MVC如何設(shè)置請求頭和響應(yīng)頭的Header
在Spring MVC中,動態(tài)設(shè)置請求頭和響應(yīng)頭的方法有多種,以下是一些常見的方式:
設(shè)置請求頭
使用@RequestHeader注解
這個注解用于讀取請求中的單個HTTP頭部值,并將其作為一個參數(shù)傳遞給控制器方法。
@RequestMapping("/example") public String handleRequest(@RequestHeader(name = "X-Custom-Header", required = false) String customHeaderValue) { // 使用customHeaderValue... return "viewName"; }
使用ControllerAdvice
通過ControllerAdvice類,你可以全局地添加響應(yīng)頭。
@ControllerAdvice public class GlobalHeaderControllerAdvice { @AfterResponseBodyAdvice public void addGlobalHeader(@RequestHeader HttpHeaders headers) { headers.set("X-Global-Response-Header", "GlobalValue"); } }
使用@RequestMapping注解的headers屬性
對于@RequestMapping及其派生注解(如@GetMapping、@PostMapping等),可以使用headers屬性來指定請求的約束條件,這可以用來模擬請求頭的效果。
@RequestMapping(value = "/example", method = RequestMethod.GET, headers = "X-Custom-Header=someValue") public String conditionalRequestMapping() { // 方法實現(xiàn)... }
使用HttpServletRequest
通過注入HttpServletRequest
對象,可以讀取和修改請求頭(通常用于讀取,因為HTTP請求頭在請求到達servlet時已經(jīng)設(shè)置好了,不能修改)。
@RequestMapping("/example") public String handleRequest(HttpServletRequest request) { String customValue = request.getHeader("X-Custom-Header"); // 使用customValue... return "viewName"; }
使用ClientHttpRequestInterceptor
實現(xiàn)ClientHttpRequestInterceptor
接口,可以在請求發(fā)送前動態(tài)添加或修改請求頭。
public class CustomRequestHeaderInterceptor implements ClientHttpRequestInterceptor { @Override public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException { request.getHeaders().set("X-Custom-Request-Header", "DynamicValue"); return execution.execute(request, body); } }
使用Filter
通常,HTTP請求頭是在客戶端發(fā)送請求時設(shè)置的,一旦請求被發(fā)送到服務(wù)器,請求頭就不能再被修改。Filter可以讀取和修改HttpServletRequest對象,但它不能修改已經(jīng)接收到的請求頭,因為HTTP協(xié)議本身不支持修改請求頭。
如果你需要在服務(wù)器端“偽造”或“添加”請求頭,這通常是通過在Filter中設(shè)置屬性到HttpServletRequest中實現(xiàn)的,但這些屬性不會成為HTTP請求頭的一部分,它們僅可以被下游的Servlet或控制器方法所使用。
public class CustomRequestHeaderFilter implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest = (HttpServletRequest) request; httpRequest.setAttribute("X-Custom-Header", "HeaderValue"); chain.doFilter(request, response); } }
使用RestTemplate自定義請求
如果你在控制器中使用RestTemplate
發(fā)起請求,可以在請求頭中動態(tài)設(shè)置值。
HttpHeaders headers = new HttpHeaders(); headers.set("X-Custom-Request-Header", dynamicHeaderValue); HttpEntity<String> entity = new HttpEntity<>("Request Body", headers); restTemplate.exchange(...);
設(shè)置響應(yīng)頭
使用@ResponseHeader注解
在控制器類或方法上使用@ResponseHeader
注解直接添加響應(yīng)頭。
@Controller @ResponseHeader("X-Custom-Response-Header: DynamicValue") public class ExampleController { // 控制器方法... }
使用HttpServletResponse
通過注入HttpServletResponse
對象,在控制器方法中調(diào)用setHeader
或addHeader
方法來設(shè)置響應(yīng)頭。
@RequestMapping("/example") public String handleRequest(HttpServletResponse response) { response.setHeader("X-Custom-Response-Header", "DynamicValue"); return "viewName"; }
使用ResponseEntity對象
返回一個ResponseEntity
對象,允許你設(shè)置狀態(tài)碼、頭部和響應(yīng)體。
@RequestMapping("/example") public ResponseEntity<String> handleRequest() { HttpHeaders headers = new HttpHeaders(); headers.set("X-Custom-Response-Header", "DynamicValue"); return new ResponseEntity<>("Response Body", headers, HttpStatus.OK); }
使用HandlerInterceptor
實現(xiàn)HandlerInterceptor
接口,可以在請求處理后動態(tài)添加響應(yīng)頭。
public class CustomResponseHeaderInterceptor implements HandlerInterceptor { @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { response.setHeader("X-Custom-Response-Header", "DynamicValue"); } }
使用Filter
創(chuàng)建一個過濾器,在請求處理之后動態(tài)設(shè)置響應(yīng)頭。
public class CustomHeaderFilter implements Filter { @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { filterChain.doFilter(servletRequest, servletResponse); HttpServletResponse response = (HttpServletResponse) servletResponse; response.setHeader("X-Custom-Response-Header", "DynamicValue"); } }
使用RestClient響應(yīng)式調(diào)用
如果你使用響應(yīng)式編程,可以在調(diào)用外部服務(wù)時動態(tài)設(shè)置響應(yīng)頭。
public Mono<ResponseEntity<String>> callExternalService(Data data) { return webClient.post() .uri("/example") .header("X-Custom-Response-Header", dynamicHeaderValue) .retrieve() .bodyToMono(String.class); }
說明
這些方法可以根據(jù)你的具體需求和場景靈活使用,例如是否需要在請求處理的特定階段添加頭部,或者是否需要全局地添加頭部。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot整合mybatis中的問題及出現(xiàn)的一些問題小結(jié)
這篇文章主要介紹了springboot整合mybatis中的問題及出現(xiàn)的一些問題小結(jié),本文給出了解決方案,需要的朋友可以參考下2018-11-11詳談@Cacheable不起作用的原因:bean未序列化問題
這篇文章主要介紹了@Cacheable不起作用的原因:bean未序列化問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01