Nginx代理minIO图片路径实现公网图片访问

1、网络部署情况

VUE前端项目Nginx部署在公司内网,端口7790

后台接口项目部署在公司内网,端口7022

minIO服务部署在公司内网,端口9000

公网IP设备将80端口映射到7790端口(具体映射方式不详),实现通过互联网访问系统。

2、遇到的问题

后台将图片的minIO共享路径,直接返回给前端,交给浏览器去请求。

例如:http://内网IP:9000/bucketname/imagename.png?XXXXXXX

浏览器能通过内网地址访问系统,一般情况下也能直接访问到minIO服务器,图片展示没问题。

当用户不在公司内网环境,用浏览器通过公网地址访问系统时,后台接口返回的图片地址,浏览器无法直接请求到。

3、问题解决方案

(1)前端修改图片请求地址,代码如下:

javascript 复制代码
Vue.directive('minio-src', {
    inserted: async function(el, binding) { //指令名称为:real-img
        let imgURL = binding.value; //获取图片地址
        if (imgURL) {
            const protocol = window.location.protocol;
            const host = window.location.host;

            imgURL = imgURL.replaceAll(process.env.VUE_APP_MINIO_HOST,protocol+"//"+host+"/minio");
            console.log("minio-url",imgURL);
            el.setAttribute('src', imgURL);

        }
    }
})

其中process.env.VUE_APP_MINIO_HOST是获取前端项目的环境变量,配置代码如下:

javascript 复制代码
VUE_APP_MINIO_HOST = "http://172.17.0.1:9000"

img标签使用自定义指令,代码如下:

html 复制代码
<img v-minio-src="imagUrl"/>                 

(2)Nginx代理配置如下:

cpp 复制代码
location /minio/ {
    proxy_pass http://172.17.0.1:9000/;
}
相关推荐
若梦plus1 分钟前
Hybrid之JSBridge原理
前端·webview
chilavert3182 分钟前
技术演进中的开发沉思-269 Ajax:拖放功能
前端·javascript·ajax
xiaoxue..2 分钟前
单向数据流不迷路:用 Todos 项目吃透 React 通信机制
前端·react.js·面试·前端框架
若梦plus12 分钟前
Canvas的未来之AI绘图、生成式视觉与XR
前端·canvas
艾莉丝努力练剑16 分钟前
Al Ping免费上新:GLM-4.7 && MiniMaxM2.1重磅上线,附独家使用教程
java·大数据·linux·运维·人工智能·python
一水鉴天17 分钟前
整体设计 定稿 之 34 codybuddy项目跨机同步方案 之2 (codebuddy)
服务器·前端
朱 欢 庆17 分钟前
Jenkins任务执行完成后发送邮件
前端·经验分享·jenkins
前端无涯18 分钟前
React/Vue 消息订阅发布:实现方式、开发避坑与面试核心考点
前端·javascript·vue.js
莫渊博-天下无病22 分钟前
node高版本安装
运维·node.js
人工智能训练23 分钟前
Ubuntu 系统安装 VSCode 超全指南(3 种方法,适配 20.04/22.04 LTS)
linux·运维·服务器·vscode·ubuntu