这是我的web.xml
<filter>
<filter-name>pollingTest</filter-name>
<filter-class>
webapp.controller.core.servlet.PollingService
</filter-class>
<async-supported>true</async-supported>
</filter>
<filter-mapping>
<filter-name>pollingTest</filter-name>
<url-pattern>/app/poll</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>ASYNC</dispatcher>
</filter-mapping>
这是班级:
public class PollingService implements Filter {
Logger logger = LoggerFactory.getLogger(getClass());
@Override
public void destroy() {
logger.info("Destroy");
}
@Override
public void doFilter(ServletRequest req, ServletResponse res,
FilterChain chain) throws IOException, ServletException {
logger.info("Running");
req.startAsync(req, res);
this.doFilter(req, res, chain);
return;
}
@Override
public void init(FilterConfig arg0) throws ServletException {
logger.info("Init=");
}
}
我在glassfish和tomcat 7上运行它,得到例外:
java.lang.IllegalStateException: Request is within the scope of a filter or servlet that does not support asynchronous operations
at org.apache.catalina.connector.Request.startAsync(Request.java:3657)
at org.apache.catalina.connector.Request.startAsync(Request.java:3633)
at org.apache.catalina.connector.RequestFacade.startAsync(RequestFacade.java:1053)
at javax.servlet.ServletRequestWrapper.startAsync(ServletRequestWrapper.java:450)
谁可以帮我这个?非常感谢。
因为你的servlet和链中的任何其他过滤器必须在web.xml中有<async-supported>true</async-supported>
。
我有类似的问题,但就我而言,这还不够。如果使用标签Context和Valve(在tomcat7 - service.xml中),则必须在标记值中添加参数asyncSupported =“true”。然后它工作了。
<Context docBase="aaa" path="/aaa" reloadable="true" source="org.eclipse.jst.jee.server:aaa"><Valve className="cz.tomcatUtil.ForceUserValve" user="DZC0GRP" asyncSupported="true"/></Context>
你正在递归地调用this.doFilter(req, res, chain);
。
如果你想继续链,你必须调用chain.doFilter(httpRequest, httpResponse);
而不是this.doFilter(req, res, chain);
。
您可以像这样使用Annotation for Mapping Asynchronous Servlet
@WebServlet(urlPatterns = {"/yourServlet"}, **asyncSupported=true**)
public class YourServlet extends HttpServlet { }
彼得卡拉比诺维奇,你回答是不对的。从Servlet 3.0规范:
2.3.3.3异步处理 ... 从具有asyncSupported = true的servlet调度到asyncSupported设置为false的servlet是允许的。在这种情况下,当退出不支持异步的servlet的服务方法时,将提交响应...
我知道这是一篇旧帖子,但我想分享我的解决方案。我花了一个星期才找出原因,因为我试过几乎尝试了所有可能的解决方案。
对我来说,servlet url-pattern不正确。
<servlet-mapping>
<servlet-name>MyServlet</servlet-name>
<url-pattern>/pattern/</url-pattern> <---
</servlet-mapping>
希望它会有所帮助。