Java加密和数字签名编程快速入门[Java编程]
本文“Java加密和数字签名编程快速入门[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
本文主要谈一下密码学中的加密和数字签名,以及其在java中若何举行利用.对密码学有爱好的搭档,举荐看Bruce Schneier的著作:Applied Crypotography.在jdk1.5的发行版本中安全性方面有了很大的改良,也供应了对RSA算法的直接支持,目前我们从实例动手办理问题(本文仅是作为简单介绍):
1、密码学上常用的概念
1)消息择要:
这是一种与消息认证码结合利用以确保消息完好性的技术.主要利用单向散列函数算法,可用于查验消息的完好性,和通过散列密码直接以文本情势保存等,目前遍及利用的算法有MD4、MD5、SHA-1,jdk1.5对上面都供应了支持,在java中举行消息择要很简单, java.security.MessageDigest供应了一个简易的操作办法:
/**
*MessageDigestExample.java
*Copyright 2005-2-16
*/
import java.security.MessageDigest;
/**
*单一的消息择要算法,不利用密码.可以用来对明文消息(如:密码)躲藏保存
*/
public class MessageDigestExample{
public static void main(String[] args) throws Exception{
if(args.length!=1){
System.err.println("Usage:java MessageDigestExample text");
System.exit(1);
}
byte[] plainText=args[0].getBytes("UTF8");
//利用getInstance("算法")来得到消息择要,这里利用SHA-1的160位算法
MessageDigest messageDigest=MessageDigest.getInstance("SHA-1");
System.out.println("
"+messageDigest.getProvider().getInfo());
//开始利用算法
messageDigest.update(plainText);
System.out.println("
Digest:");
//输出算法运算后果
System.out.println(new String(messageDigest.digest(),"UTF8"));
}
}
还可以通过消息认证码来举行加密实现,javax.crypto.Mac供应了一个办理筹划,有爱好者可以参考相关API文档,本文只是简单介绍什么是择要算法.
以上是“Java加密和数字签名编程快速入门[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |