JAX-RS开发(三):ajax访问REST服务时的跨域问题以及jsonp解决方案

同源策略是指:协议、主机和端口都相同。我们可以在本地机器上部署2个不同端口的tomcat,让一个tomcat下的应用通过ajax访问另一个tomcat下的rest服务,这样就存在跨域访问问题了。修改conf/server.xml下面的三处端口号:

<Server port="****" shutdown="SHUTDOWN">
    <Connector port="****" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <Connector port="****" protocol="AJP/1.3" redirectPort="8443" />

在上一篇博客的基础上,为了解决cxf跨域问题需要:

1.修改pom文件,增加providers

<dependency>
	<groupId>org.apache.cxf</groupId>
	<artifactId>cxf-rt-rs-extension-providers</artifactId>
	<version>${cxf.version}</version>
</dependency>

2.修改cxf-spring.xml配置jsonp拦截器

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:jaxrs="http://cxf.apache.org/jaxrs"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
	http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
	http://cxf.apache.org/jaxrs
	http://cxf.apache.org/schemas/jaxrs.xsd">

	<jaxrs:server address="/rest">
		<jaxrs:serviceBeans>
			<ref bean="nameServiceImpl"/>
		</jaxrs:serviceBeans>
		
		<!--jsonp-->
		<jaxrs:providers>
			<bean class="org.apache.cxf.jaxrs.provider.jsonp.JsonpPreStreamInterceptor"/>
		</jaxrs:providers>

		<jaxrs:inInterceptors>
			<bean class="org.apache.cxf.jaxrs.provider.jsonp.JsonpInInterceptor"/>
		</jaxrs:inInterceptors>
		<jaxrs:outInterceptors>
			<bean class="org.apache.cxf.jaxrs.provider.jsonp.JsonpPostStreamInterceptor"/>
		</jaxrs:outInterceptors>
	</jaxrs:server>
	
	
</beans>

3.在另一个tomcat下通过ajax访问

$.ajax({
	  type: 'get',
	  url: 'http://127.0.0.1:8080/aty-rest/rest/rest/welcome',
	  dataType: 'jsonp',
	  jsonp: '_jsonp',
	  jsonpCallback: 'callback',
	  success: function(data) {
		alert(JSON.stringify(data));
	  }
});


本文参考了 Web Service 那点事儿(4)—— 使用 CXF 开发REST服务 这篇很不错的入门文章。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值