SpringBoot+Nginx前后端分离项目部分配置总结

一. 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.来替换请求地址,达到访问静态资源的目的,并且不会影响到前端的静态资源访问。

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

搭建Spring Boot和Vue前后端分离项目需要以下步骤: 1. 安装环境:首先,需要安装Java JDK和Maven来支持Spring Boot的开发。可以去官方网站下载并安装。然后,安装Node.js和Vue CLI来支持Vue的开发。 2. 创建Spring Boot项目:使用Maven创建一个Spring Boot项目,可以使用宝塔面板自带的Maven插件进行构建,也可以通过命令行进入项目目录,运行`mvn clean install`来创建项目。 3. 编写后端代码:在Spring Boot项目中编写后端逻辑,包括接口的实现、数据库的操作等。可以选择使用Spring Data JPA来简化对数据库的操作。 4. 创建Vue项目:使用Vue CLI创建一个Vue项目,可以通过宝塔面板自带的Node.js插件进行创建,也可以通过命令行运行`vue create 项目名`来创建。 5. 编写前端代码:在Vue项目中编写前端逻辑,包括页面的布局、调用后台接口等。可以使用axios库来发送HTTP请求。 6. 配置跨域:由于前后端分离项目可能存在不同端口的情况,需要进行跨域配置。可以在Spring Boot项目配置文件中添加`@CrossOrigin`注解,允许指定的域访问接口。 7. 打包部署:完成开发后,可以使用Maven将后端项目打包成一个独立的Jar文件。然后,将打包好的Jar文件上传到宝塔面板上的对应目录。将Vue项目使用`npm run build`命令打包成静态文件,然后将打包好的文件上传到宝塔面板对应的目录。 8. 配置Nginx反向代理:为了将前后端项目结合在一起,可以使用Nginx配置反向代理,将前端的请求转发给后端的接口。在宝塔面板上找到对应的站点,进行Nginx配置。 通过以上步骤,就可以搭建一个基于Spring Boot和Vue的前后端分离项目,并将项目部署到宝塔面板上进行访问和使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值