如何判定API接口是否支持跨域访问

1.背景

同一个h5页面需要访问多个不同的域名下的地址

2.判定方式

方式一

在浏览器控制台执行如下代码:

var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://XXXX.XXX.com/api/order/query'); // 测试时改为自己的地址
xhr.send(null);
xhr.onload = function(e) {
    var xhr = e.target;
    console.log(xhr.responseText);
}

如果能正常拿到接口结果说明支持跨域,结果如下

如果返回如下结果,说明不支持跨域:

 

方式二

编写如下html文件,直接访问html,如果不能正常访问则不支持跨域

<html>
<script type="text/javascript">
var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://xxx.xxx.com/api/order/query'); // 换为自己的接口地址
xhr.send(null);
xhr.onload = function(e) {
    var xhr = e.target;
    console.log(xhr.responseText);
}
</script>
</html>

3.springboot的java接口如何实现跨域

增加如下代码

@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowCredentials(true)
                .allowedMethods("*")
                .allowedHeaders("Content-Type", "X-Requested-With", "accept,Origin", "Access-Control-Request-Method", "Access-Control-Request-Headers", "token")
        ;
    }
}

完美

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
跨域交互是指在浏览器中,通过JavaScript代码从一个域名下的网页向另一个域名下的网页发送请求。由于浏览器的安全机制,不同域名下的网页不能直接访问对方的资源,需要使用组合式API进行访问。 下面是一个使用组合式API访问后端接口完成跨域交互的示例代码: ``` // 创建一个XMLHttpRequest对象 var xhr = new XMLHttpRequest(); // 设置请求的方法和URL xhr.open('GET', 'http://example.com/api/data', true); // 设置响应的数据类型 xhr.responseType = 'json'; // 设置请求头信息 xhr.setRequestHeader('Content-Type', 'application/json'); // 发送请求 xhr.send(); // 监听请求的响应 xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 获取响应的数据 var data = xhr.response; // 处理响应的数据 console.log(data); } }; ``` 在这个示例代码中,首先创建了一个XMLHttpRequest对象,并设置了请求的方法和URL,然后设置了响应的数据类型和请求头信息,最后发送请求。 在监听请求的响应时,判断请求的状态是否为4(即请求完成),状态码是否为200(即请求成功),如果都满足,则说明请求成功,可以获取响应的数据并进行处理。 需要注意的是,由于浏览器的安全机制,使用组合式API进行跨域交互时,需要使用CORS(跨域资源共享)或JSONP(JSON with Padding)等技术来实现。在使用CORS时,需要在后端接口中设置响应头信息,允许指定的域名访问接口。而在使用JSONP时,需要在前端代码中使用一个回调函数来处理响应的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值