检疫登记模块图片上传,nginx自动映射地址

当选择图片上传时前后端是如何配合操作的?

前端找到检疫登记的index.vue查看相关代码

通过ctrl+f全局搜索

我们要实现当上传照片后自动生成一个图片地址并且是可以在浏览器访问到的地址

注:文件上传必须是post请求

因为文件路径要转换成二进制放在请求体中,get没有请求体

在前端utils包下找到common.js将上传文件路径的端口号改成我们自己的,并且查看接口和二级接口

在项目中的controller层下面新建UploadController类作为文件上传模块

同时需要加相应注解

然后定义一个本地上传的方法localUpdate(对象为MultipartFile file)

文件名称从前端获得

我们要返回的src是imgUrl

MultipartFile由spring mvc提供

方法上加postMapping 通过前端查看路径

基于http协议访问电脑中的资源:

而不是只是一张桌面地址的图片或者文件地址,这样浏览器是访问不到的

使用nginx静态服务器进行反向代理

1.在D盘创建pts_resource文件夹将来使用nginx代理监听这个包下面的资源

2.执行后端代码再回到浏览器检疫模块随意上传一张图片,transferTo会将图片转发过到我们自定义的路径下

如果上传任意一张jpg格式的图片最后也会上传到我们指定的文件路径下并且会覆盖掉之前上传进来的图片,格式会转换成png

3.我们想保留源文件的后缀名,也就是将上传的图片使用自己原有名字保留在pts_resource中,使用固定名称1.png会改变源文件名称

调用

4.也要保证每一张图片名字不重复,只拿到源文件格式名 如:png

使用.分割数组,拿取mp4,原来数组长度为4,要拿到索引为3的mp4,使用长度-1就拿到了,产生的文件名叫做uuid自动生成的字符串拼接上.和源文件后缀名

最后输出在我们指定文件路径下

5.我们一般随机生成的文件名是通过时间自动命名的,uuid生成的不符合我们大众使用的命名

6.纳秒Nano和毫秒差1000000

7.我们在pts下新建一个Utils封装工具类,实现时间格式命名的图片

8.创建FileNameUtils类

实现 拿取源文件后缀名+生成时间格式形成一个图片名

一般工具类是一个静态方法 因为可以通过类名调用

测试类进行测试

最终在controller实现功能

我们要实现生成的图片命名地址自动映射在图片下方,使用nginx代理

1.下载nginx压缩包

2.解压至D盘

通过nginx访问文件资源步骤 见此博客

最终实现图片上传同时映射路径,将上传的文件转存到自己指定的目录下

相关推荐
凤山老林2 小时前
从0到1搭建企业级权限管理系统:Spring Boot + JWT + RBAC实战指南
java·spring boot·后端·权限管理·rbac
2401_878820474 小时前
Sa-Token基础篇
java·spring boot·后端·sa-token
2301_816374334 小时前
Nginx下构建PC站点
java·运维·nginx
weixin_lizhao5 小时前
50天独立打造企业级API网关(二):安全防护体系与弹性设计
java·spring boot·安全·spring cloud·gateway
网络笨猪5 小时前
Nginx企业级高频场景配置大全
运维·nginx
Slow菜鸟7 小时前
Docker 学习篇(七)| 实战 — 用 Docker 构建 SpringBoot + Vue 全栈项目
spring boot·学习·docker
普修罗双战士11 小时前
项目设计-文章系统发布文章完整前后端设计
java·数据库·vue.js·spring boot·git·intellij-idea
StockTV12 小时前
新加坡股票API 实时行情、K 线及指数数据
android·java·spring boot·后端·区块链
RuoyiOffice12 小时前
SpringBoot+Vue3 企业云盘系统设计:文件上传+共享权限+收藏分类+5GB空间控制——从“网盘孤岛”到“企业知识底座”
spring boot·uni-app·vue·文件管理·云盘·网盘·ruoyioffice