文件上传的思路与固定参数

文件上传的思路与固定参数

VO对象

@Data
@Accessors(chain=true)
@NoArgsConstructor
@AllArgsConstructor
public class EasyUI {
	private Integer error; //状态码,0正常,1异常
	private String url;
	private (其余参数);
	
	//1.失败方法
	public static EasyUIImage fail() {		
		return new EasyUIImage(1,(url为空),(其余参数为空));
	}
	
	//2.成功方法
	public static EasyUIImage success(String url,(其余参数)) {
		
		return new EasyUIImage(0, url,(其余参数));
	}
}

配置类 properties

image.fileDirPath=E:/JT_IMAGE/
image.urlPath=http://image.jt.com/

Controller对象

	@RequestMapping("(url)")
	public EasyUI uploadFile(MultipartFile uploadFile) {
		return fileService.uploadFile(uploadFile);
	}

Service对象

@Service
@PropertySource("classpath:/properties/image.properties")
public class FileServiceImpl implements FileService {
	
	@Value("${image.fileDirPath}")
	private String fileDirPath;	// = "E:/JT_IMAGE/"; //定义文件根目录
	@Value("${image.urlPath}")
	private String urlPath;	// = "http://image.jt.com/";
	/**
	 * 实现思路:
	 * 	1.校验是否为文件,以图片为例 jpg|png|gif...
	 *  2.防止恶意程序
	 *  3.分目录保存图片 1.按照图片类型 2.按照时间划分 yyyy/MM/dd
	 *  4.防止图片重名    1.原有名称+随机数3位.jpg
	 *  			   2.UUID.jpg
	 */
	@Override
	public EasyUIImage uploadFile(MultipartFile uploadFile) {
		//一.实现校验
		//1.1 获取名称 判断字符串的类型
		String fileName = uploadFile.getOriginalFilename();
		fileName = fileName.toLowerCase();	//全部转化为小写
		//1.2利用正则表达式判断是否为图片
		if(!fileName.matches("^.+\\.(jpg|png|gif)$")) {
			//证明不是图片
			return EasyUIImage.fail();
		}
		
		//二:如何防止是恶意程序?  可以根据宽度和高度实现图片校验.
		//首先准备一个图片的容器.将字节信息添加到容器中,获取宽高.
		try {
			BufferedImage bufferedImage = ImageIO.read(uploadFile.getInputStream());
			int width = bufferedImage.getWidth();
			int height = bufferedImage.getHeight();
			
			if(width ==0 || height ==0) {
				//一定不是图片
				return EasyUIImage.fail();
			}
			
			//三  说明图片类型正确. 分目录存储. date转化为yyyy/MM/dd
			String datePath = new SimpleDateFormat("yyyy/MM/dd/")
							  .format(new Date());
			//E:\JT_IMAGE\yyyy\MM\dd\
			String fileLocalPath = fileDirPath + datePath;
			File dirFile = new File(fileLocalPath);
			if (!dirFile.exists()) {
				//创建新目录
				dirFile.mkdirs();
			}
			
			//四:实现文件上传 UUID.jpg
			String uuid = UUID.randomUUID().toString().replace("-", "");
			int index = fileName.lastIndexOf(".");
			String fileType = fileName.substring(index);
			String realFileName = uuid + fileType;
			
			//准备文件上传的全路径 E:\JT_IMAGE\2020\02\12\ uuid.jpg
			String realFilePath = fileLocalPath + realFileName;
			//文件上传
			uploadFile.transferTo(new File(realFilePath));
			//准备虚拟路径 http://image.jt.com/yyyy/MM/dd/uuid.jpg 
			String url = urlPath + datePath + realFileName;
			return EasyUIImage.success(url, width, height);
			
		} catch (Exception e) {
			e.printStackTrace();
			return EasyUIImage.fail(); //如果转化出错,则回传错误信息.
		}
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值