Java中多媒体文件上传及页面回显的操作代码

文件上传页面

<%@ 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 fail
 public 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对象.
 */
 @Autowired
 private 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.后缀...
 */
 @Override
 public ImageVO upload(MultipartFile uploadFile) {
 //1.校验图片类型是否正确 jpg|png|gifxxxx 1.正则表达式判断 2.准备集合之后进行校验Set<去重>
 //1.1 获取上传的图片类型 ABC.JPG
 String fileName = uploadFile.getOriginalFilename(); //文件的全名 abc.jpg
 fileName = 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.jpg
  String url = urlPath+dateDir+realFileName;
  return ImageVO.success(url,width,height);
 } catch (IOException e) {
  e.printStackTrace();
  return ImageVO.fail();
 }
 }
} 

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

到此这篇关于Java中多媒体文件上传及页面回显的操作代码的文章就介绍到这了,更多相关Java文件上传页面回显内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • java Springboot实现多文件上传功能

    前端采用layui框架,讲解多文件上传的完整实现功能. 前端html重点代码如下: <div class="layui-form-item"> <label class="layui-form-label">上传文件</label> <div class="layui-input-block"> <div class="layui-upload"> <butto

  • java 文件上传到读取文件内容的实例

    1.下载文件,将文件保存到本地.(只试用excel): 2.对文件的标题进行检验: 3.获取导入的批次(取一个表的一个值,加1): 4.循环获取文件某一个行,某一列的值,set到对象中: 5.检验值的合法性: 6.循环保存到对象中. 7.用map将错误的信息和正确的信息,JSONObject.fromObject(map): public String uploadFile() throws Exception { logger.info("开始导入规则文件:" + fileInput

  • JavaWeb实现多文件上传及zip打包下载

    本文实例为大家分享了javaweb多文件上传及zip打包下载的具体代码,供大家参考,具体内容如下 项目中经常会使用到文件上传及下载的功能.本篇文章总结场景在JavaWeb环境下,多文件上传及批量打包下载功能,包括前台及后台部分. 首先明确一点: 无法通过页面的无刷新ajax请求,直接发下载.上传请求.上传和下载,均需要在整页请求的基础上实现.项目中一般通过构建form表单形式实现这一功能. 一.多文件上传 项目需求为实现多图片上传功能.参考测试了网上找到的众多插件方法后,决定选用Jquery原始

  • Java文件上传与文件下载实现方法详解

    本文实例讲述了Java文件上传与文件下载实现方法.分享给大家供大家参考,具体如下: Java文件上传 数据上传是客户端向服务器端上传数据,客户端向服务器发送的所有请求都属于数据上传.文件上传是数据上传的一种特例,指客户端向服务器上传文件.即将保存在客户端的文件上传一个副本到服务器,并保存在服务器中. 1.上传表单要求 文件上传要求客户端提交特殊的请求--multipart请求,即包含多部分数据的请求.必须将<form/>标签的enctype属性值设为"multipart/form-d

  • 基于Java文件输入输出流实现文件上传下载功能

    本文为大家分享了Java实现文件上传下载功能的具体代码,供大家参考,具体内容如下 前端通过form表单的enctype属性,将数据传递方式修改为二进制"流"的形式,服务端(servlet)通过  getInputStream() 获取流信息, 运用java I/O 流的基础操作将流写入到一个服务端临时创建的文件temp中,然后再次利用文件基本操作,读取并截取临时文件内容,根据其中信息创建相应的文件,将读取出来的具体信息写入,下载时,根据提交的文件名称,找到服务器端相应的文件,然后根据输

  • Java中多媒体文件上传及页面回显的操作代码

    文件上传页面 <%@ 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"&

  • 基于SpringBoot实现图片上传及图片回显

    目录 数据库脚本 框架搭建 pom.xml 依赖 配置文件 实体类 DAO Service 文件上传 添加页面 控制器 列表页面 运行测试问题 全局异常处理 1. @ControllerAdvice + @ExceptionHandler 2. @Configuration+SimpleMappingExceptionResolver 图片回显 1. 回顾保存方式 2. 配置资源映射 案例:图书管理(SpringBoot+Thymeleaf+SpringData-JPA) 添加图书:图书基本信息

  • vant的Uploader 文件上传,图片数据回显问题

    目录 vant的Uploader文件上传,图片数据回显 需求 分析 使用 使用有赞Vant上传控件Uploader感悟 数据处理 后台处理 vant的Uploader文件上传,图片数据回显 需求 描述一下:点击上传证件照,选取需要的图片文件,然后图片在证件照栏展示 分析 看着挺简单的,用的是vant,里面有个文件上传的组件Uploader,它里面的文件预览模式是这样的 啊这... 指定不行,还好它还有自定义上传样式的,像这样 问题又来了:选取文件后没反应了!!! 其实也不是,没有反应就是没有对文

  • element中的el-upload附件上传与附件回显

    目录 1.上传 2.附件回显 开发中经常也会遇到附件的上传和回显,最方便的就是我们封装一个公共组件在页面中引用 1.上传 在src里面新建一个文件夹 <template> <el-upload class="upload-demo" multiple :limit="limit" :accept="accept" :headers="headers" :file-list="fileList&quo

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

    问题描述: 使用org.apache.commons.net.ftp.FTPClient创建中文目录.上传中文文件名时,目录名及文件名中的中文显示为"??". 原因: FTP协议里面,规定文件名编码为iso-8859-1,所以目录名或文件名需要转码. 解决方案: 1.将中文的目录或文件名转为iso-8859-1编码的字符.参考代码: 复制代码 代码如下: String name="目录名或文件名"; name=new String(name.getBytes(&qu

  • Java实现图片上传至FastDFS入门教程

    今天来开始写图片上传的功能, 现在的图片上传都讲求 上传完成后立刻回显且页面不刷新, 这里到底是怎么做的呢? 当然是借助于ajax了, 但是ajax又不能提交表单, 这里我们还要借助一个插件: jquery.form.js 剩下的一个是FastDFS, 那么什么是FastDFS呢? FastDFS是一个开源的轻量级分布式文件系统,由跟踪服务器(tracker server).存储服务器(storage server)和客户端(client)三个部分组成,主要解决了海量数据存储问题,特别适合以中小

  • Java Struts图片上传至指定文件夹并显示图片功能

    继上一次利用Servlet实现图片上传,这次利用基于MVC的Struts框架,封装了Servlet并简化了JSP页面跳转. JSP上传页面 上传一定要为form加上enctype="multipart/form-data",表示提交的数据时二进制的 并且必须是method="post" <%@ page language="java" contentType="text/html; charset=utf-8" page

  • Android实现相册中图片上传或下载

    本文实例为大家分享了Android实现相册中图片上传或下载的具体代码,供大家参考,具体内容如下 目标效果: 打开相册选择一张图片,会显示到上方的ImageView中并存储到Bmob中,存储后进入Bmob后台,复制刚才添加的数据的objectId,粘贴到代码指定出,然后运行,点击下载会在下方的ImageView显示刚才上传的图片,这里的下载是指定objectId,可以进行动态获取objectId进行下载. 1.activity_main.xml页面设置布局. activity_main.xml页面

  • 聊聊在Servlet中怎么上传文件

    首先对Servlet上传文件的简单理解 此前,Servlet本身没有对文件上传提供直接的支持,一般需要使用第三方框架来实现,这样就比较麻烦 不过,Servlet3.0之后提供了这个功能,而且使用非常简单,,为此,HTTPServletRequest提供了两个方法用于从请求中解析出上传的文件: Part getPart(String name) //获取请求中给定 name 的文件 Collection<Part> getParts() //获取所有的文件 其中每一个文件用一个javax.ser

  • java实现文件上传和下载

    本文实例为大家分享了java实现文件上传和下载的具体代码,供大家参考,具体内容如下 文件的上传 upload:文件上传 客户端通过表单的文件域file  把客户端的文件 上传保存到服务器的硬盘上 页面 首先对上传的表单有以下要求: 必须有文件域:input type=file 表单提交方式:method=post 表单的 enctype=multipart/form-data <form method="post" action="/user/regist"

随机推荐