SpringBoot 文件上传(一)

应用场景

文件上传是指将本地图片、音频、视频等文件上传至服务器的过程,应用场景非常多。

比如:更新头像、交作业上传作业文件、发微博微信时上传图片等。

前端页面三要素

上图显示前端页面的三要素以及对应的页面样式

前端页面三要素:

  1. 请求方式是post。因为文件比较大,一般情况下都使用post方式。
  2. 表单的编码格式为mutipart/form-data。因为普通默认的编码格式是不适用于大型的二进制文件的。
  3. 上传文件对应的表单项类型是file

实际操作

前端页面放置位置

将前端页面放置在src/main/resources/static目录下

鼠标放置在属性名上,会显示对应的解释

建议使用火狐浏览器进行测试,因为chorm浏览器将请求数据封装了

利用开发者工具查看请求数据

点击F12,打开开发者工具

提交表单,查看开发者工具中的网络一栏

点击Post请求,首先查看请求头,点击“原始”

可以看到Content-Type(数据内容类型)是前端指定的mutipart/form-data,后面所接的boundary代表表单会分为多个部分提交,且每个部分之间都会有一个分隔符。

接下来确认请求体,点击“请求”

后端接收文件

后端要编写相应的代码接收浏览器传递的数据

新建一个UploadController类,标明注释

@RestController
@Slf4j
public class UploadController {}

创建和前端请求路径相同、方式相同的方法

@RestController
@Slf4j
public class UploadController {@PostMapping("/upload")public Result upload() {}
}

书写对应的请求参数:

  • 特别注意文件的参数类型(MultipartFile)
  • 参数名要和前端表单项的名字对应,如果不同要用@RequestParam声明
public Result upload(String username, Integer age, @RequestParam("image") MultipartFile Myimage) {}

对应的前端代码是:

    <form action="/upload" method="post" enctype="multipart/form-data">姓名: <input type="text" name="username"><br>年龄: <input type="text" name="age"><br>头像: <input type="file" name="image"><br><input type="submit" value="提交"></form>

记录日志

 @PostMapping("/upload")public Result upload(String username, Integer age,MultipartFile image){log.info("文件上传:{},{},{}",username,age,image);return Result.success();}

断点测试

在记录日志这行打个断点

注意,现在不能直接使用快捷方式跳转到浏览器中前后端联调测试了,需要到后端的8080端口进行测试,访问localhost:8080/upload.html

以debug的方式运行后端程序,浏览器提交表单,返回后端查看断点的数据

location是浏览器上传的文件,服务器端将其存放的目录,是临时文件的格式

放行断点后,临时文件被删除

下一节讲解如何将浏览器上传的文件保存下来

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/562590.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python爬取歌曲宝音乐:轻松下载Jay的歌

歌曲宝是一个不用付费就能听jay的歌曲&#xff0c;但是每次都只能播放一首不方便&#xff0c;于是今天想把它下载下来&#xff0c;本地循环播放&#xff0c;它所用到的接口是某我的还不错哈 获取搜索接口 分析html请求接口&#xff0c;获取到的数据是直接渲染好的HTML内容&…

浅谈Javascript虚拟列表(virtaul list)改造成虚拟表格(virtaul table)的技术

前端加载百万条数据列表&#xff0c;如果采用真实的DOM插入100万个div&#xff08;或li&#xff09;标签&#xff0c;肯定是非常卡顿的。这就不得不使用虚拟列表技术方案&#xff0c;但是虚拟列表技术方案网上有很详细的实现方法&#xff0c;今天我就来谈谈根据网上的方案&…

【Python音视频技术】玩AI视频创作引发写Python音视频技术系列文章1---视频添加字幕

最近对视频创作感兴趣&#xff0c; 详情见之前写的几篇文章。 【AI应用】模仿爆款视频二次创作短视频操作步骤 【人工智能】AI数字人视频演示 【人工智能】AI视频二次创作演示 作为程序员出身的我&#xff0c;看到一些功能, 我都有猎奇的习惯&#xff0c; 想着自己用什么技…

cryptohack代码(2)

5.XOR 简单异或&#xff0c;简单代码 from pwn import * print(xor(label,13)) 与" "效果一样 6.XOR Properties 题目&#xff1a; 题目给了相应的中字符串 k1k2 ^ k1k2 ^ k3flag ^ k1 ^ k2 ^ k3分别记为A、B、C、D&#xff0c;则flag D ^ A ^ C 异或高级…

每日一题 --- 977. 有序数组的平方[力扣][Go]

今天这一题和昨天的知识点是一样的&#xff0c;就是双指针法。 题目&#xff1a; 给你一个按 非递减顺序 排序的整数数组 nums&#xff0c;返回 每个数字的平方 组成的新数组&#xff0c;要求也按 非递减顺序 排序。 示例 1&#xff1a; 输入&#xff1a;nums [-4,-1,0,3,1…

C++一维数组练习 洛谷

1.冰雹猜想 #include<bits/stdc.h> using namespace std; int main() {int n,a[1002]{0},i1;//i是记个数用的cin>>n;while(n!1)//重点{a[i]n;i;if(n%20) n/2;else n3*n1;}a[i]1;//开始准备输出for(int ji;j>1;j--){cout<<a[j]<< ;}return 0; } #in…

后端Jwt实现Token编码、解码以及axios的request请求头的Token传输方式

目录 一、什么是JWT&#xff1a; 二、Jwt的使用&#xff1a; 第一步&#xff1a;引入依赖&#xff1a; 第二步&#xff1a;配置拦截器&#xff1a;JwtInterceptor.java&#xff1a; 其中异常文件ServiceException配置如下&#xff1a; 全局异常文件GlobalException.java文…

OceanMind海睿思入选中国信通院《2023高质量数字化转型技术解决方案集》

近日&#xff0c;由中国信息通信研究院“铸基计划”编制的《2023高质量数字化转型技术解决方案集&#xff08;第一版&#xff09;》正式发布。 中新赛克海睿思 凭借卓越的产品力以及广泛的行业实践&#xff0c;成功入选该方案集的数据分析行业技术解决方案。 为促进数字化转型…

大模型学习笔记七:LLM应用

文章目录 一、维护生产级别的LLM应用,需要做的事二、符合需求的LLM App维护平台三、LangFuse1)替换OpenAI客户端(把跟OpenAI交互记录到LangFuse)1.1)几个基本概念2)通过LangChain的回调函数触发记录(上面用的原生OpenAI接口,下面是调用LangChain的接口)3)构建一个实际…

蓝桥刷题--N皇后和最近公共祖先

1.N皇后 #include<iostream> using namespace std;const int N 12; int vis[N][N], n, ans;void dfs(int dep) {// 在这个搜索中dep表示行&#xff0c;i表示列// 1 搜索出口if(dep n 1){ans;return;}// 2 继续搜索for(int i 1; i < n; i){// 2.1 排除非法情况if(v…

副业赚钱秘籍:让空闲时间更有价值

副业&#xff0c;无疑是增加收入、实现财务自由的理想途径&#xff0c;尤其适合那些希望利用闲暇时间创造价值的人群。今天&#xff0c;我为您精选了六种副业赚钱策略&#xff0c;让您轻松拓宽财源。 一、网络营销&#xff1a;通过社交媒体、博客或在线市场&#xff0c;巧妙推…

Linux进程管理:(九)实时调度

文章说明&#xff1a; Linux内核版本&#xff1a;5.0 架构&#xff1a;ARM64 参考资料及图片来源&#xff1a;《奔跑吧Linux内核》 Linux 5.0内核源码注释仓库地址&#xff1a; zhangzihengya/LinuxSourceCode_v5.0_study (github.com) 实时指的是一个特定任务的执行时间必…