ie8 java 上传图片,使用Webuploader和图片Base64特性完成IE8及其它浏览器的头像上传...

本文介绍了在Web环境中如何使用Webuploader实现图片上传,并针对大图进行压缩处理。通过makeThumb生成缩略图,获取BASE64编码,利用jQuery插件imgAreaSelect进行裁剪。在IE8下需要注意BASE64编码的大小限制,以及Java转换BASE64编码为图片时要去掉头部数据。同时,文章也提及了处理过程中遇到的问题及其解决方案。
摘要由CSDN通过智能技术生成

#获取BASE64 利用Webuploader获取所选图片的文件大小,如果图片过大设定一个压缩比例,然后利用API:makeThumb生成缩略图,并获取第一次缩略图的BASE64编码,并讲该编码放置为页面一个隐藏div的html代码,利用js的Image对象获取图片的原始尺寸

uploader.makeThumb(file, function (error, src) {

if (error) {

$('#headerImage').html("图片加载失败,请重新选择!");

return;

}

$('#id_img_file_type').val(file.ext);

var img = new Image();

img.onload = function () {

var width = img.width;

var height = img.height;

$('#id_img_src').html(src);

var showImgSize = cacluateShowImgSize(width, height);

showHeaderImg(showImgSize, file);

};

img.src = src;

}, compressPercent, compressPercent);

#利于jquery插件imgAreaSelect进行裁剪 利用将图片展示在页面上,然后进行相应的裁剪动作; #保存图片 提交base64编码、裁剪的四个定位数据,在后台生成图片并进行相应的裁剪,即可生成相应的头像图片。 #遇到的坑

ie8页面img的src如果为base64编码,最大只支持32KB的数据,所以可能js中要进行二次压缩,如果第一次压缩过剧,会影响头像最后的显示效果。 这就是开始时base64编码过大在页面产生的效果:

c60e6c6209a312f6fc5abd86bf66cac3.png

java转base64编码为图片,需要去掉编码前面的头数据,形如:“data:image/jpeg;base64,”,否则图片会转化失败。

public static File base64ToImage(String fileBasePath, String base64src, String fileType) {// 对字节数组字符串进行Base64解码并生成图片

if (base64src.indexOf(",") > 0) {

base64src = base64src.substring(base64src.indexOf(",") + 1);

}

String fileDir = fileBasePath + File.separator + "temp";

File targetDir = new File(fileDir);

if (!targetDir.exists()) {

targetDir.mkdirs();

}

File targetFile = new File(fileDir + File.separator + UUID.randomUUID().toString() + "." + fileType);

BASE64Decoder decoder = new BASE64Decoder();

try {

byte[] bytes = decoder.decodeBuffer(base64src);

for (int i = 0; i < bytes.length; ++i) {

if (bytes[i] < 0) {// 调整异常数据

bytes[i] += 256;

}

}

OutputStream out = new FileOutputStream(targetFile);

out.write(bytes);

out.flush();

out.close();

return targetFile;

} catch (Exception e) {

logger.error("base64转图片失败", e);

return null;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值