- 浏览: 194847 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (101)
- 职业 (4)
- 生活 (3)
- 场景应用 (6)
- flex (14)
- java (31)
- php (2)
- python (2)
- hadoop (6)
- 项目管理 (1)
- 工作流 (4)
- 手机web应用 (3)
- 算法 (4)
- 小技巧 (1)
- 数据库 (2)
- sphinx (1)
- web综合 (15)
- spring (5)
- 设计 (9)
- javascript (3)
- linux (2)
- 报表 (2)
- delphi (1)
- ejb (1)
- 架构 (3)
- uml (3)
- lucene (2)
- BI (1)
- 多线程 (1)
- 地图 (1)
- gis (1)
- 网络基础 (1)
- spark (2)
- 分布式 (3)
- ext (1)
- android (3)
- arduino (1)
- 协同办公 (2)
- OA流程 (2)
- 畅想 (1)
- ios (3)
- swift (1)
- webkit (1)
- c (1)
- 浏览器 (1)
- html5 (2)
- rtmp (1)
- soket (1)
- AI (2)
- tensorflow (1)
- ignite (1)
- react (4)
- 新空间 (2)
- 闲话 (3)
- docker (1)
- kubernetes (1)
最新评论
-
wenzhiyinghen:
...
spark 学习 -
zlbdexiaohao:
flex 写的时钟 -
minn84:
luoguohong88 写道你上传的那个openi.zip ...
openi1.3 eclipse 整合调试 -
luoguohong88:
你上传的那个openi.zip (5.5 MB)有问题 能再上 ...
openi1.3 eclipse 整合调试 -
minn84:
demo的思路很简单,主要是两点:1.hadoop负责处理数据 ...
hadoop+lucene+web 综合小demo
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.Signature;
public class SinatureTest {
private static final int KEYSIZE=512;
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
try
{
if(args[0].equals("-genkey"))
{
KeyPairGenerator pairgen=KeyPairGenerator.getInstance("DSA");
SecureRandom random=new SecureRandom();
pairgen.initialize(KEYSIZE, random);
KeyPair keyPair=pairgen.generateKeyPair();
ObjectOutputStream out=new ObjectOutputStream(new FileOutputStream(args[1]));
out.writeObject(keyPair.getPublic());
out.close();
out=new ObjectOutputStream(new FileOutputStream(args[2]));
out.writeObject(keyPair.getPrivate());
out.close();
}else if(args[0].equals("-sign"))
{
ObjectInputStream keyIn=new ObjectInputStream(new FileInputStream(args[3]));
PrivateKey privkey=(PrivateKey) keyIn.readObject();
keyIn.close();
Signature signalg=Signature.getInstance("DSA");
signalg.initSign(privkey);
File infile=new File(args[1]);
InputStream in=new FileInputStream(infile);
int length=(int) infile.length();
byte[] message=new byte[length];
in.read(message,0,length);
in.close();
signalg.update(message);
byte[] signature=signalg.sign();
DataOutputStream out=new DataOutputStream(new FileOutputStream(args[2]));
int signlength=signature.length;
out.writeInt(signlength);
out.write(signature,0,signlength);
out.write(message,0,length);
out.close();
}else if(args[0].equals("-verify"))
{
ObjectInputStream keyIn=new ObjectInputStream(new FileInputStream(args[2]));
PublicKey pubkey=(PublicKey) keyIn.readObject();
keyIn.close();
Signature verifyalg=Signature.getInstance("DSA");
verifyalg.initVerify(pubkey);
File infile=new File(args[1]);
DataInputStream in=new DataInputStream(new FileInputStream(infile));
int signlength=in.readInt();
byte[] signature=new byte[signlength];
in.read(signature,0,signlength);
int length=(int) (infile.length()-signlength-4);
byte[] message=new byte[length];
in.read(message,0,length);
in.close();
verifyalg.update(message);
if(!verifyalg.verify(signature))
{
System.out.println("not ");
}
System.out.println("verifid");
}
}catch(Exception e)
{
e.printStackTrace();
}
}
}
消息签名
1)javac *.java
2)java SignatureTest -genkey public.key private.key
3)java SignatureTest -sign sample.txt.signed private.key
4)java SignatureTest -verify sample.txt.signed public.key
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.Signature;
public class SinatureTest {
private static final int KEYSIZE=512;
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
try
{
if(args[0].equals("-genkey"))
{
KeyPairGenerator pairgen=KeyPairGenerator.getInstance("DSA");
SecureRandom random=new SecureRandom();
pairgen.initialize(KEYSIZE, random);
KeyPair keyPair=pairgen.generateKeyPair();
ObjectOutputStream out=new ObjectOutputStream(new FileOutputStream(args[1]));
out.writeObject(keyPair.getPublic());
out.close();
out=new ObjectOutputStream(new FileOutputStream(args[2]));
out.writeObject(keyPair.getPrivate());
out.close();
}else if(args[0].equals("-sign"))
{
ObjectInputStream keyIn=new ObjectInputStream(new FileInputStream(args[3]));
PrivateKey privkey=(PrivateKey) keyIn.readObject();
keyIn.close();
Signature signalg=Signature.getInstance("DSA");
signalg.initSign(privkey);
File infile=new File(args[1]);
InputStream in=new FileInputStream(infile);
int length=(int) infile.length();
byte[] message=new byte[length];
in.read(message,0,length);
in.close();
signalg.update(message);
byte[] signature=signalg.sign();
DataOutputStream out=new DataOutputStream(new FileOutputStream(args[2]));
int signlength=signature.length;
out.writeInt(signlength);
out.write(signature,0,signlength);
out.write(message,0,length);
out.close();
}else if(args[0].equals("-verify"))
{
ObjectInputStream keyIn=new ObjectInputStream(new FileInputStream(args[2]));
PublicKey pubkey=(PublicKey) keyIn.readObject();
keyIn.close();
Signature verifyalg=Signature.getInstance("DSA");
verifyalg.initVerify(pubkey);
File infile=new File(args[1]);
DataInputStream in=new DataInputStream(new FileInputStream(infile));
int signlength=in.readInt();
byte[] signature=new byte[signlength];
in.read(signature,0,signlength);
int length=(int) (infile.length()-signlength-4);
byte[] message=new byte[length];
in.read(message,0,length);
in.close();
verifyalg.update(message);
if(!verifyalg.verify(signature))
{
System.out.println("not ");
}
System.out.println("verifid");
}
}catch(Exception e)
{
e.printStackTrace();
}
}
}
消息签名
1)javac *.java
2)java SignatureTest -genkey public.key private.key
3)java SignatureTest -sign sample.txt.signed private.key
4)java SignatureTest -verify sample.txt.signed public.key
发表评论
-
多语言版基础管理系统展示[es6版]-入门配置篇
2018-10-26 07:17 517新增一篇入门配置文档 原文地址: http://www.i8 ... -
多语言版基础管理系统展示[es6版] -流程配置效果
2017-12-17 19:42 704终于找到一个可以较好展示工作流程配置的 ... -
多语言版基础管理系统展示[es6版]-简单整合spring+tensorflow+ignite+hadoop
2017-08-05 18:14 8121.整合基于[多语言版基础管理系统展示[es6版] ] ... -
多语言版基础管理系统展示[es6版]-简单整合tensorflow
2017-05-03 19:48 1002在大数据和AI渐渐兴起的时候,这是一个关于大 ... -
基于html5的websocket和rtmp协议的java socket服务器
2016-12-07 07:20 1056现代企事业单位中,会涉及到数据推送和获取服 ... -
多语言版基础管理系统展示[flash版]-hadoop+spark+spring简单整合
2016-06-18 21:36 4280本demo基于多语言版基础管理系统展示[fl ... -
ios简单的增删查例子
2015-02-23 16:08 834本例子分为两 ... -
spark 学习
2013-05-18 00:13 19168spark,又一个传说中的分布式实现,详情:ht ... -
基于rtmp协议的java多线程服务器
2013-03-31 21:34 3835打算设计这个半开源服务的计划已经有很长时间了,大 ... -
矩阵算法实现修改
2013-03-23 00:10 1000前段时间因为项目需要,需要实现一个据说是某高 ... -
hadoop+lucene+web 综合小demo
2013-03-02 01:28 13707很长一段时间没有关注hadoop,突然间有兴致,于是动手又 ... -
ejb3.x 简单小 demo
2012-02-21 21:07 1160本demo适合有一定编程经验的自学者 ,简单易懂,涉及数据 ... -
java综合
2012-02-11 22:00 1426以下自定义的简单类中,分析涉及的基础知识 / ... -
java nio应用 aes字符串加密与解密
2010-08-18 22:36 1958import java.io.IOException; imp ... -
java excel内容转换为键/值对基本通用方法与数据库导入
2010-06-01 23:28 1680有时候我们需要从execel中导入大量的数据,编程过程中就遇到 ... -
简单servlet socket 整合
2010-05-05 21:52 4337package filter; import java.io ... -
java写的简单生成sql语句的工具方法
2010-04-20 23:02 3428jdbc编程中,最麻烦的是拼sql语句,尤其是字段太多的时候, ... -
基于rtmp协议用java nio写小型游戏服务器的总结3
2010-03-05 20:59 2152在flex使用rtmp协议进行连接的时候,有个握手的过程,详情 ... -
基于rtmp协议用java nio写小型游戏服务器的总结2
2010-03-04 21:41 2271今天介绍一下学习rtmp的过程,首先当然是baidu和goog ... -
基于rtmp协议用java nio写小型游戏服务器的总结1
2010-03-03 22:55 2483前一阵子,进了一家公司,工作的内容是写基于rtmp协议的jav ...
相关推荐
java数字签名(签名生成,用证书验证签名)
JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字签名JAVA数字...
Java实现数字签名(ChinaSEI) 版权所有 郭克华 讲解详细,有实例,并且均可以测试通过!
开心的java超级签名系统,别人发的我也不知道那个版本了,这个java版当是别人1W多买的,java的不会搞就没搭建了,所以你也别来问我怎么搭建和演示了,截图是源码里的模板图,源码里附带部署说明。有需要的自行下载。...
java数字签名的讲解java数字签名的讲解java数字签名的讲解java数字签名的讲解
java JAR包签名java JAR包签名java JAR包签名java JAR包签名java JAR包签名
用Java数字签名提供XML安全.doc
别人那边考过来的 一款java艺术签名jar包
此项目基于java标准数字签名验签技术可直接二次开发
对Java Applet和Java Web Start进行数字签名
java数字签名,可以解决数字签名的问题。
用java 对文件进行签名验证的工具类,根据加密算法,把想要数字签名的文件传入,可自定义添加一些识别记号,返回该文件,再用工具类进行签名,之后再用返回后的文件跟生成的签名备份的文件进行比对,验证签名,以实现文件...
java简单实现验证签名
实现当前主流签名机制。 对请求参数进行排序 并添加协议key值 进行Md5加密
自己用JAVA写的数字签名程序,包括说明文档和截图。
java数字签名(签名生成,用证书验证签名)[定义].pdf
java md5的签名加密 和 C#的签名加密 Java开发或C#开发 Java和C#交互开发都能用的接口签名安全防护 自己java多年开发,大型项目中使用的接口安全措施
java通信安全主要包括:md5 密码加密与验证 对称加密与解密 非对称加密以解密 基于MD5信息摘要算法实现密码加密与验证 凯撒加密算法 数字签名与验证 消息验证码 消息摘要 所有程序都经过了测试
java数字签名(签名生成,用证书验证签名)[汇编].pdf
JAVA签名实例程序