我正在开发一个HTML5应用程序,它必须从遗留Web服务(Jax-Ws)获取一些值,所以我使用
jQuery.soap来查询这些Web服务以获取响应.我已经使用SOAP UI尝试了我的请求的正确性,并且它们正常工作.
从我的HTML5客户端,我无法从服务器接收SOAP响应,因为在响应中没有将Allow-Control-Allow-Origin标头设置为*.因此,请求的来源被识别为不允许,并且服务器的响应是错误响应.
使用Firebug Firefox调试我的HTML5项目的错误消息是:
锁定的跨源请求:原点处的标准不允许读取远程资源.您可以通过将资源移动到同一域或激活CORS来解决问题.
如何在jBoss中启用CORS?
解决方法
您需要处理遗留的Web服务以解决问题.正如上面提到的mccannf所说,你需要在web.xml中添加CORS过滤器.
您可以使用来自交易公司的解决方案:
web.xml中:
<filter> <filter-name>CORS</filter-name> <filter-class>com.thetransactioncompany.cors.CORSFilter</filter-class> </filter> <filter-mapping> <filter-name>CORS</filter-name> <url-pattern>*</url-pattern> </filter-mapping>
行家:
<dependency> <groupId>com.thetransactioncompany</groupId> <artifactId>cors-filter</artifactId> <version>2.5</version> </dependency>
如果你使用apache Tomcat,你可以使用内置的CorsFilter:
web.xml中:
<filter> <filter-name>CorsFilter</filter-name> <filter-class>org.apache.catalina.filters.CorsFilter</filter-class> </filter> <filter-mapping> <filter-name>CorsFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
pom.xml中:
<dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-catalina</artifactId> <version>7.0.42</version> <scope>provided</scope> </dependency>