网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.Jini技术基础结构.
.Java的垃圾回收机制研究.
.细述Java技术开发规则--开发篇.
.用Axis开发基于Java的Web服务.
.osworkflow源码分析(一).
.APPLET实例-从源代码到应用.
.Java编程实现列表框元素动态变化.
.使用J2SE API读取Properties文件.
.Java 的选择语句.
.通过WSDL决定Web服务是否支持XML.
.SUN系统维护命令大全.
.10年回顾:世界各地开发高手谈Java.
.Java Applet 编 程 技 巧.
.JBoss与Sun的Java标准之争日趋严.
.J2EE项目登录方式的改进设计与实.
.应用Rational 工具简化基于J2EE的.
.进阶:怎样使用AJAX进行WEB应用程.
.新手上路:JDBC初级应用实例(二).
.Javadoc 利弊分析.
.为什么Java中继承是有害的一.

JAVA上加密算法的实现用例(2)

发表日期:2008-1-5


 


添加要签名的信息

public final byte[] sign()
throws SignatureException
返回签名的数组,前提是initSign和update

public final void initVerify(PublicKey publicKey)
throws InvalidKeyException
用指定的公钥初始化
参数:publicKey 验证时用的公钥

public final boolean verify(byte[] signature)
throws SignatureException
验证签名是否有效,前提是已经initVerify初始化
参数: signature 签名数组
 */
import Java.security.*;
import java.security.spec.*;
public class testdsa {
 public static void main(String[] args) throws java.security.NoSUChAlgorithmException,java.lang.Exception {
       testdsa my=new testdsa();
       my.run();
 }
 public void run()
 {

 //数字签名生成密钥
 //第一步生成密钥对,假如已经生成过,本过程就可以跳过,对用户来讲myprikey.dat要保存在本地
 //而mypubkey.dat给发布给其它用户
  if ((new java.io.File("myprikey.dat")).exists()==false) {
      if (generatekey()==false) {
          System.out.println("生成密钥对败");
          return;
         };
       }
//第二步,此用户
//从文件中读入私钥,对一个字符串进行签名后保存在一个文件(myinfo.dat)中
//并且再把myinfo.dat发送出去
//为了方便数字签名也放进了myifno.dat文件中,当然也可分别发送
 try {
 java.io.ObjectInputStream in=new java.io.ObjectInputStream(new java.io.FileInputStream("myprikey.dat"));
 PrivateKey myprikey=(PrivateKey)in.readObject();
 in.close();

// java.security.spec.X509EncodedKeySpec pubX509=new java.security.spec.X509EncodedKeySpec(bX509);

//java.security.spec.X509EncodedKeySpec pubkeyEncode=java.security.spec.X509EncodedKeySpec
 String myinfo="这是我的信息";    //要签名的信息
 //用私钥对信息生成数字签名
 java.security.Signature signet=java.security.Signature.getInstance("DSA");
 signet.initSign(myprikey);
 signet.update(myinfo.getBytes());
 byte[] signed=signet.sign();  //对信息的数字签名
 System.out.println("signed(签名内容)="+byte2hex(signed));
//把信息和数字签名保存在一个文件中
 java.io.ObjectOutputStream out=new java.io.ObjectOutputStream(new java.io.FileOutputStream("myinfo.dat"));
 out.writeObject(myinfo);
 out.writeObject(signed);
 out.close();
 System.out.println("签名并生成文件成功");
 }
 catch (java.lang.Exception e) {
   e.printStackTrace();
   System.out.println("签名并生成文件失败");
 };

 //第三步
 //其他人通过公共方式得到此户的公钥和文件
 //其他人用此户的公钥,对文件进行检查,假如成功说明是此用户发布的信息.
 //
 try {

  java.io.ObjectInputStream in=new java.io.ObjectInputStream(new java.io.FileInputStream("mypubkey.dat"));
  PublicKey pubkey=(PublicKey)in.readObject();
  in.close();
  System.out.println(pubkey.getFormat());

  in=new java.io.ObjectInputStream(new java.io.FileInputStream("myinfo.dat"));
  String info=(String)in.readObject();
  byte[] signed=(byte[])in.readObject();
  in.close();

 java.security.Signature signetcheck=java.security.Signature.getInstance("DSA");
 signetcheck.initVerify(pubkey);
 signetcheck.update(info.getBytes());
 if (signetcheck.verify(signed)) {
 System.out.println("info="+info);
  System.out.println("签名正常");
 }
 else  System.out.println("非签名正常");
 }
 catch (java.lang.Exception e) {e.printStackTrace();};


 }

 //生成一对文件myprikey.dat和mypubkey.dat---私钥和公钥,
 //公钥要用户发送(文件,网络等方法)给其它用户,私钥保存在本地
 public boolean generatekey()
 {
   try {
 java.security.KeyPairGenerator  keygen=java.security.KeyPairGenerator.getInstance("DSA");
// SecureRandom secrand=new SecureRandom();
// secrand.setSeed("tttt".getBytes()); //初始化随机产生器
// keygen.initialize(576,secrand);     //初始化密钥生成器
 keygen.initialize(512);
 KeyPair keys=keygen.genKeyPair();
//  KeyPair keys=keygen.generateKeyPair(); //生成密钥组
 PublicKey pubkey=keys.getPublic();
 PrivateKey prikey=keys.getPrivate();

 java.io.ObjectOutputStream out=new java.io.ObjectOutputStream(new java.io.FileOutputStream("myprikey.dat"));
 out.writeObject(prikey);
 out.close();
 System.out.println("写入对象 prikeys ok");
 out=new java.io.ObjectOutputStream(new java.io.FileOutputStream("mypubkey.dat"));
  out.writeObject(pubkey);
  out.close();
  System.out.println("写入对象 pubkeys ok");
  System.out.println("生成密钥对成功");
  return true;
 }
 catch (java.lang.Exception e) {
  e.printStackTrace();
  System.out.println("生成密钥对失败");


上一篇:利用UDP Sockets技术实现IP多点传送 人气:693
下一篇:Java 编程技术中汉字问题的分析及解决 人气:574
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐