序言
Java 8 内置了 Base64 编码的编码器和解码器. 类目录:java.util.Base64
Base64工具类提供了一套静态方法获取下面三种BASE64编解码器:
- 基本:输出被映射到一组字符A-Za-z0-9+/,编码不添加任何行标,输出的解码仅支持A-Za-z0-9+/。(用于编解码我们一般的信息)
- URL:输出映射到一组字符A-Za-z0-9+_,输出是URL和文件。(用于编解码URL字符串,区别就是把会把URL中的"/"编码成"_")
- MIME:输出隐射到MIME友好格式。输出每行不超过76字符,并且使用'\r'并跟随'\n'作为分割。编码输出最后没有行分割。(适用于源码很长的编解码,每一行输出不超过76个字符,而且每行以“\r\n”符结束。)
该类实现一个解码器用于,使用 Base64 编码来解码字节数据。
2static class Base64.Encoder该类实现一个编码器,使用 Base64 编码来编码字节数据。
对应不同的编解码器 序号方法名 & 描述1static Base64.Decoder getDecoder()返回一个 Base64.Decoder ,解码使用基本型 base64 编码方案。
2static Base64.Encoder getEncoder()返回一个 Base64.Encoder ,编码使用基本型 base64 编码方案。
3static Base64.Decoder getMimeDecoder()返回一个 Base64.Decoder ,解码使用 MIME 型 base64 编码方案。
4static Base64.Encoder getMimeEncoder()
返回一个 Base64.Encoder ,编码使用 MIME 型 base64 编码方案。
5static Base64.Encoder getMimeEncoder(int lineLength, byte[] lineSeparator)返回一个 Base64.Encoder ,编码使用 MIME 型 base64 编码方案,可以通过参数指定每行的长度及行的分隔符。
6static Base64.Decoder getUrlDecoder()返回一个 Base64.Decoder ,解码使用 URL 和文件名安全型 base64 编码方案。
7static Base64.Encoder getUrlEncoder()返回一个 Base64.Encoder ,编码使用 URL 和文件名安全型 base64 编码方案。
代码package nan.yao.cui;
import java.io.UnsupportedEncodingException;
import java.math.BigDecimal;
import java.nio.charset.StandardCharsets;
import java.time.LocalTime;
import java.util.Base64;
import java.util.UUID;
import java.util.concurrent.ExecutionException;
import java.util.function.Predicate;
/**
* @author 崔耀男
* @des: TODO
* @date 2020年5月14日 下午5:39:33
* @package nan.yao.cui
*/
public class Test {
public static void main(String[] args) throws UnsupportedEncodingException {
//基本编解码
//编码
String basicencode = Base64.getEncoder().encodeToString("http://daxigua/11?123123=1212+/!@#$%^%^&*".getBytes(StandardCharsets.UTF_8));
System.out.println(basicencode);
//解码
System.out.println(new String(Base64.getDecoder().decode(basicencode.getBytes(StandardCharsets.UTF_8)),"utf-8"));
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
//URL编解码
//编码
basicencode = Base64.getUrlEncoder().encodeToString("http://daxigua/11?123123=1212+/!@#$%^%^&*".getBytes(StandardCharsets.UTF_8));
System.out.println(basicencode);
//解码
System.out.println(new String(Base64.getUrlDecoder().decode(basicencode.getBytes(StandardCharsets.UTF_8)),"utf-8"));
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
//Mime编解码
//编码
basicencode = Base64.getMimeEncoder().encodeToString("http://daxigua/11?123123=1212+/!@#$%^%^&*".getBytes(StandardCharsets.UTF_8));
System.out.println(basicencode);
//解码
System.out.println(new String(Base64.getMimeDecoder().decode(basicencode.getBytes(StandardCharsets.UTF_8)),"utf-8"));
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
System.out.println("华丽的分隔");
//如果是比较产的字符串使用一般编解码就不看,如果使用mime编解码则会自动进行跨行
StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < 10; ++i) {
stringBuilder.append(UUID.randomUUID().toString());
}
basicencode = Base64.getEncoder().encodeToString(stringBuilder.toString().getBytes(StandardCharsets.UTF_8));
System.out.println(basicencode);
//解码
System.out.println(new String(Base64.getDecoder().decode(basicencode.getBytes(StandardCharsets.UTF_8)),"utf-8"));
}
}