📄 signaturetest.java
字号:
/*
Name: SignatureTest.java
Licensing: LGPL
API: Sun (http://java.sun.com) JCE 1.2.2 API (cleanroom implementation by Bouncy Castle)
Provider: Bouncy Castle (http://www.bouncycastle.org)
Disclaimer:
COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY OF ANY KIND,
EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE
IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. THE ENTIRE
RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE IS WITH YOU. SHOULD ANY COVERED CODE
PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR)
ASSUME THE COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY
CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED
HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
(C) Copyright 2003 Gert Van Ham
*/
package net.sourceforge.jcetaglib.test;
import junit.framework.Assert;
import junit.framework.TestCase;
import net.sourceforge.jcetaglib.lib.Signatures;
import net.sourceforge.jcetaglib.lib.X509Cert;
import java.io.DataOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.security.PrivateKey;
import java.security.cert.X509Certificate;
/**
* A collection of SIG (siganture) tests
* <P>
* These tests can be run using JUnit (http://www.junit.org)
*
* @author Gert Van Ham
* @author hamgert@users.sourceforge.net
* @author http://jcetaglib.sourceforge.net
* @version $Id: SignatureTest.java,v 1.1 2003/12/28 19:06:57 hamgert Exp $
*/
public class SignatureTest extends TestCase {
private StringBuffer sig = null;
/**
* setup test
*
* @throws java.io.IOException
*/
protected void setUp() throws IOException {
// create text file
FileOutputStream outStr = new FileOutputStream(RunTest.TEMPFOLDER + "readable.txt");
DataOutputStream dataStr = new DataOutputStream(outStr);
dataStr.writeBytes("This is a readable string inside a file");
dataStr.flush();
dataStr.close();
outStr.close();
}
/**
* test Signature
*
* @throws Exception
*/
public void testSignature() throws Exception {
// load Alice's certificate
X509Certificate alicecert = X509Cert.getCertificateFromP12(RunTest.TEMPFOLDER + "alice.p12", "alice", new StringBuffer("password"));
// load Alice's private key to decrypt
PrivateKey aliceprivate = X509Cert.getPrivateFromP12(RunTest.TEMPFOLDER + "alice.p12", "alice", new StringBuffer("password"));
for (int i = 0; i < RunTest.sig.length; i++) {
for (int j = 0; j < RunTest.text.length; j++) {
sig = Signatures.generateSIG(RunTest.text[j], aliceprivate, RunTest.sig[i]);
Assert.assertTrue(Signatures.verifySIG(RunTest.text[j], sig, alicecert.getPublicKey(), RunTest.sig[i]));
}
}
}
/**
* test Signature from file
*
* @throws Exception
*/
public void testFileSignature() throws Exception {
// load Alice's certificate
X509Certificate alicecert = X509Cert.getCertificateFromP12(RunTest.TEMPFOLDER + "alice.p12", "alice", new StringBuffer("password"));
// load Alice's private key to decrypt
PrivateKey aliceprivate = X509Cert.getPrivateFromP12(RunTest.TEMPFOLDER + "alice.p12", "alice", new StringBuffer("password"));
for (int i = 0; i < RunTest.sig.length; i++) {
sig = Signatures.generateFileSIG(RunTest.TEMPFOLDER + "readable.txt", aliceprivate, RunTest.sig[i]);
Assert.assertTrue(Signatures.verifyFileSIG(RunTest.TEMPFOLDER + "readable.txt", sig, alicecert.getPublicKey(), RunTest.sig[i]));
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -