minio图片展示

  • 一、minio图片服务器
  • 二、图片展示
    • 1.方法一:后端转发
    • 2.方法二:nginx代理

一、minio图片服务器

拥有两个端口号,一个时web端控制台端口号,一个是上传时使用的端口号
在后端配置的是内网地址,直接使用minio返回的url进行展示的话,外网无法正常展示

二、图片展示

1.方法一:后端转发

代码如下(示例):
后端:

public void getImage(String bucketName, String fileName, HttpServletResponse response) throws IOException {InputStream in = null;try {in = minioClient.getObject(GetObjectArgs.builder().bucket(bucketName).object(fileName).build());} catch (Exception e) {e.printStackTrace();}if (in == null){response.sendError(404, "未能找到图片");}//图片类型String[] fileArr = fileName.split("\\.");String contentType = "";StringBuilder originalFileName = new StringBuilder();if (fileArr.length > 1){contentType = "image/" + fileArr[fileArr.length - 1];for (int i = 0; i < fileArr.length - 1; i++) {originalFileName.append(fileArr[i]);if (i != fileArr.length - 2){originalFileName.append(".");}}}else {contentType = "application/octet-stream";originalFileName = new StringBuilder(fileName);}try {response.addHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");response.addHeader("X-Original-File-Name", originalFileName.toString());response.setContentType(contentType);ServletOutputStream outputStream = response.getOutputStream();IOUtil.copyCompletely(in, outputStream);outputStream.flush();outputStream.close();} catch (IOException e) {e.printStackTrace();}}

前端:

<img v-for="picture in picturesSrc":src="picture"alt="图片"style="width: 40px; height: 40px; display: inline-block; border-radius: 4px"v-on:click="showPicture(picture)"/>......this.picturesSrc = JSON.parse(row.fileName).map(fileName => {let encodeUrl = encodeURIComponent(fileName);return `${this.$config.baseUrl}/getImage?fileName=${encodeUrl}&bucketName=test`})

注意:这里之前写好的接口返回了图片名称,图片名称可能存在特殊字符,所以进行了加码处理

2.方法二:nginx代理

public List<String> getNginxObjectUrlByList(String bucketName, String fileNameList) {List<String> fileNames = JSON.parseArray(fileNameList, String.class);List<String> urlList =  new ArrayList<>();fileNames.forEach(res ->{urlList.add(getObjectUrl(bucketName, res).replace("内网地址+minio端口号", "外网地址/minio"));});return urlList;}
server {listen   80;location ^~ /minio/ {proxy_read_timeout 600s;#这里一开始用了127.0.0.1不好用,没看原因proxy_pass http://内网地址+minio端口号;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Special-Delivery "";proxy_set_header Access-Control-Allow-Origin "";proxy_set_header Proxy-Client-IP $remote_addr;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;add_header X-Special-Delivery "stop-polling-our-interface-you-bitch" always;add_header Access-Control-Allow-Origin "you-poll-your-mama-blyat" always;}}

minio图片展示(minio图片上传地址为内网,展示时为外网)相关推荐

  1. MinIO基本使用(实现上传、下载功能)

    MinIO基本使用(实现上传.下载功能) 1.简介 2.下载和安装 3.启动服务端 4.创建User和Bucket 4.1 创建User 4.1.1 生成accessKey和secretKey 4.2 ...

  2. axios获取图片显示_Vue.js+axios图片预览以及上传显示进度

    在平时项目开发中,我们经常会对文件做一些上传操作,不仅仅要实现基本需求,也要兼顾用户体验,根据自己在工作中遇到的问题谈谈对图片上传的预览以及上传进度的优化. 1.搭建项目 基于Vue.js+axios ...

  3. vue+element-ui实现富文本(含有图片粘贴拖拽上传)

    vue+element-ui实现富文本(含有图片粘贴拖拽上传) Just For Share | 仅仅分享 首先需要安装 cnpm i vue-quill-editor -D 富文本编辑器 cnpm ...

  4. 【OSS】图片加水印与上传

    图片加水印与上传 一.效果图 1.未添加水印图 2.添加水印效果图 二.需求场景 三.加水印 1. 图片上设置水印,字体如何设置? 2.图片有大有小,如何使水印大小自适应 3.水印位置如何设置 4.图 ...

  5. 图片文件压缩并上传至阿里云OSS

    图片处理 Thumbnails 在进行Java开发时可以使用Thumbnails工具类对图片进行处理,旋转.裁剪.格式转换.加水印等. 使用步骤 导包 <dependency><gr ...

  6. H5图片预览及上传(WEB前端)

    H5图片预览及上传 web上传图片很简单,网上有许多的demo和js,但是本人嫌弃用那些会引入许多js包,所以还是用原生的jquery来写吧. 一.html布局文件 html有一个自己的上传文件控件- ...

  7. 图片服务器上图片的管理网站上传与前台显示

    图片服务器上图片的管理网站上传与前台显示 代码简介:  很实用的一个图片上传得例子 图片上传:生成缩略图 加文字水印 图片水印 51aspx.png为水印图片 远程图片抓取(保存到本地)支持jpg.g ...

  8. 图片和视频的上传(文件上传通用)

    流程如下: 1.先引入el-upload 2.调用上传前事件 3.上传前事件中将file文件转formData 4.调用后端oss接口上传文件 5.上传完成后回显数据 6.点击图片/视频预览 图片和视 ...

  9. 富文本在服务器上图片不显示,解决CKEditor 4 富文本编辑器在图片组件无法显示[上传]选项卡的相关问题...

    关于解决CKEditor 4 富文本编辑器在图片组件无法显示[上传]选项卡的相关问题. 本文可能会对以下现象得以解决: 图片上传组件,没有 [上传] 选项卡. 资源无法加载 [imgupload] ( ...

最新文章

  1. 中国科学7月微生物组专刊:赵立平、秦楠、东秀珠领衔
  2. MyBatis之注解开发
  3. dev c++不能单步调试的问题汇总!我劝Dev耗子尾汁!
  4. mysql 113_Centos 下 can't connect mysql server 113
  5. Java:反射和注解从入门到放弃
  6. LeetCode之两个数组的交集
  7. 1038: 绝对值最大 Python
  8. 判断div是否在可视区内
  9. 百度统计之百度代码引用
  10. Android 隐藏虚拟按键
  11. 微信开发者工具-真机调试
  12. 必看,抖音小店无货源模式到底该怎么做?
  13. 开根号的笔算算法图解_一个数的开根号怎么计算
  14. append html 是字符串,jquery .html()vs .append()
  15. 2022-6-4 小明爱上课,切木头,最多分成多少块,躲猫猫,争渡
  16. Matlab 计算显色指数(Ra,R1-R15)、CCT、duv、Lux、XYZ三刺激值、CIE1931x、CIE1931y
  17. Linux Zram配置使用(特定平台个人使用,maybe不具普适性)
  18. 新型发明创造大赛计算机类,2019年自主招生的七大途径你知道吗,这些内容你需要了解!...
  19. Mysql 慢SQL分析工具pt-query-digest介绍
  20. 原创文章写作(seo原创文章写作时有哪些忌讳)

热门文章

  1. python二进制转为十进制-Python实现的十进制小数与二进制小数相互转换功能
  2. js中的图片指定切换效果
  3. JS 语法有效性的判断
  4. uniapp 实现微信小程序 个人分享,朋友圈分享
  5. ExpRe[4] python[1] 单元测试,算法题对拍
  6. 机械系统计算机辅助运动学和动力学 引言
  7. python连接sql server数据库并模糊查询
  8. 如何在matlab中打开一个.dat文件,并载入数据
  9. 经验:那些年,我在大学接过的外包项目
  10. 失去中国市场,三星手机却连续11年居于全球第一