Rainbond 中Vue、React项目如何调用后端接口

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: 本文介绍Vue、React等前端项目在Rainbond中如何实现对后端API的调用。

前言

以往我们在部署前端项目后,调用后端接口有以下几种场景:

  1. 后端接口没有统一,比较分散,例如:/system/user,/tool/gen

    通常我们会在项目的全局配置文件 .env.production中直接写入后端ip,例如:

    ENV = 'production'
    VUE_APP_BASE_API = '192.168.6.66:8080'

    这样写虽可以正常访问,但会导致产生跨域问题

  2. 后端接口统一,例如:/api/system/user, /api/tool/gen

    大部分小伙伴也还是同样会直接把IP + 后缀写入到项目全局配置文件,例如:

    ENV = 'production'
    VUE_APP_BASE_API = '192.168.6.66:8080/api'

    这样写当然了也会有跨域的问题。

那我们该怎么解决接口不统一或接口统一的跨域问题呢。

​ 答:使用Nginx 反向代理

​ 大部分小伙伴用nginx都是项目打包完的dist包丢进nginx,配置个 location proxy_pass 反向代理后端,然后在项目全局配置里填写Nginx地址。酱紫还是会跨越哦😋。那究竟该怎么处理呢,请往下看👇

解决跨域对于不同的场景有以下几种方法:

接口没有统一

  1. 接口数量较少的话,比如只有几个接口system tool moitor login getmenu等。

    首先需要修改全局配置文件.env.production 的请求api 为/,酱紫写前端发起请求的时候会直接转发到nginx。

    ENV = 'production'
    VUE_APP_BASE_API = '/'

    其次修改Nginx配置文件,添加多个location,在浏览器请求的时候就会匹配到nginx的location规则,例如:

    ​ 浏览器请求菜单:http://192.168.6.66/getmenu,会匹配 location /getmenu规则反向代理到后端。

    server {
          listen       5000;
              #静态页面
          location / {
              root   /app/www;
              try_files $uri $uri/ /index.html;
              index  index.html index.htm;
          }
          
          location /getmenu{
              proxy_pass http://127.0.0.1:8080/;
          }
      }

    这种方式固然可以,但对于接口几十个上百个 一一配置很麻烦。

  2. 接口数量很多。

    同样首先也需要修改全局配置文件.env.production,修改请求接口为 api,这个接口自定义的。有的小伙伴就疑问了,我没有这个接口呀,请接着往下看。

    ENV = 'production'
    VUE_APP_BASE_API = '/api'

    紧接着修改Nginx配置文件,在nginx配置文件中添加了location /api,并且添加了 rewriteproxy_pass,这个 rewrite是URL重写。

    例如:请求 http://192.168.6.66/api/system/menu,酱紫请求正常情况发送到后端,后端会报错是没有这个接口的。

    我们通过rewrite 重写URL,此时URL就会变成http://192.168.6.66/system/menu并且通过proxy_pass反向代理到后端,此时发送接口请求/system/menu,后端正常返回。

    server {
        listen       5000;
    
        location / {
            root   /app/www;
            try_files $uri $uri/ /index.html;
            index  index.html index.htm;
        }
    
        location  /api {
            rewrite ^/api/(.*)$ /$1 break;
            proxy_pass http://192.168.2.182:8080;
        }
    }

    rewrite ^/api/(.*)$ /$1 break具体可参考Nginx官方文档rewrite_module模块,在这里简单介绍下:

    ​ rewrite ^/api/(.*)$ /$1 break

    ​ 关键字 正则 替代内容 flag标记

接口统一

对于这种就比较好处理了。

同样首先也是修改项目的全局配置文件.env.production,修改请求接口为 /prod-api。这个统一接口是后端提供的哈。

ENV = 'production'
VUE_APP_BASE_API = '/prod-api'

修改Nginx配置文件,增加一条location,反向代理到后端地址。

此时在浏览器请求的URL则为:http://192.168.6.66/prod-api/system/menu

server {
    listen       5000;

    location / {
        root   /app/www;
        try_files $uri $uri/ /index.html;
        index  index.html index.htm;
    }

    location  /prod-api {
        proxy_pass http://192.168.2.182:8080;
    }
}

跨域问题解决了,那我们开始实践一次😁。

本次前端的配置就是上面说的接口统一的方式

接下来部署一个SpringBoot后端项目来配合前端一起使用。

源码部署后端

  • 本项目源码地址https://gitee.com/zhangbigqi/RuoYi-Vue.git Fork开源项目 若依
  • 后端是SpringBoot + Mysql + Redis 架构。

Dockerfile源码构建部署Mysql

  1. 通过Dockerfile源码构建部署Mysql。

    ​ Dockerfile源码构建需要在项目所需Sql目录放置Dockerfile文件自动初始化数据库。

    ​ Dockerfile文件可参考https://gitee.com/zhangbigqi/RuoYi-Vue.git 此项目下的 sql 目录

  2. 填写源码仓库地址,填写Mysql子目录 sql,构建Mysql。
  3. 确认创建组件,平台会自动识别语言为 dockerfile
  4. 创建,等待构建组件完成即可。
  5. 构建完成后,在组件 > 端口中打开对内服务并且修改 别名,点击即可修改,改为MYSQL_HOST,以供后端连接时使用。

Docker镜像部署Redis

  1. 通过 docker镜像部署redis
  2. 使用 redis 官方镜像,redis:latest
  3. 确认创建,平台会检测出来一些镜像信息,直接创建即可。
  4. 构建完成后,在组件 > 端口中打开对内服务。以供后端连接使用

Java源码构建部署 SpringBoot

  1. 这里提前修改了后端项目里的配置文件 ruoyi-admin/src/main/resources/application-druid.yml连接数据库的配置,改为了环境变量连接,这里就用到了上面修改的端口别名。以及修改了ruoyi-admin/src/main/resources/application.yml文件中的连接Redis配置

    # 主库数据源
      master:
          url: jdbc:mysql://${MYSQL_HOST}:${MYSQL_PORT}/ry-vue?
      redis:
          # 地址
          host: 127.0.0.1
          # 端口,默认为6379
          port: 6379
  2. 通过Java源码构建项目
  3. 填写源码仓库地址,构建SpringBoot项目。
  4. 平台会根据项目根目录的 pom.xml 文件检测是什么项目,这里检测的是多模块项目。
  5. 进入多模块构建,勾选ruoyi-admin模块,此模块是可运行的,其他模块都是依赖。具体模块功能参考若依官方文档
  6. 可修改Maven构建参数,无特殊要求无需修改。
  7. 确认创建,等待构建完成。

    ​ 这里需要注意,平台默认使用openjdk ,此项目需要使用oraclejdk来生成前端验证码。

    ​ 需要在组件 > 构建源中修改 JDK类型为自定义JDK,填写自定义JDK下载路径。

    自定义JDK下载地址: https://buildpack.oss-cn-shanghai.aliyuncs.com/jdk/jdk1.8.0.tgz
  • 需要打开 禁用缓存按钮,防止包不一样出现奇奇怪怪的问题。构建成功后再把禁用缓存关闭,下次构建就缓存正确的包了。
  • 修改后 保存修改。构建组件,等待构建完成,修改端口为 8080
  • 进入拓扑图界面,切换为编辑模式,建立组件依赖关系。

    • ruoyi-ui 连接 ruoyi-admin
    • ruoyi-admin 连接 MysqlRedis
  • 更新组件ruoyi-ui ruoyi-admin,至此完成。
  • 最终效果,拓扑图:

tuoputu

  • 页面效果:

ym


Rainbond 云原生应用管理平台,实现微服务架构不用改代码,管理 Kubernetes 不用学容器,帮企业实现应用上云,一站式将任何企业应用持续交付到 Kubernetes 集群、混合云、多云等基础设施。是 Rainstore 云原生应用商店的支撑平台。

1. Rainbond 官网

2. Rainbond 安装使用

3. Rainbond 参考手册全集


本文作者:张齐

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
11天前
|
JavaScript 前端开发 API
vue获取图片的blob传给django后端
vue获取图片的blob传给django后端
17 4
|
10天前
|
算法 Java Linux
java制作海报五:java 后端整合 echarts 画出 折线图,项目放在linux上,echarts图上不显示中文,显示方框口口口
这篇文章介绍了如何在Java后端整合ECharts库来绘制折线图,并讨论了在Linux环境下ECharts图表中文显示问题。
24 1
|
1月前
|
前端开发 JavaScript UED
react或者vue更改用户所属组,将页面所有数据进行替换(解决问题思路)____一个按钮使得页面所有接口重新请求
在React或Vue中,若需在更改用户所属组后更新页面所有数据但不刷新整个页面,可以通过改变路由出口的key值来实现。在用户切换组成功后,更新key值,这会触发React或Vue重新渲染路由出口下的所有组件,从而请求新的数据。这种方法避免了使用`window.location.reload()`导致的页面闪烁,提供了更流畅的用户体验。
50 1
react或者vue更改用户所属组,将页面所有数据进行替换(解决问题思路)____一个按钮使得页面所有接口重新请求
|
16天前
|
JavaScript 算法 前端开发
【VUE】Vue的diff算法和React的diff算法
【VUE】Vue的diff算法和React的diff算法
|
18天前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
36 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
1月前
|
SQL JSON Java
springboot 如何编写增删改查后端接口,小白极速入门,附完整代码
本文为Spring Boot增删改查接口的小白入门教程,介绍了项目的构建、配置YML文件、代码编写(包括实体类、Mapper接口、Mapper.xml、Service和Controller)以及使用Postman进行接口测试的方法。同时提供了SQL代码和完整代码的下载链接。
springboot 如何编写增删改查后端接口,小白极速入门,附完整代码
|
10天前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
145 0
|
10天前
|
前端开发 JavaScript API
深入理解前端框架:React 和 Vue 的比较
【10月更文挑战第7天】深入理解前端框架:React 和 Vue 的比较
|
10天前
|
JavaScript 前端开发 算法
写 React / Vue 项目时为什么要在列表组件中写 key
在React或Vue项目中,为列表组件中的每个元素添加唯一的key属性,有助于框架高效地更新和渲染列表。Key帮助虚拟DOM识别哪些项已更改、添加或删除,从而优化性能并减少不必要的重新渲染。
|
10天前
|
前端开发 Java Shell
后端项目打包上传服务器部署运行记录
后端项目打包上传服务器部署运行记录
14 0

热门文章

最新文章