MD5 加密算法的使用
最近在看视频时,看到 MD5 的加密算法,感觉其在某些重要信息中,还是很好的解决了一些安全问题的。于是,就在自己理解的情况下,实现了 MD5 算法。
具体的流程大致是:
(1)将指定的数据首先通过 MessageDigest 类转为 MD5 的表现形式
(2)将 MD5 表现形式的数据,将其每个字节,转为 16 进制的表示方法
具体的实现方式如下:
/**
* 0.0.0.1
*/
package com.test.common; import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; import org.apache.log4j.Logger; /**
* MD5加密测试
* @author 高青
* 2014-4-21
*/
public class MD5Security { /** 日志对象 */
private static Logger log = Logger.getLogger(MD5Security.class); /** 十六进制数组 */
private static char[] hexArr = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'}; /**
* 构造方法
*/
public MD5Security() {
// TODO Auto-generated constructor stub
} /**
* 主线程方法
* @author 高青
* 2014-4-21
* @param args 字符串参数集
* @return 空
*/
public static void main(String[] args) {
//加密的信息
String securityInfo = "a"; try {
//通过 JAVA 的 Security 包,得到 MD5 表示方式 的字节数组
MessageDigest instance = MessageDigest.getInstance("MD5"); //此字节数据是 128 位的长整数,即是 16 个字节表示的数据
byte[] digest = instance.digest(securityInfo.getBytes()); //转换为 16 进制后的字节数组
char[] hexByte = new char[16*2];
//记录 当前计算后的字节在 十六进制字节数组中的位置
int k = 0; //循环遍历 MD5 中的每个字节,并将每个字节改成对应的 16 进制进行表示
for (int i = 0; i < 16; i++) { //计算当前字节的高四位所对应的十六进制数
hexByte[k++] = hexArr[digest[i] >>> 4 & 0xf]; //计算当前字节的低四位所对应的十六进制数
hexByte[k++] = hexArr[digest[i] & 0xf];
}
//将转化后的字符数组转为 String 类型
String hexString = new String(hexByte);
System.out.println(hexString); } catch (NoSuchAlgorithmException e) {
log.info("实例化 MessageDigest 对象异常!");
e.printStackTrace();
}
}
}
加密后的结果为:0cc175b9c0f1b6a831c399e269772661
MD5 加密算法的使用的更多相关文章
- 一起谈谈MD5加密算法
MD5是一个安全的散列算法,输入两个不同的明文不会得到相同的输出值,根据输出值,不能得到原始的明文,即其过程不可逆:所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后 ...
- MD5加密算法
package com.bao.tools.encryption; import java.security.MessageDigest;import java.security.NoSuchAlgo ...
- md5加密算法c语言版
from: http://blog.sina.com.cn/s/blog_693de6100101kcu6.html 注:以下是md5加密算法c语言版(16/32位) ---------------- ...
- MD5加密算法测试
在用户注册这一块,密码加密保证客户信息安全是最重要的,在网上查询了一些资料,发现加密算法比较流行的有MD5,DES和SHA. 虽然SHA与MD5通过碰撞法被破解了,但是MD5和SHA仍被公认是安全的加 ...
- 标准MD5加密算法
标准MD5加密算法: public class Md5 { public static String getMd5(String s) { char hexDigits[] = { '0', '1', ...
- MD5加密算法(java及js)
为了防止用户登陆过程中信息被拦截导致信息泄露,我们应该在客户端就对用户密码进行加密.浏览器提交给服务器的是加密后的信息,即使被恶意拦截,被拦截信息也已做了加密处理,现在比较安全的一种加密算法是MD5加 ...
- MD5加密算法的Java版本
网上搜索Java实现MD5的资料很多,错误的也很多. 之前编写的一个阿里云直播鉴权原理算法需要用到MD5算法,网上找了几个,都是不行,浪费了时间,现在贴一个,做备用. import java.secu ...
- JAVA实现MD5加密算法(使用MessageDigest)
http://blog.csdn.net/ymc0329/article/details/6738711 *********************************************** ...
- c++Builder XE6 MD5 加密算法 BASE64 URL 编码
xe6,xe7 BASE64XE6 MD5 加密算法Delphifunction MD5(const texto: string): string; var idmd5: TIdHashMessage ...
- MD5加密算法原理及其应用
MD5是一个安全的散列算法,输入两个不同的明文不会得到相同的输出值,根据输出值,不能得到原始的明文,即其过程不可逆:所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后 ...
随机推荐
- URL格式和urlencode
URL的格式:protocol :// hostname[:port] / path / [;parameters][?query]#fragment URL出现了有+,空格,/,?,%,#,& ...
- @angular/cli项目构建--路由2
app.module.ts update const routes: Routes = [ {path: '', redirectTo: '/home', pathMatch: 'full'}, {p ...
- nyoj-155-求高精度幂(java大数)
题目链接 import java.util.*; import java.math.*; public class Main{ public static void main(String[] arg ...
- nyoj-115-城市平乱(dijkstra算法)
题目链接 /* Name:nyoj-115-城市平乱 Copyright: Author: Date: 2018/4/25 17:28:06 Description: dijkstra模板题 枚举从 ...
- C++ 静态常量
#include<iostream> #include<stdexcept> #include <map> using namespace std; class n ...
- 树莓派(Linux)与镜像源
树莓派学习笔记--修改树莓派软件源 1. linux 镜像源文件 >> vim /etc/apt/sources.list 可在树莓派官网 http://www.raspbian.org/ ...
- Uncaught TypeError: this.canvas.getContext is not a function
/**************************************************************************** * Uncaught TypeError: ...
- linux 下安装rar解压
在liunx下原本是不支持rar文件的,需要安装liunx下的winrar版本,操作如下 wget http://www.rarsoft.com/rar/rarlinux-4.0.1.tar.gz t ...
- Linux 链接网络
目录 查看网卡 存在多个网卡 网卡配置静态IP 报错总结 诚邀访问我的个人博客:我在马路边 更好的阅读体验点击查看原文:Linux链接网络 原创博客,转载请注明出处 @ Linux在安装系统结束后总要 ...
- 1110. Complete Binary Tree (25)
Given a tree, you are supposed to tell if it is a complete binary tree. Input Specification: Each in ...