十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
前端js 生成的base64位图片怎样在后端 java,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
专业从事企业网站建设和网站设计服务,包括网站建设、国际域名空间、网页空间、企业邮箱、微信公众号开发、微信支付宝成都微信小程序、手机APP定制开发、软件开发、等服务。公司始终通过不懈的努力和以更高的目标来要求自己,在不断完善自身管理模式和提高技术研发能力的同时,大力倡导推行新经济品牌战略,促进互联网事业的发展。
// 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问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。