【发布时间】:2015-09-25 14:38:16
【问题描述】:
我编写了一个存在业务逻辑的 servlet。我将从调用我的 RESTful Web 服务方法的调用程序中获得一个令牌。有了这个令牌,我需要使用 serlvet 中编写的业务逻辑进行验证。我还映射了一个过滤器,它在点击 servlet 之前设置了一些标头值。
现在我想从 RESTful Web 服务方法中点击过滤器和 servlet。可以通过以下方式获取 ServletContext。
@上下文 私有 ServletContext servletContext;
但是如何获取HttpServletRequest、HttpServletResponse对象。因为,我需要在 HttpServletRequest 中设置 token 的属性。
请提出解决方案。
提前致谢。
编辑
我需要将令牌设置为授权标头。下面是代码。 web.xml
<filter>
<filter-name>HeaderFilter</filter-name>
<filter-class>com.controller.HeaderFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HeaderFilter</filter-name>
<url-pattern>/dummy</url-pattern>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
Rest Web 服务类
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
@Path("/service")
public class Service {
@Path("/val/{token}")
@GET
@Produces("application/xml")
public String setToken(@Context HttpServletRequest request, @Context HttpServletResponse response, @PathParam("token") String token) throws ServletException, IOException {
String value=token;
if(request==null){
System.out.println("Request null");
}
System.out.println("Token: " + value);
if(request!=null){
request.setAttribute("param", value);
request.getRequestDispatcher("/dummy").include(request, response);
}
return "<token>"+ "<value>"+value+" token value"+"</value>" + "</token>";
}
}
过滤器类
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest=(HttpServletRequest)request;
System.out.println("********Filter**********");
HttpServletResponse httpResponse=(HttpServletResponse)response;
if(request.getAttribute("param")!=null){
String token=request.getAttribute("param").toString();
System.out.println("Filter httpRequest: " + token);
Wrapper requestWrapper = new Wrapper(httpRequest);
requestWrapper.addHeader("Authorization", token);
chain.doFilter(requestWrapper, response);
}
}
Servlet 类
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
ServletContext ctx=getServletContext();
System.out.println("Inside Dummy Servlet");
System.out.println(request.getAttribute("param").toString());
System.out.println("Request Header: "+response.getHeader("Authorization").toString());
}
现在可以通过在 web.xml 中添加以下代码进行过滤来点击过滤器。
<filter-mapping>
<filter-name>HeaderFilter</filter-name>
<url-pattern>/dummy</url-pattern>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>REQUEST</dispatcher>
但是在Filter for Authorization中设置的值在servlet中调用时为null。我需要在HeaderFilter 的授权标头中设置令牌。我坚持这样做。
【问题讨论】:
-
与
ServletContext相同。使用@Context。
标签: java web-services rest servlets