检疫登记模块图片上传,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 小时前
【技术底稿 15】SpringBoot 异步文件上传实战:多线程池隔离 + 失败重试 + 实时状态推送
java·经验分享·spring boot·后端·程序人生·spring
Arya_aa3 小时前
HTTP与Tmocat服务器与SpringMVC
java·spring boot
songcream13 小时前
Spring Boot资料整理
java·spring boot·后端
披着羊皮不是狼3 小时前
(8):实现双删(MySQL+Redis)
spring boot·后端
全栈工程师修炼指南3 小时前
Nginx | 磁盘IO层面性能优化秘诀:error 日志内存环形缓冲区及小文件 sendfile 零拷贝技术
运维·网络·nginx·性能优化
lhbian3 小时前
PHP vs Java vs Go:编程语言终极对比
java·spring boot·后端·kafka·linq
ywgcsxue3 小时前
在麒麟V10上源码编译安装Nginx
linux·运维·服务器·nginx
Tirzano6 小时前
SpringOAuth2Server 自定义授权码认证,登录和授权码混合
spring boot
一 乐6 小时前
饮食营养信息|基于springboot + vue饮食营养管理信息平台系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·饮食营养管理信息系统