前端开发项目,解决localhost 本地运行项目,请求后台接口数据跨域问题,使用nginx 解决。

前言

前端开发项目,解决localhost 本地运行项目,请求后台接口数据跨域问题,使用nginx 解决。

一、环境

电脑:macbook pro
安装工具:homebrew,没有,请先安装!

二、安装

1.nginx

打开终端
brew search nginx //查看软件是否存在,这里我已经安装好了。
brew install nginx //安装nginx
安装 brew install xxx
卸载 brew uninstall xxx
更新brew本身 brew update

在这里插入图片描述

brew info nginx //查看nginx 详细信息
在这里插入图片描述
Docroot默认为/usr/local/var/www
/usr/local/etc/nginx/nginx.conf 配置文件
默认端口 8080 ,可以更改。
nginx将在/usr/local/etc/nginx/servers/目录中加载所有文件。
open /usr/local/etc/nginx/ //打开nginx安装目录 ,找到nginx.conf 文件进行配置,也可以单独创建配置文件,放到 servers 文件夹下面,它会自动加载配置文件。
open /usr/local/Cellar/nginx //其实这个才是nginx被安装到的目录
一个以当前安装的nginx的版本号为名称的文件夹,这个就是我们安装的nginx根目录啦。进入1.12.2_1/bin 目录,会看到nginx的可执行启动文件。一个名字为html的文件夹,该目录指向的就是/usr/local/var/www目录,这个在上面我们查看的info信息中有提到(Dcroot)

在这里插入图片描述

2.nginx.conf配置文件


#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    #my_config
    #include myconf/*.conf;
	#设置根目录,就是项目所在目录
	root   /Users/zx.gehua/WebstormProjects/;

    server {
    	#侦听8877端口
        listen       8877;   
        #定义使用 localhost访问
        server_name  localhost;

        #charset koi8-r;
        #access_log  logs/host.access.log  main;
		#访问localhost:8877 ,显示欢迎nginx页面
        #location / {
        #    root   html;
        #    index  index.html index.htm;
        #}
        #配置本地项目访问
        # 你的项目实际电脑上位置就是:/Users/zx.gehua/WebstormProjects/01test/index.html
        # 访问地址为:http://localhost:8877/01test/index.html
        # 依照以上可以设置多个本地项目
		location /01test {
		# html 是根文件夹,修改成项目文件夹,这里我在server 外设置成 “/Users/zx.gehua/WebstormProjects/”
        #    root   html
            index  index.html index.htm;
        #}
        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
 
       #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
    #加载执行servers里面所有配置文件
    include servers/*;
}

修改后保存, 找到nginx 目录,重启
cd /usr/local/etc/nginx
nginx -s reload
出现 403页面怎么办?

在这里插入图片描述
根目录为html(即/usr/local/var/www),索引文件为index.html 和 index.htm 没有,可以手动创建。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>title</title>
</head>
<body>
    <div>
        <h1>nginx欢迎!!!</h1>
    </div>
</body>
</html>

3.跨域问题配置

listen 8877; #原为8080,避免冲突,更改为80
        server_name  localhost;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location / {
            proxy_pass   http://127.0.0.1:8877;        # 前端静态页面地址,端口为8877,可根据自己的项目情况修改
            proxy_redirect default;
            #设置主机头和客户端真实地址,以便服务器获取客户端真实IP
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;                
        }
        location /api {                            # 自定义nginx接口前缀
            rewrite  ^/api/(.*)$ /$1 break;        # 监听所有/apis前缀,是则转发后台api接口地址
            include  uwsgi_params;
            proxy_pass   http://10.191.222.53;        # 后台api接口地址
            #设置主机头和客户端真实地址,以便服务器获取客户端真实IP
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;                
        }
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
解决接口跨域问题,可以通过配置Nginx来实现。以下是一种常见的解决方案: 1. 打开Nginx配置文件,通常是位于 `/etc/nginx/nginx.conf` 或 `/etc/nginx/conf.d/default.conf`。 2. 在 `http` 块中添加以下内容: ``` http { ... # 允许跨域请求的域名 add_header Access-Control-Allow-Origin *; # 允许的请求方法 add_header Access-Control-Allow-Methods "GET, POST, OPTIONS, PUT, DELETE"; # 允许的请求头 add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept, Authorization"; # 允许携带凭证(如Cookie) add_header Access-Control-Allow-Credentials true; ... } ``` 3. 如果需要处理预检请求(OPTIONS),可以添加以下配置: ``` server { ... # 处理预检请求 if ($request_method = 'OPTIONS') { add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods "GET, POST, OPTIONS, PUT, DELETE"; add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept, Authorization"; add_header Access-Control-Allow-Credentials true; add_header Content-Length 0; add_header Content-Type text/plain; return 204; } ... } ``` 4. 保存配置文件并重新加载Nginx。 这样配置后,Nginx会在响应头中添加相应的CORS(跨域资源共享)相关字段,从而解决接口跨域问题。请注意,此配置将允许所有域进行跨域请求。如需限制只允许特定域名访问,可以将 `Access-Control-Allow-Origin` 的值设置为相应的域名。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胖鹅儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值