一. Nginx如何配置访问Java的Api服务?

location /api/ {
			rewrite  ^/api/(.*)$ /$1 break;
			proxy_pass   http://127.0.0.1:8089;
			proxy_set_header Host $host;
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			
			proxy_http_version 1.1; 
			proxy_set_header Upgrade $http_upgrade;  
			proxy_set_header Connection "Upgrade"; 
    }

        我们的Api服务和Nginx放在同一台服务器上了,我们可以在Nginx中配置我们的Api请求地址:域名+/api/+接口路径,这样就可以通过域名访问到我们的Java服务程序。配置多个地址同理,上面的代码中 proxy_pass 放的是我们的Api服务的服务器端口地址。

二.Nginx配置微信授权的Mpxxxxx.txt文本文件

location /MP_verify_xxxxxxxx.txt {
      root /xxx/xx/xxxx; #服务器中MP.txt的存放目录
 }

        H5在做微信授权的时候,需要配置一个MP.txt的授权文件,可以按照上面的代码配置,放在服务器的某个文件夹下。然后请求的地址为:域名 + /MP_verify_xxxxxxxx.txt,可以直接访问到文件地址,完成微信授权。

三.Nginx配置微信头像,解决微信头像和我们项目的域名跨域问题

location ^~ /xxx/wechat_image/ {
      add_header 'Access-Control-Allow-Origin' "$http_origin" always;
      add_header 'Access-Control-Allow-Credentials' 'true' always;
      add_header 'Access-Control-Allow-Methods' 'GET, OPTIONS' always;
      add_header 'Access-Control-Allow-Headers' 'Accept,Authorization,Cache-              Control,Content-Type,DNT,If-Mod ified- Since,Keep-Alive,Origin,User-Agent,X-Requested-With' always;
      proxy_pass http://thirdwx.qlogo.cn/;
    }

        当我们在完成微信授权的时候,可以获取到微信的微信头像信息,但是微信头像是微信自己的域名地址,上面代码 proxy_pass http://thirdwx.qlogo.cn/,这个时候如果我们在自己项目的域名下访问,会出现跨域问题,我们可以直接使用Nginx的最重要一个功能——反向代理,来解决跨域问题你。

        反向代理,这里可以理解成,我们让Nginx帮我们去转发一下需要请求的地址。例如:我想要张三一张照片,我就告诉Nginx,,如果张三来找我,你让他把照片给我。换成程序就是请求路径中出现/xxx/wechat_image,我们的Nginx匹配中了,就把我们的域名,换成他们的域名,然后把东西获取到。

四.Nginx的匹配请求路径规则

  1. ~      # 波浪线表示执行一个正则匹配,区分大小写
  2. ~*    # 表示执行一个正则匹配,不区分大小写
  3. ^~    # ^~表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配别的选项,一般用来匹配目录
  4. =      # 进行普通字符精确匹配
  5. @     # "@" 定义一个命名的 location,使用在内部定向时,例如 error_page, try_files

        这里我们根据匹配规则可以看出,上面的反向代理,使用的是 ^~,他的意思是:只匹配该选项,不匹配别的选项,我们用来匹配URL的请求路径,匹配中了,就开始替换请求域名,将我们的域名替代代理成其他的域名地址。根据这个我们可以实现很多地址目录的匹配

五.Nginx匹配规则实践

location ^~ /profile/upload {
       proxy_pass   http://127.0.0.1:8089; #Java项目端口地址
    }

        当我们搞了一个前后端分离项目,而这个时候,我们的Java项目又有一个上传图片的功能,并且这个上传的图片都是在服务器当中,我们需要访问到这些图片资源,该如何操作呢?

        通常,我们的SpringBoot项目配置了一个WebConfig放行一个图片地址,我们的访问地址就是:IP+端口+路径地址+图片.jpg。可是我们的访问是通过Nginx来访问的,我们的Java项目,只是在服务器上,我们想通过Nginx上的前端项目,来访问到图片,这个时候前端是有自己的静态资源的,我们没办法直接在匹配规则中直接配置IP地址。

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
 {
  		# proxy_pass   http://127.0.0.1:8089; #这里直接配置我们的Java项目地址后,前端的项目,就没有办法访问到,前端的静态资源了
        expires      30d;
        error_log /dev/null;
        access_log /dev/null;
 }

        如果我们按照上面直接配置我们的Java项目地址后,虽然我们Java项目可以获取到了静态紫玉了,但是前端的项目,就没有办法访问到前端的静态资源了。所以我们就要去匹配请求规则了,例如:请求路径 =  域名+/profile/upload/xxx.jpg,我们在Nginx就可以配置上面的规则,去匹配/profile/upload.来替换请求地址,达到访问静态资源的目的,并且不会影响到前端的静态资源访问。

至此:部分经验配置结束,如有错误,请大家留言交流。