当前位置: 首页 > news >正文

手写一个文件上传demo

背景

最近闲来无事,同事闻了一下上传文件的基本操作,如何用文件流来实现一个文件的上传功能

基本概念

   流(Stream)是指在计算机的输入输出操作中各部件之间的数据流动。可以按照数据传输的方向,将流可分为输入流和输出流,它是java中相对比较重要的知识点,无论是考试、面试,还是实际工作过程中,这都是经常能够使用到的身影。希望各位看官们可以更好地了解流的相关知识。

输入流

Java 流相关的类都封装在 java.io 包中,而且每个数据流都是一个对象。所有输入流类都是 InputStream 抽象类(字节输入流)以及 Reader 抽象类(字符输入流)的子类。其中 InputStream 类是字节输入流的抽象类,是所有字节输入流的父类,其层次结构如下图 所示。

Java 中的字符他其实是 Unicode 编码,即双字节,而 InputerStream 是用来对单字节处理的,在处理字符文本时显得不是很方便。这时可以使用 Java中 的文本Reader 类(输入流 ),该类是字符输入流的抽象类,即所有字符输入流的实现都是它的子类,该类的方法与 InputerSteam 类的方法类似,这里不再介绍。

以上是关于输入流的基本概念,下面我们直接上代码。实现我们的文件上传功能

输出流

在 Java 中所有输出流类都是 OutputStream 抽象类(字节输出流)和 Writer 抽象类(字符输出流)的子类。其中 OutputStream 类是字节输出流的抽象类,是所有字节输出流的父类,其层次结构如下图所示。

OutputStream 类是所有字节输出流的超类,用于对以二进制的形式将数据写入目标设备,该类是抽象类,不能被实例化。OutputStream 类提供了一系列跟数据输出有关的方法, 

 代码如下

    public ApiResult upload(@NotNull(message = "上传参数不能为空") @RequestParam("file")MultipartFile[] file) throws BaseException{for (int i = 0; i < file.length; i++) {String originalFilename = file[i].getOriginalFilename();String type = originalFilename.substring(originalFilename.lastIndexOf(".") + 1);if(!getPicTypeMap().containsKey(type.toLowerCase())){throw new ParamException("只允许上传png、jpg格式图片或者pdf");}// TODO 此处未做大小显示如果想要限制,放开就好if(type.equalsIgnoreCase("png") || type.equalsIgnoreCase("jpg") ){if(file[i].getSize() > 5120){throw new ParamException("图片超过了限制");}}if(type.equalsIgnoreCase("mp4")){if(file[i].getSize() > 512000){throw new ParamException("视频超过了限制");}}if(type.equalsIgnoreCase("pdf") ){if(file[i].getSize() > 30720){throw new ParamException("pdf超过了限制");}}/*  if(file[i].getSize() > 设定的值){throw new ParamException("上传内容超过了限制");}*/}ApiResult apiResult = new ApiResult();SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMdd");String format = simpleDateFormat.format(new Date());String realPath = filePath + File.separator + format;String returnPath = format;File targetFile = new File(realPath);if (!targetFile.exists()){targetFile.mkdirs();}FileOutputStream bos = null;for (int i = 0; i < file.length; i++) {try {String fileName = UUID.randomUUID().toString().replace("-","");//获取文件后缀(.txt)String extendFileName = file[i].getOriginalFilename().substring(file[i].getOriginalFilename().lastIndexOf('.'));String str = targetFile + File.separator + fileName + extendFileName;// 此处是外面要访问的,所以必须添加returnPath = returnPath  + "/" + fileName + extendFileName;logger.info(str);bos = new FileOutputStream(str);bos.write(file[i].getBytes());apiResult.getData().put("filePath","/" + returnPath);}catch(FileNotFoundException e){e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally{try {bos.flush();bos.close();} catch (IOException e) {e.printStackTrace();}}logger.info("上传成功");}return apiResult;}

今天的文章到此就结束了,欢迎大家留言交流,也可以点击下方的卡片关注一波

这篇文章2000多字,你却说因为文字段被标记为质量低,以下文字就是为了打破它的文字段而造成的质量低!

相信和我一样遇到这个问题的的小伙伴们,心里也已经暗自问候了这个产品经理的祖总十八代了吧!

算法实在是不敢苟同,文字的长短和文章的质量有毛线的关系吗?

这篇文章因为文字段被标记为质量低,以下文字就是为了打破它的文字段而造成的质量低!

相信和我一样遇到这个问题的的小伙伴们,心里也已经暗自问候了这个产品经理的祖总十八代了吧!

算法实在是不敢苟同,文字的长短和文章的质量有毛线的关系吗?

相关文章:

手写一个文件上传demo

背景 最近闲来无事&#xff0c;同事闻了一下上传文件的基本操作&#xff0c;如何用文件流来实现一个文件的上传功能 基本概念 流&#xff08;Stream&#xff09;是指在计算机的输入输出操作中各部件之间的数据流动。可以按照数据传输的方向&#xff0c;将流可分为输入流和输出…...

通过 Apifox Echo 了解 Content-Length

Content-Length 用以指定 Body 的体积。响应头中的 Content-Length 指定 Response Body 的体积&#xff0c;请求头中的 Content-Length 指定 Request Body 的体积。 通过 Content-Length&#xff0c;HTTP 客户端/服务器端将会根据该头部计算出 Body 的大小。 请求头中的 Cont…...

ESP32设备驱动-CPU频率设置

CPU频率设置 文章目录 CPU频率设置1、ESP32的CPU频率介绍1.1 CPU时钟1.2 外设时钟2、CPU频率设置API3、软件准备4、硬件准备5、CPU频率设置实例5.1 CPU频率读取5.2 CPU频率设置在本文中,将介绍如何通过Arduino Core设置或更改ESP32 CPU时钟速度(频率)。 1、ESP32的CPU频率介…...

超声波风速风向传感器的技术参数

技术参数 风速 ◆ 启动风速&#xff1a;0.1m/s ◆ 测量范围&#xff1a;0&#xff5e;30m/s&#xff08;可定制&#xff09; ◆ 测量精度&#xff1a;(0.2m/s0.02*v)(v为真实风速) ◆ 分 辨 率&#xff1a;0.01m/s 风向 ◆ 测量范围&#xff1a;0&#xff5e;359 ◆ 测量精度&a…...

【vue2每日小知识】实现store中modules模块的封装与自动导入

&#x1f973;博 主&#xff1a;初映CY的前说(前端领域) &#x1f31e;个人信条&#xff1a;想要变成得到&#xff0c;中间还有做到&#xff01; &#x1f918;本文核心&#xff1a;省去我们store仓库中分模块时的需要每次导入index的问题 目录 【前言】在store中如何简…...

【Leetcode 剑指Offer】第3天 字符串(简单)

字符串剑指 Offer 05. 替换空格字符串构造函数和析构函数操作函数剑指 Offer 58 - II. 左旋转字符串剑指 Offer 05. 替换空格 题&#xff1a;实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 class Solution { public:string replaceSpace(string s…...

【双指针问题】LeetCode344、345、 844、283问题详解及代码实现

Halo&#xff0c;这里是Ppeua。平时主要更新C语言&#xff0c;C&#xff0c;数据结构算法......感兴趣就关注我吧&#xff01;你定不会失望。 &#x1f308;个人主页&#xff1a;主页链接 &#x1f308;算法专栏&#xff1a;专栏链接 我会一直往里填充内容哒&#xff01; &…...

Linux基础命令-netstat显示网络状态

文章目录 netstat 命令介绍 语法格式 基本参数 显示各列内容分析 1&#xff09;netstat -a显示各列内容分析 2&#xff09;netstat -r显示各列内容分析 3&#xff09;netstat -i 显示各列内容分析 参考实例 1&#xff09;显示系统网络状态的所有连接 2&#xff09;…...

液氮恒温器(电学)T9015的技术规格

液氮型低温恒温器&#xff0c;利用液氮作为降温媒介&#xff0c;标准恒温器可实现快速降温至液氮温度&#xff08;约20min&#xff09;&#xff0c;其工作原理是在恒温器内部液氮腔内装入液氮&#xff0c;通过调整控温塞与冷指的间隙来保持冷指的漏热稳定在一定值上&#xff0c…...

字节跳动大规模实践埋点自动化测试框架设计

大数据时代&#xff0c;多数的web或app产品都会使用第三方或自己开发相应的数据系统&#xff0c;进行用户行为数据或其它信息数据的收集&#xff0c;在这个过程中&#xff0c;埋点是比较重要的一环。 埋点收集的数据一般有以下作用&#xff1a; 驱动决策&#xff1a;ABtest、漏…...

自动化测试优势和劣势

一、自动化测试概述 软件自动化测试是相对手工测试而存在的&#xff0c;由测试人员根据测试用例中描述的规程一步步执行测试&#xff0c;得到实际结果与期望结果的比较。在此过程中&#xff0c;节省人力、时间或硬件资源&#xff0c;提高测试效率。 二、自动化测试优势&劣…...

数据结构---顺序表

专栏&#xff1a;数据结构 个人主页&#xff1a;HaiFan. 专栏简介&#xff1a;从零开始&#xff0c;数据结构&#xff01;&#xff01; 顺序表前言接口实现SListInit初始化和SListDestory销毁SListPrint打印表中的元素SListCheckCapacity检查表中空间SListPushBack尾插和SListP…...

springboot基础

文章目录[toc]SpringBoot概述spring springmvc springboot的关系Spring Boot简介微服务springboot的优点核心功能SpringBoot搭建使用IDEA快速搭建 Spring Boot项目入门案例研究项目结构pom 文件主程序类&#xff0c;主入口类配置文件、加载顺序开启配置文件注释配置文件和加载顺…...

华为OD机试真题Python实现【 时间格式化】真题+解题思路+代码(20222023)

时间格式化 题目 运维工程师采集到某产品线网运行一天产生的日志n条 现需根据日志时间先后顺序对日志进行排序 日志时间格式为H:M:S.N H表示小时(0~23) M表示分钟(0~59) S表示秒(0~59) N表示毫秒(0~999) 时间可能并没有补全 也就是说 01:01:01.001也可能表示为1:1:1.1 🔥�…...

android kotlin 协程(五) suspend与continuation

android kotlin 协程(五) suspend与continuation 通过本篇你将学会: suspendCoroutine{} suspendCancellableCoroutine{} suspend 与 continuation suspendCoroutine 第一次看到这玩意的时候肯定有点身体不适, 先不用管这个东西是什么, 目前为止 只需要知道 suspendCoro…...

JavaScript事件循环

大厂面试题分享 面试题库后端面试题库 &#xff08;面试必备&#xff09; 推荐&#xff1a;★★★★★地址&#xff1a;前端面试题库一、异步执行原理1. 单线程的JavaScript我们知道&#xff0c;JavaScript是一种单线程语言&#xff0c;它主要用来与用户互动&#xff0c;以及操…...

华为OD机试真题Python实现【最少停车数】真题+解题思路+代码(20222023)

最少停车数 题目 特定大小的停车场 数组cars表示 其中1表示有车0表示没车 车辆大小不一,小车占一个车位(长度1) 货车占两个车位(长度2) 卡车占三个车位(长度3) 统计停车场最少可以停多少辆车 返回具体的数目 🔥🔥🔥🔥🔥👉👉👉👉👉👉 华为OD机试(Pyt…...

Python每日一练(20230223)

目录 1. 合并区间 2. 单词接龙 3. N皇后 附录&#xff1a;回溯算法 基本思想 一般步骤 1. 合并区间 难度&#xff1a;★★ 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回…...

Flask----------第一个flask项目,debug、host、port的配置

目录 1.flask 1.简介 2.flask框架的优势 2.第一个flask项目 3.debug 开启debug方法 1.专业版 2.社区版 4.修改host 5. 修改port端口 1.flask 1.简介 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架&#xff0c;对于Werkzeug本质是So…...

容器技术概述

容器技术概述 软件应用程序通常依赖于运行时环境提供的其他库、配置文件或服务。软件应用程序的传统运行环境是物理主机或虚拟机&#xff0c;应用程序依赖项作为主机的一部分安装。 例如&#xff0c;考虑一个 Python 应用程序&#xff0c;它需要访问实现 TLS 协议的公共共享库…...

Diablo Edit2完整指南:掌握暗黑破坏神II角色存档编辑的终极工具

Diablo Edit2完整指南&#xff1a;掌握暗黑破坏神II角色存档编辑的终极工具 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit Diablo Edit2是一款功能强大的暗黑破坏神II角色存档编辑器&#xff0c;…...

ModTheSpire技术全解析:从模组加载到高级开发指南

ModTheSpire技术全解析&#xff1a;从模组加载到高级开发指南 【免费下载链接】ModTheSpire External mod loader for Slay The Spire 项目地址: https://gitcode.com/gh_mirrors/mo/ModTheSpire 引言&#xff1a;为何需要模组加载器&#xff1f; 当你在《Slay The Spi…...

【learn-claude-code】S08BackgroundTasks - 后台任务:慢操作放后台,Agent 继续思考

核心理念 “慢操作放后台&#xff0c;Agent 继续思考” – 后台线程执行命令&#xff0c;完成后通知模型。 源码&#xff1a;https://github.com/xiayongchao/learn-claude-code-4j/blob/main/src/main/java/org/jc/agents/S08BackgroundTasks.java原版&#xff1a;https://g…...

突破网盘限速壁垒:ctfileGet实现技术民主化的创新实践

突破网盘限速壁垒&#xff1a;ctfileGet实现技术民主化的创新实践 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 在数字资源高速流通的今天&#xff0c;网盘服务已成为信息传递的重要基础设施。然而&a…...

G-Helper终极指南:3分钟摆脱华硕笔记本性能烦恼

G-Helper终极指南&#xff1a;3分钟摆脱华硕笔记本性能烦恼 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, Scar, an…...

解锁Dell G15散热潜能:开源Thermal Control Center实战指南

解锁Dell G15散热潜能&#xff1a;开源Thermal Control Center实战指南 【免费下载链接】tcc-g15 Thermal Control Center for Dell G15 - open source alternative to AWCC 项目地址: https://gitcode.com/gh_mirrors/tc/tcc-g15 厌倦了官方AWCC的臃肿和迟缓&#xff1…...

模型轻量化探索:尝试量化cv_unet_image-colorization以适应边缘设备

模型轻量化探索&#xff1a;尝试量化cv_unet_image-colorization以适应边缘设备 最近在做一个智能相册的项目&#xff0c;需要把老照片自动上色。用上色模型效果不错&#xff0c;但一放到手机或者树莓派这类小设备上&#xff0c;问题就来了&#xff1a;模型太大&#xff0c;跑…...

华硕笔记本终极性能优化工具:G-Helper完整使用指南

华硕笔记本终极性能优化工具&#xff1a;G-Helper完整使用指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, Scar,…...

OpenClaw未来展望:Qwen3-4B模型与自动化生态的演进方向

OpenClaw未来展望&#xff1a;Qwen3-4B模型与自动化生态的演进方向 1. 从个人实践看OpenClaw的现状与挑战 去年冬天&#xff0c;当我第一次在本地MacBook上部署OpenClaw时&#xff0c;那种"让AI直接操控我的电脑"的新奇感至今难忘。通过简单的自然语言指令&#xf…...

百度PaddleOCR-VL-WEB效果实测:识别精度超高,多语言支持

百度PaddleOCR-VL-WEB效果实测&#xff1a;识别精度超高&#xff0c;多语言支持 1. 效果初探&#xff1a;它到底有多强&#xff1f; 如果你还在为识别扫描的PDF文档、复杂的表格或者多语言混合的合同而头疼&#xff0c;那么百度开源的PaddleOCR-VL-WEB镜像&#xff0c;很可能…...