I'm modifying aHttpRequest
on my WebFilter
by adding a single header to request
using a HttpServletRequestWrapper
implementation class:
HeaderMapRequestWrapper requestWrapper = new HeaderMapRequestWrapper(request);
requestWrapper.addHeader(OAuth.OAUTH_ACCESS_TOKEN, accessTokenWord);
chain.doFilter(requestWrapper, response);
After doFilter(requestWrapper, response)
is performed, JAX-RS leads request to its resource, which has a @RequestScoped
field:
@Inject
protected HttpServletRequest request;
However, it doesn't contain any expected header:
@PostConstruct
protected void initialize_resources() throws IllegalStateException {
this.currentUser = null;
String accessToken = this.request.getHeader(OAuth.OAUTH_ACCESS_TOKEN);
AccessToken accessToken = this.memcachedResources.getMemcachedAccessTokenRepository()
.get(accessToken);
if (accessToken != null && StringUtils.isNotEmpty(accessToken.getUser_id())) {
this.currentUser = this.em.find(User.class, accessToken.getUser_id());
this.currentClient = accessToken.getClientId();
}
}
So, this.request.getHeader(OAuth.OAUTH_ACCESS_TOKEN)
is null
.
How can I solve that?