访问位于“”的XMLHttpRequesthttp://localhost:8084/jia“from origin”null“已被CORS策略阻止:对飞行前请求的响应未通过访问控制检查:请求的资源上不存在”access control Allow origin“标头。
时间: 2023-09-04 16:09:58 浏览: 156
这个错误是由于浏览器的CORS(跨域资源共享)策略所导致的。CORS是一个安全机制,用于限制Web页面对不同域名下资源的访问。通常,当一个页面试图访问另一个域名下的资源时,浏览器会发出一个OPTIONS请求,以确定这个请求是否被允许,如果没有被允许,就会返回上述的错误信息。
解决这个问题的方法有以下几种:
1. 在服务器端添加Access-Control-Allow-Origin响应头,允许特定的域名访问资源。例如,在Java Web应用中,可以在web.xml文件中添加以下配置:
```
<filter>
<filter-name>CorsFilter</filter-name>
<filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
<init-param>
<param-name>cors.allowed.origins</param-name>
<param-value>*</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CorsFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
```
2. 在客户端使用代理服务器,将所有请求转发到同一个域名下。例如,在React应用中,可以使用http-proxy-middleware来实现:
```
const proxy = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',
proxy({
target: 'http://localhost:8080',
changeOrigin: true,
})
);
};
```
3. 在客户端使用JSONP(JSON with Padding)来获取数据。JSONP是一种跨域数据交互的技术,通过动态地创建script标签,将需要获取的数据包装在回调函数中返回。例如:
```
function jsonp(url, callback) {
const script = document.createElement('script');
script.src = url + '&callback=' + callback;
document.body.appendChild(script);
}
jsonp('http://localhost:8084/jia', function(data) {
console.log(data);
});
```
以上这些方法都可以解决CORS策略限制的问题,具体的选择可以根据实际情况而定。
阅读全文