zoukankan      html  css  js  c++  java
  • BASE64和图片之间的互相转换

    package com.test.demo;
    
    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.OutputStream;
    
    import sun.misc.BASE64Decoder;
    import sun.misc.BASE64Encoder;
    
    public class TestChangeImage {
    
    	public static void main(String[] args) {
    		String strImg = GetImageStr();
    		System.out.println(strImg);
    		System.out.println(strImg.length());
    		GenerateImage(strImg);
    	}
    
    	// 图片转化成base64字符串
    	public static String GetImageStr() {// 将图片文件转化为字节数组字符串,并对其进行Base64编码处理
    		String imgFile = "C:/Users/Administrator/Desktop/timg.jpg";// 待处理的图片
    		InputStream in = null;
    		byte[] data = null;
    		// 读取图片字节数组
    		try {
    			in = new FileInputStream(imgFile);
    			data = new byte[in.available()];
    			in.read(data);
    			in.close();
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    		// 对字节数组Base64编码
    		BASE64Encoder encoder = new BASE64Encoder();
    		return encoder.encode(data);// 返回Base64编码过的字节数组字符串
    	}
    
    	// base64字符串转化成图片
    	public static boolean GenerateImage(String imgStr) { // 对字节数组字符串进行Base64解码并生成图片
    		if (imgStr == null) // 图像数据为空
    			return false;
    		BASE64Decoder decoder = new BASE64Decoder();
    		try {
    			// Base64解码
    			byte[] b = decoder.decodeBuffer(imgStr);
    			for (int i = 0; i < b.length; ++i) {
    				if (b[i] < 0) {// 调整异常数据
    					b[i] += 256;
    				}
    			}
    			// 生成jpeg图片
    			String imgFilePath = "C:/Users/Administrator/Desktop/test22.jpg";// 新生成的图片
    			OutputStream out = new FileOutputStream(imgFilePath);
    			out.write(b);
    			out.flush();
    			out.close();
    			return true;
    		} catch (Exception e) {
    			return false;
    		}
    	}
    }
    

      

      需要下载base64JAR包

  • 相关阅读:
    微信小程序-开发入门(一)
    Vue入门
    美化input type=range标签滑动样式(带渐变效果)
    全新的css网站布局--Grid布局
    移动端布局与样式上的坑
    swiper 下拉刷新混乱
    子元素scroll父元素容器不跟随滚动JS实现
    解决前端页面闪烁问题(转载)
    VUE 与其他常见前端框架对比
    移动端表层div滑动,导致底层body滑动(touchmove的阻止)
  • 原文地址:https://www.cnblogs.com/woshuaile/p/7891077.html
Copyright © 2011-2022 走看看