我正在开发一个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>