Open In App

Working With HTTP Headers in Spring MVC: A Guide to @RequestHeader and @ResponseHeader

HTTP headers are key-value pairs that are sent along with HTTP requests from clients and responses from servers. Spring MVC provides various ways to access and manipulate HTTP headers in controllers.

Below are some ways to access and manipulate HTTP headers:



@RequestHeader annotation

@RequestHeader annotation is used to bind a specific HTTP request header to a method parameter. The header value will be injected.

Syntax:

@RequestHeader(
value = "headerName",
required = true,
defaultValue = "",
)

Attributes

How to Retrieve Header Values From the HTTP Request

Use Cases For @RequestHeader in Controller Methods:

Example of @RequestHeader Annotation




//Demonstration of @RequestHeader annotation to read 
//all http header in Spring Boot application
@GetMapping("/student")
public User
getStudent(@RequestHeader("Authorization") String authToken,
           @RequestHeader("X-Student-Id") String studentId)
{
  
    // authentication logic
  
    return studentService.getStudentById(studentId);
}

The headers will be passed to the authToken and studentId parameters respectively. The method then validates the auth token and returns the student based on the studentId.



Note: To access multiple headers, you can use a Map, MultiValueMap, or HttpHeaders object as the parameter type.

@ResponseHeader annotation

Syntax:

@ResponseHeader(
name = "headerName",
description = "",
response = String.class,
responseContainer = ""
)

Attributes:

How to add/modify headers in the HTTP response:

Use cases for @ResponseHeader in controller methods:

Example of @ResponseHeader Annotation




//Demonstration of @ResponseHeader annotation
@ResponseHeader("Cache-Control: max-age=3600")
// Cache for 1 hour
public String getStudent()
{
     return "marks>=40";
}

@ResponseHeader annotation indicates that the “Cache-Control” header should be added to the response generated by the “getStudent” method. The response can be cached for up to one hour before needing to be refreshed, according to the “max-age=3600” directive.

Note: To add multiple headers, you can use a Map, MultiValueMap, or HttpHeaders object as the annotation argument.

Conclusion

In summary, @RequestHeader and @ResponseHeader provide an elegant way to work with HTTP headers in Spring MVC. They simplify access to request headers and enable convenient manipulation of response headers, contributing to well-structured and informative responses.


Article Tags :