环境 vs2005 c++ windows mobile6 从一个后缀名为keystore的文件中提取证书,通过此证书访问https的网页

作者&投稿:种耐 (若有异议请与网页底部的电邮联系)
SSL中,公钥,私钥,证书的后缀名都是些啥~

Apache、Nginx环境下:公钥:.KEY私钥:.KEY证书:.CRT或者.PEM(两者都可以)概括:无论是根证书还是证书后缀都是.CRT。IIS环境:.pfxJKS环境:.JKS概括:IIS或者JKS安装证书有对应格式文件需要向Gworg机构索取:网页链接

首先,VS2005、Windows Mobile 6 Professional SDK与Win7是没有兼容性问题的。其次,mscorpe.dll是.Net Framwork的组成部分之一,安装VS2005会安装.Net Framwork2.0,但由于Win7自带.Net Framwork3.5,可能会跳过安装。建议重新安装或修复VS2005。亦可手动安装.net

可以用以下方法:
方法一:keytool -genkey -alias test -keyalg RSA -keystore c:/key.store
生成keyStore
RSA是一个既能用于数据加密也能用于数字签名的算法。
DSA(Digital Signature Algorithm,数字签名算法,用作数字签名标准的一部分),它是另一种公开密钥算法,它不能用作加密,只用作数字签名。DSA使用公开密钥,为接受者验证数据的完整性和数据发送者的身份。
提取证书:
通过keytool命令我们可以很轻松的提取证书.
证书包括主体信息,公钥.
keytool -export -alias 别名 -keystore 文件名 -file 证书名称

但是我们无法通过KEYTOOL工具来提取私钥的..我们只能通过java的KeyStore类getEntry() 或者getKey()来提取私钥.
读取keyStore文件:
char[] password = "password".toCharArray();
java.io.FileInputStream fis = new java.io.FileInputStream("c:/server/server_keystore");
// 从指定的输入流中加载此 KeyStore
ks.load(fis, password);
//keystore 中的每一项都用“别名”字符串标识。
//使用指定保护参数获取指定别名的 keystore Entry。
//KeyStore.PrivateKeyEntry 保存 PrivateKey 和相应证书链的 KeyStore 项。
方法1. KeyStore.PrivateKeyEntry pkEntry = (KeyStore.PrivateKeyEntry) ks.getEntry("keystore别名",new KeyStore.PasswordProtection(password));// 返回与给定别名相关联的密钥
方法2. PrivateKey key = (PrivateKey) ks.getKey("ser", password);
怎么来验证提取的私钥是否正确呢?(因为公钥私钥必须成对出现,我们可以通过证书提取去公钥,然后用公钥加密,使用刚刚获得的私钥解密)
提取证书的方法:
keytool -export -alias 别名 -keystore 文件名 -file 证书名称
//通过证书,获取公钥
CertificateFactory cf = CertificateFactory.getInstance("X.509");
FileInputStream in = new FileInputStream("C:\\server\\server.cer");
//生成一个证书对象并使用从输入流 inStream 中读取的数据对它进行初始化。
Certificate c = cf.generateCertificate(in);
PublicKey publicKey = c.getPublicKey();
//通过下面这段代码提取的私钥是否正确
String before = "asdf";
byte[] plainText = before.getBytes("UTF-8");
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
// 用公钥进行加密,返回一个字节流
byte[] cipherText = cipher.doFinal(plainText);
cipher.init(Cipher.DECRYPT_MODE, myPrivateKey);
// 用私钥进行解密,返回一个字节流
byte[] newPlainText = cipher.doFinal(cipherText);
System.out.println(new String(newPlainText, "UTF-8"));
方法二: 下面是英文:
1.import java.io.File;
2.import java.io.FileInputStream;
3.import java.io.FileWriter;
4.import java.security.Key;
5.import java.security.KeyPair;
6.import java.security.KeyStore;
7.import java.security.KeyStoreException;
8.import java.security.NoSuchAlgorithmException;
9.import java.security.PrivateKey;
10.import java.security.PublicKey;
11.import java.security.UnrecoverableKeyException;
12.import java.security.cert.Certificate;
13.
14.import sun.misc.BASE64Encoder;
15.
16.public class ExportPrivateKey {
17. private File keystoreFile;
18. private String keyStoreType;
19. private char[] password;
20. private String alias;
21. private File exportedFile;
22.
23. public static KeyPair getPrivateKey(KeyStore keystore, String alias, char[] password) {
24. try {
25. Key key=keystore.getKey(alias,password);
26. if(key instanceof PrivateKey) {
27. Certificate cert=keystore.getCertificate(alias);
28. PublicKey publicKey=cert.getPublicKey();
29. return new KeyPair(publicKey,(PrivateKey)key);
30. }
31. } catch (UnrecoverableKeyException e) {
32. } catch (NoSuchAlgorithmException e) {
33. } catch (KeyStoreException e) {
34. }
35. return null;
36. }
37.
38. public void export() throws Exception{
39. KeyStore keystore=KeyStore.getInstance(keyStoreType);
40. BASE64Encoder encoder=new BASE64Encoder();
41. keystore.load(new FileInputStream(keystoreFile),password);
42. KeyPair keyPair=getPrivateKey(keystore,alias,password);
43. PrivateKey privateKey=keyPair.getPrivate();
44. String encoded=encoder.encode(privateKey.getEncoded());
45. FileWriter fw=new FileWriter(exportedFile);
46. fw.write(“—–BEGIN PRIVATE KEY—–\n“);
47. fw.write(encoded);
48. fw.write(“\n“);
49. fw.write(“—–END PRIVATE KEY—–”);
50. fw.close();
51. }
52.
53.
54. public static void main(String args[]) throws Exception{
55. ExportPrivateKey export=new ExportPrivateKey();
56. export.keystoreFile=new File(args[0]);
57. export.keyStoreType=args[1];
58. export.password=args[2].toCharArray();
59. export.alias=args[3];
60. export.exportedFile=new File(args[4]);
61. export.export();
62. }
63.}
或者:方法三:
证书用这个命令:
keytool -export -alias <alias> -flie <cert_file_name>
证书可是的扩展名用cer,然后在windows打开,可以改变证书的存储格式。
私钥好像不能导出来吧,不是很清楚。
配置ssl不需要导出秘钥和证书,tomcat直接可以使用keystore

首先 不能使用java的类库. 除非你使用了JNI 但是与其这样, 不如直接使用JAVA

第二 访问https 可以使用OpenSSL, keystore文件中的证书只是个密钥. 提取出来后完全可以用一般的SSL方式进行post或者get连接

代码互联网上有的是...


华池县19780128507: 装好VS2005 然后第一次启动的时候 选择的运行环境是C# 现在需要用C++来写 如果到哪里修改啊? -
金食益可: 具体步骤如下:1.在Visual Studio 2005中选择 工具-> 导入和导出设置 菜单;2.选择 重置所有设置 选项,单击 下一步 按钮;3.选择 是否 要保存当前设置,单击 下一步 按钮;4.选择你要设置的语言(Visual C#开发设置),单击完成按钮.

华池县19780128507: VS2005的工作环境怎么转换?就是从用C#转换到用VC++? -
金食益可: 安装完成Visual Studio 2005 (VS2005) 后,第一次启动时会弹出一个“选择默认环境设置”的窗口,“以后再也不出来”(这是错误的,其实在这个窗口中已经写明“重置所有设置”的操作方法,只是很少人注意到而已). 操作步骤: 1.打开 VS2005 进入IDE,选择 工具 -> 导入导出设置... 打开导入导出设置向导; 2.选择 重置所有设置,在保存当前设置做您想做的; 3.然后就出来您想要的窗口了.

华池县19780128507: microsoft visual studio2005怎么使用? -
金食益可: 你可以直接选择环境为C++开发人员;导入和导出设置";重置所有设置"点下一步,保不保存就看你了,但如果你第一次不是选择的他(可能你是选择的学生开发环境)那你可以这样操作: 打开visual studio2005,工具菜单中选择&quot如果你是第一次启动visual studio2005.再选择C++环境再重启一下软件就OK啦.在弹出的对话框中选择"

华池县19780128507: vs2005用c++ 创建windows窗体应用程序 怎么定义数组 -
金食益可: 尝试 int *a=new int[5]; ******************************************** 用new分配的动态数组和自动数组的访问方法是一样的,如:int *a; 然后在构造函数中有如下语句:a=new int[5]; 之后,可以用a[0]=5;这样的语句对数组赋值,用a[0]这样的表达式来访问数组元素.这样的数组应该在析构函数中加入删除语句以释放占用的空间:delete[] a;

华池县19780128507: 安装VC++2005的运行环境 error1402 怎么办? 系统是WIN7 64位的 -
金食益可: 两种情况:1.你先前电脑里的C++没卸干净,解决方法:把C盘里的vc的注册表给删了;2.还有一个可能就是安装文件本身的不完整,解决方法:重新找个文件或换张盘试试.

华池县19780128507: 能否在VS.Net 2005环境下编译C源码? -
金食益可: 当然可以了,前提是你安装VS2005时安装了Visual C++.打开VS2005,新建,项目,Visual C++,Win32控制台应用程序.创建一个C++的工程,然后把你的C源代码添加到工程里就行了.

华池县19780128507: 怎么使用microsoft visual C++ ? -
金食益可: DOS程序: 1、建立工程: 文件 - 新建 - (在工程选项卡中)选择Win32 Console Application并填写工程名称 - 选择第一项(一个空的工程)- 完成 2、建立源文件 文件 - 新建 - (在文件选项卡中)选择C++ source File并填写文件名 - 确定 接下来你就可以在源文件中编写代码了 Window程序 1、文件 - 新建 -(在工程选项卡中)选择MFC AppWizard[exe] 并填写工程名字 - 选择应用程序类型 - 接下来一路按默认值按下去(简单的做法) - 完成

华池县19780128507: 安装opnet时如何设置Visual C++ 2005的环境变量 -
金食益可: 主要是h文件,lib文件,dll文件路径的设置. 打开vs2005,选主菜单 “工具”-》“选项” 选“项目”,选“VC++目录” 然后选中(显示以下内容的目录)下拉控件里面的“包含文件”,“库文件”等.在下面的列表中添加你安装的软件包的h和lib的路径,就ok了,可能还有指定dll的路径.具体在看

华池县19780128507: VS 2005 C#开发环境的说明 -
金食益可: Visual Studio 是微软公司推出的开发环境.是目前最流行的 Windows 平台应用程序开发环境.目前已经开发到 9.0 版本,也就是 Visual Studio 2008. Visual Studio 可以用来创建 Windows 平台下的 Windows 应用程序和网络应用程序,也可以...

华池县19780128507: vs2005开发环境选择了vb如何改为c++ -
金食益可: 选项---测试工具---默认测试项目语言

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网