文件上传页面

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body><h1>实现文件上传</h1><!--enctype="开启多媒体标签" -这一个属性就开启了多媒体文件的上传!! --><form action="http://localhost:8091/file" method="post" enctype="multipart/form-data"><input name="fileImage" type="file" /><input type="submit" value="提交"/></form>
</body>
</html>

1 编辑FileController --只是引入文件上传的示例

package com.jt.controller;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;import java.io.File;
import java.io.IOException;
import java.io.InputStream;@RestController
public class FileController {/***  MultipartFile 接口作用 主要就是优化了文件上传 API集合* 1. 文件上传位置???   D:\JT-SOFT\images* 2. 判断一下文件目录是否存在* 3. 利用API实现文件上传.*/@RequestMapping("/file")public String file(MultipartFile fileImage){String fileDir = "D:/JT-SOFT/images";File file = new File(fileDir);if(!file.exists()){ //文件不存在则创建文件file.mkdirs(); //一次性创建多级目录}//文件信息 = 文件名+文件后缀  ----这里开始真正的利用多媒体文件MultipartFile类型的API-getOriginalFilename获取多媒体文件的全称String fileName = fileImage.getOriginalFilename();//将文件的整体封装为对象 文件路径/文件名称File imageFile = new File(fileDir+"/"+fileName);//实现文件上传,将文件字节数组传输到指定的位置. -另一个多媒体文件的API - transferTo上传多媒体文件到本地磁盘位置并保存try {  fileImage.transferTo(imageFile);} catch (IOException e) {e.printStackTrace();}return "文件上传成功!!!!";}
}

真正项目上的文件上传操作

1 封装VO对象
{“error”:0,“url”:“图片的保存路径”,“width”:图片的宽度,“height”:图片的高度}
说明:
error: 代表文件上传的错误. 0 文件上传正确 1.文件上传失败.
url地址: 访问图片的网络地址… 用户通过url地址获取图片信息 --与真实物理地址之间经过nginx反向代理实现
访问图片的物理地址… 真实存储的地址 D:/a/a.jpg
width/height: 宽度和高度是图片的特有属性…判断是否为图片的依据

package com.jt.vo;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;import java.io.Serializable;@Data
@Accessors(chain = true)
@NoArgsConstructor
@AllArgsConstructor
public class ImageVO implements Serializable {//{"error":0,"url":"图片的保存路径","width":图片的宽度,"height":图片的高度}private Integer error;private String  url;     //图片虚拟访问路径private Integer width;  //宽度private Integer height; //高度//success  failpublic static ImageVO fail(){return new ImageVO(1,null,null,null);}public static  ImageVO success(String url,Integer width,Integer height){return new ImageVO(0, url, width, height);}
}

2 文件上传页面url分析

参数说明
jsp页面需要/或者提供了哪个参数就后端开发就要提供/或者接收那个参数,参数名称必须一致,否则页面解析不了/或后端参数/对象接收不到!!
3 编辑配置文件image.properties --为了将来实现项目的扩展性,将核心的配置写入该配置文件中

#properties的作用就是封装key=value 业务数据
image.dirPath=D:/JT-SOFT/images
image.urlPath=http://image.jt.com
#这里写域名是为了客户端访问方便的,经过nginx反向代理服务器后实际链接到服务器本地磁盘上的物理路径

3.编辑FileController

 package com.jt.controller;
//导的包就不写了,idea自动导去吧
@RestController
public class FileController {/*** 业务:实现商品的文件上传操作* url地址: http://localhost:8091/pic/upload?dir=image* 参数:    uploadFile   注意字母的大小写* 返回值结果: ImageVO对象.*/@Autowiredprivate FileService fileService;@RequestMapping("/pic/upload")public ImageVO upload(MultipartFile uploadFile){//将所有的业务操作,放到Service层中完成!!!return fileService.upload(uploadFile);}
}

4编辑FileService

package com.jt.service;
@Service
@PropertySource("classpath:/properties/image.properties")
public class FileServiceImpl implements FileService{@Value("${image.dirPath}")private String dirPath;@Value("${image.urlPath}")private String urlPath;//为了防止Set集合每次都要创建,则通过static代码块的形式负责封装数据private static Set<String> imageSet = new HashSet<>();static {imageSet.add(".jpg");imageSet.add(".png");imageSet.add(".gif");//....}/*** 文件上传具体步骤:*      1.如何校验用户上传的是图片?    jpg|png*      2.如何访问用户上传恶意程序     木马.exe.jpg  宽度*高度*      3.应该采用分目录存储的方式     保存数据*      4.上传的文件名称应该尽量避免重名  自定义文件名称...  UUID.后缀...*/@Overridepublic ImageVO upload(MultipartFile uploadFile) {//1.校验图片类型是否正确 jpg|png|gifxxxx  1.正则表达式判断  2.准备集合之后进行校验Set<去重>//1.1 获取上传的图片类型 ABC.JPGString fileName = uploadFile.getOriginalFilename();  //文件的全名 abc.jpgfileName = fileName.toLowerCase();                   //将所有的字符转化为小写int index = fileName.lastIndexOf(".");String fileType = fileName.substring(index);  //含头不含尾即从点处开始切割字符串,没有声明截止位置默认为最后了.//1.2判断是否为图片类型    bug-图片类型大小写这里判断不了一致的,所以获取到多媒体文件的全称后直接全部转化为小写!!if(!imageSet.contains(fileType)){//用户上传的不是图片return ImageVO.fail();}
//2.上传的数据是否为恶意程序. 高度和宽度是否为null. 利用图片API//BufferedImage对象 专门负责封装图片  --利用图片IO对象ImageIO的API-read方法获取到该多媒体文件的字节流封装为BufferedImage对象  --因为它上面有API获取文件的宽和高try {BufferedImage bufferedImage = ImageIO.read(uploadFile.getInputStream());int width = bufferedImage.getWidth();int height = bufferedImage.getHeight();if(width==0 || height ==0){return ImageVO.fail();}
//=======以上仅为判断客户端传来的多媒体文件是否为图片,下面才是真正的图片存入本地磁盘操作=========//3.采用分目录存储的方式 --第三步只是为了创建存储图片的磁盘目录//String dirPath = "D:/JT-SOFT/images";  //动态获取//3.1 分目录存储方式1 hash方式 ACBBCDD//3.1 分目录存储方式2 时间方式存储 yyyy/MM/dd   --注意声明时间格式时前后都要加斜杠,因为这是文件夹目录String dateDir = new SimpleDateFormat("/yyyy/MM/dd/").format(new Date());//3.2 准备文件存储的目录String imageDir = dirPath + dateDir;File imageFileDir = new File(imageDir);if(!imageFileDir.exists()){imageFileDir.mkdirs();}//4 实现文件上传  --优先防止存储文件重名UUID生成文件名称//4.1 动态拼接文件名称   f3aa1378-ece6-11ea-98c9-00d861eaf238//UUID.randomUUID()生成的是一串带有短横杠的16进制数字,转化为字符串是方便用字符串的API-replace替换掉(删减)其中的短横杠String uuid = UUID.randomUUID().toString().replace("-", "");// uuid.后缀 String realFileName = uuid + fileType;//4.2 准备文件上传的全路径  磁盘路径地址+文件名称File imageFile = new File(imageDir+realFileName);//4.3 实现文件上传uploadFile.transferTo(imageFile);
//=====以上已经将多媒体文件存入服务器磁盘了!!下面是将本地磁盘路径转化为url路径方便客户端的访问=====//5.动态生成URL地址//请求协议: http://  https:// 带证书的网址 安全性更高 公钥私钥进行加密解密.//向服务器运行商购买域名  com  cn  org   hosts文件//图片存储的虚拟地址的路径 动态变化的路径//http://image.jt.com/2020/09/02/uuid.jpgString url = urlPath+dateDir+realFileName;return ImageVO.success(url,width,height);} catch (IOException e) {e.printStackTrace();return ImageVO.fail();}}
}        

下一个博客专门写nginx反向代理服务器的安装及使用!!

32 Java中多媒体文件上传及页面回显相关推荐

  1. 上传文件页面回显_数据回显、删除以及excel导出

    数据回显 当点击某个按钮跳转某个页面之前,发送请求到后台进行数据查询,最后将查询结果返回给前端页面,前端页面获取数据,最后呈现出来的效果是就回显的效果. 示例代码: 前端代码: Controller ...

  2. 【.net】Ueditor中图片上传和图片回显路径的设置

    在csdn六百多天的游侠今日现身江湖. 问题发生的背景: 所有项目代码中,图片上传都是固定存到一个图片专属的盘符,这样就可以整个盘符对所有图片进行备份以防丢失. 但是!有一个站点所引用的百度编辑器(主 ...

  3. Java中FTPClient上传中文目录、中文文件名乱码问题解决方法

    Java中FTPClient上传中文目录.中文文件名乱码问题解决方法 参考文章: (1)Java中FTPClient上传中文目录.中文文件名乱码问题解决方法 (2)https://www.cnblog ...

  4. 上传头像并回显(SpringBoot)

    以前经常写上传头像功能,上传头像完回显出来,通常套路是: 数据库保存文件名(自己加工过,防止重名) 然后文件路径写到前台的绝对路径.前台直接用../相对路径的方式显示出来. 但是这样有一个问题就是当我 ...

  5. java中uploadify_java 上传3(uploadify中文api)

    基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同时上传,上传进行进度显示,删除已上传文件. 要求使用jquery1.4或以上版本,flash player 9.0.24以上. 有两个 ...

  6. java图片上传及图片回显1

    目的:选择图片,进行图片回显之后将图片保存到服务器上(PS:没有使用任何插件,样式很丑) 实现方式: js+servlet+jsp的方式来实现 事先准备: 文件上传处理在浏览器中是以流的形式提交到服务 ...

  7. java中excel上传_java对excel表格的上传和下载处理

    Excel表格文件的上传和下载,java中涉及到文件肯定会有io流的知识. 而excel文件就要涉及到poi技术,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为 ...

  8. java中excel上传_java:Excel操作之Excel上传导入

    1.导入我们需要的jar包. 2.创建servlet命名为UploadExcelServlet,url为UploadExcelServlet. 3.创建Excel的批量处理方法ExcelBatchUt ...

  9. 关于Kindeditor上传照片不回显的问题

    项目中用到了Kindeditor,需要把图片上传到服务器上,然后并显示出来.以前一直显示不出来,一看路径是本地磁盘的路径这样是肯定显示不出来的,所以需要在后台把saveUrl修改一下就可以了.需要修改 ...

最新文章

  1. PCL基础4:PCLVisualizer可视化窗口显示
  2. android分析windowManager、window、viewGroup之间关系
  3. C语言结构体通过 scanf初始化
  4. linux 初始化数组,c – 使用initializer_list初始化数组?
  5. 全球及中国汽车紧急呼叫终端行业运营模式及未来投资方向建议报告2022版
  6. 统计学:回归分析(2)
  7. python数据可视化代码_python数据可视化
  8. C++类与对象概念详解
  9. IOS之代理文字点击变大变小
  10. (67)Vue-cli 项目搭建
  11. [洛谷P1119]灾后重建
  12. QtCreator 编译时提示 warning C4819 的解决办法
  13. 超分20220225讨论
  14. php服务端搜索,功能改进
  15. 零基础入门STM32编程——工具篇(四)
  16. 2015 上海邀请赛c题 calculator hdu5238
  17. python glob.glob()
  18. atmega16应用之TWI(IIC) PCF8574T转接LCD1602
  19. react 中 JSX 语法的转化过程
  20. jquery LigerUI是什么?

热门文章

  1. 两步搞掉电脑开机密码
  2. sketchup模型 导入unity报错
  3. Android adb命令选择设备
  4. 从面相就能看出你的健康状况
  5. 蓝牙mesh基本概念讲解
  6. java在程序运行过程中_Java内存管理-程序运行过程(一)
  7. 游戏任务设计(1):概念与简史
  8. xib的简单介绍与使用
  9. C语言实现集合运算(交并差补)
  10. 互联网大数据公司排名_互联网上最好的数据科学课程,按照您的评论排名