我正在尝试开发一个使用RESTEasy编写的RESTFul服务。当我尝试使用基于RESTEasy Roles的身份验证和基于HTTP标头的身份验证凭据限制服务访问时,由于以下原因,它没有取得成功。
标记的服务根据服务上定义的 @RolesAllowed 正确限制。但是,在访问尝试时,它会在后端抛出一个更通用的异常(" HTTP 403 Forbidden")。这违背了我的意愿,因为即使我在HTTP标头中传递了安全凭证,它也会引发相同的异常。
当我试图通过引入 ContainerRequestFilter 来解决这个问题时,它从未被调用过
任何人都可以帮助我,并指出出了什么问题。
这些是实施细节
服务类
<pre>
@Path("/user-service")
public class UserService {
@RolesAllowed("ADMIN")
@PUT
@Path("/users/{userName}")
public Response updateUser(@PathParam("userName") String userName, @Context Request req) {
// Do processing stuff here
return Response.status(200).build();
}
}
</pre><br>
SecurityIntercepter Class
<pre>
@Provider
@PreMatching
public class SecurityInterceptor implements javax.ws.rs.container.ContainerRequestFilter {
@Override
public void filter(ContainerRequestContext requestContext) {
System.out.println("<SecurityInterceptor> Invoking SecurityInterceptor filter");
ResourceMethodInvoker methodInvoker = (ResourceMethodInvoker) requestContext
.getProperty("org.jboss.resteasy.core.ResourceMethodInvoker");
Method method = methodInvoker.getMethod();
// Do process HTTP Header and authorized based on the auth Token
}
}
</pre>
的web.xml
<web-app>
<context-param>
<param-name>resteasy.resources</param-name>
<param-value>my.package.UserService</param-value>
</context-param>
<context-param>
<param-name>resteasy.role.based.security</param-name>
<param-value>true</param-value>
</context-param>
<listener>
<listener-class>
org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap
</listener-class>
</listener>
<servlet>
<servlet-name>resteasy-servlet</servlet-name>
<servlet-class>
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>resteasy-servlet</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>
答案 0 :(得分:2)
通过更改web.xml文件解决了问题
似乎我添加了一些不必要的语句,最终导致过滤器调用
请在下面找到正确的配置详细信息。
的web.xml
<web-app>
<context-param>
<param-name>resteasy.scan</param-name>
<param-value>true</param-value>
</context-param>
<servlet>
<servlet-name>resteasy-servlet</servlet-name>
<servlet-class>
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>resteasy-servlet</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>