让Apache 和nginx支持跨域访问

本文介绍如何配置Apache及Nginx服务器以支持跨域访问。对于Apache,需修改httpd.conf文件并启用headers模块;对于Nginx,则需在html目录下创建crossdomain.xml文件,并在配置文件中添加相关头信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,如何让Apache支持跨域访问呢?
步骤:

  1. 修改httpd.conf,windows中对应的目录是:C:\wamp\bin\apache\Apache2.4.4\conf\httpd.conf
  2. 把LoadModule headers_module modules/mod_headers.so 前面的注释删除
  3. 修改
    这里写图片描述
    改为:
    这里写图片描述
    即:
<Directory />
    AllowOverride none
    Require all granted
    Header set Access-Control-Allow-Origin *
</Directory>

如果使用图形界面来开启headers_module模块要注意步骤的顺序
(1) 首先使用图形界面开启headers_module模块功能;
(2) 然后在修改httpd.conf配置文件,增加Header set Access-Control-Allow-Origin *
顺序错了就启动不了httpd服务

2,如何使Nginx支持跨域呢?
1,进入nginx的html目录
vim ./crossdomain.xml
具体路径: /usr/local/nginx/html/crossdomain.xml
2,在crossdomain.xml中添加:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
<cross-domain-policy>
<allow-access-from domain="*" />
</cross-domain-policy>

结果就是:
这里写图片描述

注意:默认/usr/local/nginx/html/crossdomain.xml 是不存在的.

nginx做请求转发

修改:/usr/local/etc/nginx/vhosts/xx.com.conf

server {
        listen 80;
        server_name xxx.com  10.1.146.81;

        location / {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' '*';
        proxy_pass http://localhost:8088;
        # proxy_redirect off ;

        index index.php index.html index.htm;
        }
# error_page 500 502 503 504 /50x.html;


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值