Android Base64Encoder解决方案

Android Base64Encoder解决方案publicclassBase64Encoder{ privatestaticfinalcharlast2byte=(char)Integer .parseInt(“00000011”,2); privatestaticfinalcharlast4byte=(char)Integer .parseInt(“00001111”,2); pri…

大家好,又见面了,我是你们的朋友全栈君。

public class Base64Encoder {
	private static final char last2byte = (char) Integer
			.parseInt("00000011", 2);
	private static final char last4byte = (char) Integer
			.parseInt("00001111", 2);
	private static final char last6byte = (char) Integer
			.parseInt("00111111", 2);
	private static final char lead6byte = (char) Integer
			.parseInt("11111100", 2);
	private static final char lead4byte = (char) Integer
			.parseInt("11110000", 2);
	private static final char lead2byte = (char) Integer
			.parseInt("11000000", 2);
	private static final char[] encodeTable = new char[] { 'A', 'B', 'C', 'D',
			'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q',
			'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd',
			'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q',
			'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3',
			'4', '5', '6', '7', '8', '9', '+', '/' };
 
	/**
	 * Base64 encoding.
	 * 
	 * @param from
	 *            The src data.
	 * @return
	 */
	public static String encode(byte[] from) {
		StringBuffer to = new StringBuffer((int) (from.length * 1.34) + 3);
		int num = 0;
		char currentByte = 0;
		for (int i = 0; i < from.length; i++) {
			num = num % 8;
			while (num < 8) {
				switch (num) {
				case 0:
					currentByte = (char) (from[i] & lead6byte);
					currentByte = (char) (currentByte >>> 2);
					break;
				case 2:
					currentByte = (char) (from[i] & last6byte);
					break;
				case 4:
					currentByte = (char) (from[i] & last4byte);
					currentByte = (char) (currentByte << 2);
					if ((i + 1) < from.length) {
						currentByte |= (from[i + 1] & lead2byte) >>> 6;
					}
					break;
				case 6:
					currentByte = (char) (from[i] & last2byte);
					currentByte = (char) (currentByte << 4);
					if ((i + 1) < from.length) {
						currentByte |= (from[i + 1] & lead4byte) >>> 4;
					}
					break;
				}
				to.append(encodeTable[currentByte]);
				num += 6;
			}
		}
		if (to.length() % 4 != 0) {
			for (int i = 4 - to.length() % 4; i > 0; i--) {
				to.append("=");
			}
		}
		return to.toString();
	}
}

非常感谢:参天大树SJ

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148636.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月16日 上午8:58
下一篇 2022年6月16日 上午8:58


相关推荐

  • Eclipse的代码自动补全功能「建议收藏」

    Eclipse的代码自动补全功能「建议收藏」Eclipse的代码自动补全功能学习Java已有两个月的时间了,今天鼓起勇气尝试写第一篇CSDN博客,希望在帮助自己记录的同时能够帮助到有需要的朋友。众所周知Eclipse是一款非常智能的IDE工具,那么我们如何设置才能让它更为智能呢?本文主要介绍以下两点内容。Eclipse代码自动补全功能只按回车键来达到自动补全代码的目的要实现Eclipse的代码自动补全功能,我们需要这样设置…

    2022年5月31日
    68
  • AFL查看crash文件

    AFL查看crash文件AFL 查看导致 crash 的输入 AFL 想要复现一下崩溃时 发现 crash 文件夹里的文件是这样的 看到一个 txt 打开之后发现是这样的 设置什么 memory 各种搜索 设置各种 memory 然并卵 想着试一下那两个奇怪的文件 用 gedit 打开 怎么办呢 绝望之下尝试了用 cat 成功了 用 vim 也成功了 说明使用 vi 编辑文件是多么重要啊

    2026年3月18日
    2
  • 2026版国内国外主流AI大模型LLM API接口调用完整指南(附 Python/Java 对照代码)

    2026版国内国外主流AI大模型LLM API接口调用完整指南(附 Python/Java 对照代码)

    2026年3月12日
    2
  • SpringMVC工作原理及其流程

    SpringMVC工作原理及其流程本文介绍SpringMVC的基本原理,对于一个浏览器请求,SpringMVC的处理流程。SpringMVC主要包含一下组件DispatcherServlet-前端控制器HandlerMapping-处理器映射Controller-控制器ViewResolver-视图解析器View-视图Spring的请求流程SpringMVC的核心在于其请求流程,这是使用Spring…

    2022年5月14日
    40
  • 防抖节流基本原理及实现

    防抖节流基本原理及实现1 防抖 防抖是指在事件触发 n 秒后再执行回调 如果在 n 秒内再次被触发 则重新计算时间 就是在触发某个事件后 在下一次触发之前 中间的间隔时间如果超过设置的时间才会发送请求 一直触发就不会发送请求 实现代码如下 func 代表一个函数 里面可能会频繁发生回调或 ajax 请求 delay 表示隔多少秒触发才触发 immediate 表示是否立即执行 可传 true 或 false 默认 falsefunctio func delay immediate result 表示返回

    2026年3月18日
    2
  • 【Redis】Redis配置文件详解

    【Redis】Redis配置文件详解一、存放位置linux下一定要养成备份配置文件的习惯。我是将配置文件拷贝至/myredis目录下进行操作的;二、Units单位这个在配置文件开始位置1.配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit;2.对大小写不敏感。三、INCLUDES1.和Struts2配置文件类似,可以通过includes包含,redis.c…

    2022年6月7日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号