文章目录
- 前言
- 一、base64简介
- 二、使用步骤
- 1.引入pom依赖
- 2.文件转base64
- 3.base64转文件
- 总结
- 注意
前言
作为服务端会出现接收base64转换为文件,或将文件转换成base64的场景。
一、base64简介
Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法。
二、使用步骤
1.引入pom依赖
代码如下(示例):
cn.hutool hutool-all 5.8.10 2.文件转base64
代码如下(示例):
//注意导入的Base64 //import cn.hutool.core.codec.Base64; /** * 文件转base64 * @param absPath: 文件的绝对路径 * @return base64编码 异常时返回null */ public static String getBase64ByAbsPath(String absPath){ File file = new File(absPath); if(!file.exists()){ return null; } return Base64.eccode(file); }
3.base64转文件
代码如下(示例):
//注意导入的Base64 //import cn.hutool.core.codec.Base64; /** * base64转文件 并存在本地 * @param absPath base64转换文件后存储的绝对路径 * @param base64 要转换文件的base64编码 * @throws IOException */ public static void base64ToFile(String absPath, String base64)throws IOException{ byte[] decodedBytes = Base64.decode(base64); Files.write(Paths.get(absPath), decodedBytes); }
总结
注意Base64不要导错包,请使用
import cn.hutool.core.codec.Base64;
注意
当请求body中的base64过大时(超过1M),nginx有可能报错Request Entity Too Large
原因是nginx中默认配置body大小不超过1M。
需要更改nginx配置 client_max_body_size : 20M 并重启