前端js 生成的base64位图片怎样在后端 java

发布时间:2021-10-19 17:06:57 作者:柒染
来源:亿速云 阅读:155

前端js 生成的base64位图片怎样在后端 java,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

// 1.需要引入的包

import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

import javax.imageio.ImageIO;

import com.google.zxing.BinaryBitmap;
import com.google.zxing.MultiFormatReader;
import com.google.zxing.client.j2se.BufferedImageLuminanceSource;
import com.google.zxing.common.HybridBinarizer;

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

// 2. 用到的方法:

/**
     * 图片转BASE64
     * @param imagePath 路径
     * @return
     */
    public static String imageChangeBase64(String imagePath){
        InputStream inputStream = null;
        byte[] data = null;
        try {
            inputStream = new FileInputStream(imagePath);
            data = new byte[inputStream.available()];
            inputStream.read(data);
            inputStream.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        // 加密
        BASE64Encoder encoder = new BASE64Encoder();
        return encoder.encode(data);
    }
    
    /**
     * BASE转图片
     * @param baseStr  base64字符串
     * @param imagePath 生成的图片
     * @return
     */
    public static boolean base64ChangeImage(String baseStr,String imagePath){
        if (baseStr == null){
            return false;
        }
        BASE64Decoder decoder = new BASE64Decoder();
        try {
            // 解密
            byte[] b = decoder.decodeBuffer(baseStr);
            // 处理数据
            for (int i = 0; i < b.length; ++i) {
                if (b[i] < 0) {
                    b[i] += 256;
                }
            }
            OutputStream out = new FileOutputStream(imagePath);
            out.write(b);
             out.flush();
            out.close();
            return true;
        } catch (Exception e) {
            return false;
        }
    }

// 3 解析测试的方法:

public static void test1(){

// 要生成的图片的地址

 String pp = imageChangeBase64("E:\\58744.jpg");

// 打印生成的base64位置编码
        System.out.println("pp:"+pp);

  String pp3=""; // 此处省略为前端返给你的base64图片码,

      base64ChangeImage(pp2.split(",")[1],"E:\\bb.jpg");
 

}

// 将图片生成base64位的网络地址:

http://imgbase64.duoshitong.com/

关于前端js 生成的base64位图片怎样在后端 java问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

推荐阅读:
  1. Android中WebView与H5前端JS代码交互的示例分析
  2. webpack中如何打包压缩js和css文件

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js java

上一篇:VUE uni-app开发环境是什么

下一篇:jquery如何实现百叶窗效果

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》