Spring Base64Utils工具类使用

业务需求

在页面上使用截图插件直接得到了一串base64的字符串,直接存在数据库中查询非常慢,所以将base64转换成文件存储于磁盘上。

示例如下:
原图base64文本过大,故找了一张图转成base64后将base64再转存为其他图片,图片请自己查找

package com.ac.hdx.base.framework.utils;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

import org.apache.commons.lang3.StringUtils;
import org.springframework.util.Base64Utils;

public class Base64Util {
	
	public static void main(String[] args) {
		String imgBase64Str = Base64Util.ImageToBase64ByLocal("C:\\Users\\Administrator\\Desktop\\网络高并发负载均衡.jpg");
		
        System.out.println(imgBase64Str);
 
        boolean b = Base64Util.Base64ToImage(imgBase64Str,"C:\\Users\\Administrator\\Desktop\\test.jpg");
        System.out.println(b);
	}
	
    /**
     * 本地图片转换成base64字符串
     * @param imgFile	本地图片全路径 (注意:带文件名)
     *  (将图片文件转化为字节数组字符串,并对其进行Base64编码处理)
     * @return
     */
    public static String ImageToBase64ByLocal(String imgFile) {
 
 
        byte[] data = null;
 
        // 读取图片字节数组
        try {
            InputStream in = new FileInputStream(imgFile);
 
            data = new byte[in.available()];
            in.read(data);
            in.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
 
       // 返回Base64编码过的字节数组字符串
        return Base64Utils.encodeToString(data);
    }
 
 
 
 
    /**
     * base64字符串转换成图片 (对字节数组字符串进行Base64解码并生成图片)
     * @param imgStr		base64字符串
     * @param imgFilePath	指定图片存放路径  (注意:带文件名)
     * @return
     */
    public static boolean Base64ToImage(String imgStr,String imgFilePath) {
 
        if (StringUtils.isEmpty(imgStr)) // 图像数据为空
            return false;
 
        try {
            // Base64解码
            byte[] b = Base64Utils.decodeFromString(imgStr);
            for (int i = 0; i < b.length; ++i) {
                if (b[i] < 0) {// 调整异常数据
                    b[i] += 256;
                }
            }
 
            OutputStream out = new FileOutputStream(imgFilePath);
            out.write(b);
            out.flush();
            out.close();
 
            return true;
        } catch (Exception e) {
            return false;
        }
 
    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要解密一个字符串,我们需要先知道使用了什么算法进行加密。常见的加密算法有DES、AES等。这里我以AES算法为例进行解密。 首先,我们需要在Spring Boot中引入相关的依赖,如下: ```xml <!--引入AES算法依赖--> <dependency> <groupId>javax.crypto</groupId> <artifactId>jce</artifactId> <version>1.0.2</version> </dependency> ``` 接下来,我们需要编写一个解密函数,如下所示: ```java import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import java.nio.charset.StandardCharsets; import java.util.Base64; public class DecryptUtils { /** * 解密函数 * * @param content 待解密字符串 * @param key 解密密钥 * @param iv 解密向量 * @param algorithm 解密算法 * @return 解密后字符串 * @throws Exception 解密异常 */ public static String decrypt(String content, String key, String iv, String algorithm) throws Exception { // 将密钥和向量转为字节数组 byte[] keyBytes = key.getBytes(StandardCharsets.UTF_8); byte[] ivBytes = iv.getBytes(StandardCharsets.UTF_8); // 创建解密密钥 SecretKeySpec secretKeySpec = new SecretKeySpec(keyBytes, algorithm); // 创建解密向量 IvParameterSpec ivParameterSpec = new IvParameterSpec(ivBytes); // 创建解密器 Cipher cipher = Cipher.getInstance(algorithm + "/CBC/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec); // 对密文进行解密 byte[] encryptedBytes = Base64.getDecoder().decode(content); byte[] decryptedBytes = cipher.doFinal(encryptedBytes); return new String(decryptedBytes, StandardCharsets.UTF_8); } } ``` 这个函数接受四个参数,分别是待解密字符串、解密密钥、解密向量和解密算法。其中,解密密钥和解密向量需要转为字节数组,解密算法常见的有AES/CBC/PKCS5Padding,具体可以根据实际情况进行修改。 使用这个函数进行解密的示例代码如下所示: ```java public class Main { public static void main(String[] args) throws Exception { String content = "SjB0RnJjZGt6QWhhSzZZK3p2Q2hIQT09"; String key = "1234567890123456"; String iv = "1234567890123456"; String algorithm = "AES"; String decryptedContent = DecryptUtils.decrypt(content, key, iv, algorithm); System.out.println(decryptedContent); } } ``` 运行结果为:`K0tFrcdkzAhaKhK6zvChHA==`。 至此,我们就完成了字符串的解密。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值