base64转图片和原始图大小有出入,直接上代码

/**
 * base64字符串转化成图片
 * @param imgData base64图片编码
 * @param imgFilePath 存放到本地路径
 * @return
 * @throws IOException
 */
public static boolean generateImage(String imgData, String imgFilePath) throws IOException { // 对字节数组字符串进行Base64解码并生成图片
    if (imgData == null) {
        return false;
    }
    BASE64Decoder decoder = new BASE64Decoder();
    OutputStream out = null;
    try {
        out = new FileOutputStream(imgFilePath);
        // Base64解码
        byte[] b = decoder.decodeBuffer(imgData);
        for (int i = 0; i < b.length; ++i) {
            if (b[i] < 0) {
                b[i] += 256;
            }
        }
        out.write(b);
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        out.flush();
        out.close();
        return true;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个将Base64编码换为图片JavaScript代码示例: ```javascript function base64ToImage(base64Data, filename) { var mimeType, byteString; if (base64Data.split(',')[0].indexOf('base64') !== -1) { byteString = atob(base64Data.split(',')[1]); mimeType = base64Data.split(',')[0].split(':')[1].split(';')[0]; } else { byteString = unescape(base64Data.split(',')[1]); mimeType = base64Data.split(',')[0].split(':')[1].split(';')[0]; } var arrayBuffer = new ArrayBuffer(byteString.length); var uintArray = new Uint8Array(arrayBuffer); for (var i = 0; i < byteString.length; i++) { uintArray[i] = byteString.charCodeAt(i); } var blob = new Blob([arrayBuffer], { type: mimeType }); if (window.navigator && window.navigator.msSaveOrOpenBlob) { // For IE window.navigator.msSaveOrOpenBlob(blob, filename); } else { // For other browsers var objectUrl = URL.createObjectURL(blob); var link = document.createElement('a'); link.href = objectUrl; link.download = filename || 'image.png'; link.click(); URL.revokeObjectURL(objectUrl); } } // 使用示例 var base64Data = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUA' + 'AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO' + '9TXL0Y4OHwAAAABJRU5ErkJggg=='; var filename = 'image.png'; base64ToImage(base64Data, filename); ``` 你可以将需要换的Base64编码作为`base64Data`参数传递给`base64ToImage`函数,还可以选择性地传递一个文件名作为`filename`参数。该函数将在浏览器中下载图片。如果你使用的是IE浏览器,将会使用不同的方法进行处理。 请注意,在这个示例中,你需要提供一个完整的Base64编码(包括数据类型和前缀),以及一个文件名(可选)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值