Vue +Element UI 图片上传控件使用,前端开发练习

41 阅读1分钟

methods: {

handleRemove(file, fileList) {//移除图片

console.log(file, fileList);

},

handlePictureCardPreview(file) {//预览图片时调用

console.log(file);

this.dialogImageUrl = file.url;

this.dialogVisible = true;

},

beforeAvatarUpload(file) {//文件上传之前调用做一些拦截限制

console.log(file);

const isJPG = true;

// const isJPG = file.type === 'image/jpeg';

const isLt2M = file.size / 1024 / 1024 < 2;

// if (!isJPG) {

// this.$message.error('上传头像图片只能是 JPG 格式!');

// }

if (!isLt2M) {

this.$message.error('上传图片大小不能超过 2MB!');

}

return isJPG && isLt2M;

},

handleAvatarSuccess(res, file) {//图片上传成功

console.log(res);

console.log(file);

this.imageUrl = URL.createObjectURL(file.raw);

},

handleExceed(files, fileList) {//图片上传超过数量限制

this.$message.error('上传图片不能超过6张!');

console.log(file, fileList);

},

imgUploadError(err, file, fileList){//图片上传失败调用

console.log(err)

this.$message.error('上传图片失败!');

}

}

}

3.controller

@RequestMapping(value = "/imgUpload")

public Wrapper imgUpload(HttpServletRequest req, MultipartHttpServletRequest multiReq)

throws IOException {

System.out.println("---" + fileUploadPath);//我这里用的springboot 在application.properties中配置,使用@Value 获取的文件上传目录

MultipartFile file = multiReq.getFile("file");

String originalFilename = file.getOriginalFilename();

String suffix = originalFilename.substring(originalFilename.indexOf("."));

String localFileName = MD5Util.md5(file.getInputStream()) + suffix;

File localFile = new File(fileUploadPath + localFileName);

if (!localFile.exists()) {

localFile.createNewFile();

FileOutputStream fos = new FileOutputStream(

localFile);

FileInputStream fs = (FileInputStream) multiReq.getFile("img").getInputStream();

byte[] buffer = new byte[1024];

int len = 0;

while ((len = fs.read(buffer)) != -1) {

fos.write(buffer, 0, len);

}

fos.close();

fs.close();

} else {

log.info("文件已存在!!");

}

return WrapMapper.wrap(

Wrapper.SUCCESS_CODE,

Wrapper.SUCCESS_MESSAGE,

"http://localhost:8080/img/" + localFileName);//这里是我执行封装的返回结果,也可以使用map,

}

4.MD5工具类

import java.io.*;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

public class MD5Util {

private static char[] Digit = {'0', '1', '2', '3', '4', '5', '6', '7', '8',

'9', 'a', 'b', 'c', 'd', 'e', 'f'};

public static String getMd5Sum(String inputStr)

throws NoSuchAlgorithmException {

MessageDigest digest = MessageDigest.getInstance("MD5");

byte[] inputStrByte = inputStr.getBytes();

digest.update(inputStrByte, 0, inputStrByte.length);

byte[] md5sum = digest.digest();

StringBuffer sb = new StringBuffer();

for (int i = 0; i < 16; i++) {

char[] ob = new char[2];

ob[0] = Digit[md5sum[i] >> 4 & 0x0F];

ob[1] = Digit[md5sum[i] & 0x0F];

String s = new String(ob);

sb.append(s);

}

return sb.toString();

}

/**

  • 对字符串进行 MD5 加密

  • @param str

  •        待加密字符串
    
  • @return 加密后字符串

*/

public static String md5(String str) {

MessageDigest md5 = null;

try {

md5 = MessageDigest.getInstance("MD5");

md5.update(str.getBytes("UTF-8"));

} catch (NoSuchAlgorithmException e) {

throw new RuntimeException(e.getMessage());

} catch (UnsupportedEncodingException e) {

throw new RuntimeException(e.getMessage());

}

byte[] encodedValue = md5.digest();

int j = encodedValue.length;

char finalValue[] = new char[j * 2];

int k = 0;

for (int i = 0; i < j; i++) {

byte encoded = encodedValue[i];

finalValue[k++] = Digit[encoded >> 4 & 0xf];

finalValue[k++] = Digit[encoded & 0xf];

}

return new String(finalValue);

}

/**

  • 签名字符串

  • @param text

  •        需要签名的字符串
    
  • @param sign

  •        签名结果
    
  • @return 签名结果

*/

public static boolean verify(String text, String sign) {

String mysign = md5(text);

if (mysign.equals(sign)) {

return true;

} else {

return false;

}

}

/**

  • 对文件进行 MD5 加密

  • @param file

  •        待加密的文件
    
  • @return 文件加密后的 MD5 值

  • @throws IOException

*/

public static String md5(File file) throws IOException {

FileInputStream is = new FileInputStream(file);

return md5(is);

}

算法刷题

大厂面试还是很注重算法题的,尤其是字节跳动,算法是问的比较多的,关于算法,推荐《LeetCode》和《算法的乐趣》,这两本我也有电子版,字节跳动、阿里、美团等大厂面试题(含答案+解析)、学习笔记、Xmind思维导图均可以分享给大家学习。

写在最后

最后,对所以做Java的朋友提几点建议,也是我的个人心得:

  1. 疯狂编程

  2. 学习效果可视化

  3. 写博客

  4. 阅读优秀代码

  5. 心态调整

开源分享:docs.qq.com/doc/DSmRnRG…