要解决AjaxFileUpload跨域上传的问题,您需要在服务器端设置CORS(跨源资源共享)策略。以下是一些建议:
cors
包来简化CORS设置。首先,安装cors
包:npm install cors
然后,在您的服务器代码中引入并配置cors
:
const express = require('express');
const cors = require('cors');
const app = express();
app.use(cors()); // 启用所有CORS请求
// 或者
app.use(cors({ origin: 'http://example.com' })); // 仅允许来自example.com的CORS请求
// ...其他路由和中间件
.htaccess
文件中添加以下内容:Header set Access-Control-Allow-Origin "*"
Header set Access-Control-Allow-Methods "GET, POST, OPTIONS"
Header set Access-Control-Allow-Headers "Content-Type"
nginx.conf
文件中的location
块中添加以下内容:add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'Content-Type';
请注意,将Access-Control-Allow-Origin
设置为*
(允许所有来源)可能会导致安全隐患。因此,建议您仅允许来自您信任的域名的请求。
辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
推荐阅读: ajaxfileupload上传文件没反应