base64算法的加解密处理

简介:

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算法就是将浏览器中不允许出现的+=号给替换成-.这些符号

目录
相关文章
|
2月前
|
算法 安全 Java
Java 实现 RSA 非对称加密算法-加解密和签名验签
Java 实现 RSA 非对称加密算法-加解密和签名验签
|
7月前
|
存储 算法 BI
经典加解密算法——香农算法介绍(附源码!)
经典加解密算法——香农算法介绍(附源码!)
94 0
经典加解密算法——香农算法介绍(附源码!)
|
2月前
|
移动开发 算法 安全
安卓逆向 -- 算法基础(Base64与HEX)
安卓逆向 -- 算法基础(Base64与HEX)
14 1
|
3月前
|
存储 算法 安全
C/C++学习 -- Base64算法
C/C++学习 -- Base64算法
20 0
|
6月前
|
算法 搜索推荐 安全
20.3 OpenSSL 对称AES加解密算法
AES算法是一种对称加密算法,全称为高级加密标准(Advanced Encryption Standard)。它是一种分组密码,以`128`比特为一个分组进行加密,其密钥长度可以是`128`比特、`192`比特或`256`比特,因此可以提供不同等级的安全性。该算法采用了替代、置换和混淆等技术,以及多轮加密和密钥扩展等机制,使得其加密效果优秀,安全性高,被广泛应用于各种领域中,如数据加密、文件加密、网络安全等。
79 0
20.3 OpenSSL 对称AES加解密算法
|
6月前
|
算法 数据安全/隐私保护
20.2 OpenSSL 非对称RSA加解密算法
RSA算法是一种非对称加密算法,由三位数学家`Rivest`、`Shamir`和`Adleman`共同发明,以他们三人的名字首字母命名。RSA算法的安全性基于大数分解问题,即对于一个非常大的合数,将其分解为两个质数的乘积是非常困难的。OpenSSL库中提供了针对此类算法的支持,但在使用时读者需要自行生成公钥与私钥文件,在开发工具包内有一个`openssl.exe`程序,该程序则是用于生成密钥对的工具,当我们需要使用非对称加密算法时,则可以使用如下命令生成公钥和私钥。
46 0
20.2 OpenSSL 非对称RSA加解密算法
|
6月前
|
存储 算法 安全
C/C++学习 -- Base64算法
C/C++学习 -- Base64算法
39 0
|
6月前
|
数据采集 JavaScript 前端开发
“探秘JS加密算法:MD5、Base64、DES/AES、RSA你都知道吗?”
“探秘JS加密算法:MD5、Base64、DES/AES、RSA你都知道吗?”
111 0
|
10月前
|
算法 数据安全/隐私保护
基于Logistic混沌序列的图像加解密算法matlab仿真
基于Logistic混沌序列的图像加解密算法matlab仿真
168 0
|
10月前
|
算法 Java
java的DES和3DES加解密算法
java的DES和3DES加解密算法