base64算法的加解密处理

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介:

base64分两个:一个是base64针对邮件传输的算法。另外一个就是为了在浏览器中传送加密数据或者隐藏表单中用的加密数据,防止大家直接用肉眼从页面中看到数据内容而采用的URL base64。其实只要是我们想让加密数据可逆,或者想将数据不让别人用肉眼就分辨出来,就可以用base64的算法。一些机构给客户的签名值都使用base64加密后提供.

  关于urlbase64算法,目前没定义,不过我们可以参考rfc 4648的规范要求

 

 详细介绍参见:http://baike.baidu.com/view/469071.htm

 

 base64算法是一个违反加密原则的加密算法。

 加密原则:公布算法,但是不公布密钥

 但是base64是即公布算法又公布了转换的密钥。不过我们可以通过改进base64算法来提升base64的实用性。

 

 关于实现:

 jdk6有sun公司内部使用base64算法的实现,这里不推荐使用,因为用他们内部的实现,编译提示错误。说不定哪天丢失

 这里推荐使用Bouncy Castle的实现或者apache的commons codec的实现。

 (1)、Bouncy Castle的实现跟rfc的标准略有出入

 (2)、commons codec的实现紧密追随rfc2045的文档

 

 举例尝试Bouncy Castle的加解密算法:

1、base64的算法实现

package com.ca.test;
import java.security.Security;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Base64;
/**
 * 
 * 使用bouncycastle扩展包进行base64为编码
 * @kongqz
 * **/
public class Base64Coder {
	
	
	public final static String ENCODING="UTF-8";
	/***
	 * 进行base64编码
	 * @param data 要编码的数据
	 * @return 编码后的数据
	 * */
	public static String encode(String data) throws Exception{
		
		Security.addProvider(new BouncyCastleProvider());
		
		byte[] b =Base64.encode(data.getBytes(ENCODING));
		return new String(b,ENCODING);
	}
	
	/**
	 * 进行Base64解码
	 * @param data 待解码数据
	 * @return 解码后的数据
	 * */
	public static String decode(String data) throws Exception{
		
		Security.addProvider(new BouncyCastleProvider());
		
		byte[] b=Base64.decode(data.getBytes(ENCODING));
		return new String(b,ENCODING);
	}
	/**
	 * @param args
	 * @throws Exception 
	 */
	public static void main(String[] args) throws Exception {
		
		String tmp="java的base64位加解密操作";
		System.out.println("原文:"+tmp);
		
		String code=Base64Coder.encode(tmp);
		System.out.println("编码后:"+code);
		
		System.out.println("解码后:"+Base64Coder.decode(code));
	}
}
控制台输出的结果为:

原文:java的base64位加解密操作
编码后:amF2YeeahGJhc2U2NOS9jeWKoOino+WvhuaTjeS9nA==
解码后:java的base64位加解密操作

对比后我们可以发现一个问题,就是urlbase64算法就是将浏览器中不允许出现的+=号给替换成-.这些符号

目录
相关文章
|
6月前
|
算法 安全 Java
Java 实现 RSA 非对称加密算法-加解密和签名验签
Java 实现 RSA 非对称加密算法-加解密和签名验签
257 0
|
存储 算法 BI
经典加解密算法——香农算法介绍(附源码!)
经典加解密算法——香农算法介绍(附源码!)
204 0
经典加解密算法——香农算法介绍(附源码!)
|
6月前
|
算法 Java
Java使用Cipher.getInstance(“AES/ECB/PKCS5Padding“);加解密算法工具类实现
Java使用Cipher.getInstance(“AES/ECB/PKCS5Padding“);加解密算法工具类实现
577 0
|
5月前
|
算法 安全 Java
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
|
5月前
|
算法 安全 Java
AES加解密算法:原理、应用与安全性解析
AES加解密算法:原理、应用与安全性解析
|
6月前
|
XML 存储 算法
BASE64的算法说明
【5月更文挑战第10天】BASE64的算法说明
55 3
|
6月前
|
算法 数据安全/隐私保护 数据格式
基于混沌序列的图像加解密算法matlab仿真,并输出加解密之后的直方图
该内容是一个关于混沌系统理论及其在图像加解密算法中的应用摘要。介绍了使用matlab2022a运行的算法,重点阐述了混沌系统的特性,如确定性、非线性、初值敏感性等,并以Logistic映射为例展示混沌序列生成。图像加解密流程包括预处理、混沌序列生成、数据混淆和扩散,以及密钥管理。提供了部分核心程序,涉及混沌序列用于图像像素的混淆和扩散过程,通过位操作实现加密。
|
6月前
|
移动开发 算法 安全
安卓逆向 -- 算法基础(Base64与HEX)
安卓逆向 -- 算法基础(Base64与HEX)
37 1
|
6月前
|
存储 算法 安全
C/C++学习 -- Base64算法
C/C++学习 -- Base64算法
63 0
|
存储 算法 安全
C/C++学习 -- Base64算法
C/C++学习 -- Base64算法
67 0