跳至正文

der格式编码,der编码解析

如何查看证书的16进制der编码,及证书的各个域der格式

如何查看证书的16进制der编码,及证书的各个域der格式

证书一般都是x.509格式的证书,然后经过DER编码,DER是TLV编码,然后再经过base64编码后存储的。

正确的方法,应该是,把证书文件,用binary方式,传送到linux下,然后用linux中的base64来进行文件解 码。

命令如下:base64

-d -i ca.crt > crt.hex

-d的命令是,然后-i是–ignore-garbage

When decoding, ignore non-alphabet characters.

Decoding

require compliant input by default, use –ignore-garbage to

attempt to

recover from non-alphabet characters (such as newlines) in

the encoded

stream.

然后再用vim打开crt.hex,这时候再转换成16进制,就可以查看到正常的证书16进制的DER编码了。

怎么把DER编码的数据转成PEM的数据

怎么把DER编码的数据转成PEM的数据

openssl里有pem开头的函数就可以得到pem编码的 比如 存到文件的:PEM_write_RSAPublicKey 写到bio的:PEM_write_bio_RSAPrivateKey 找找类似的你需要的吧

如何把DER编码的数据转成PEM的数据

如何把DER编码的数据转成PEM的数据

如何把DER编码的数据转成PEM的数据

创建内容组的代码类似于自定义维度的代码。可以使用这个追踪代码设置5个内容组。每个组都与一个1至5的数字相对应,如图上面的例子所示。查看Google Analytics支持文档获取更多代码示例。基本上,这个方法可以从其他系统通过其他变量代码来传递属性值,这些系统可以是一个CMS(内容管理系统),一个数据层 ,或者仅仅是页面的HTML。关键是,无论用哪种方式,都需要添加组的名称到Google Analytics代码中。

优点:使用自定义跟踪代码的方法,能通过改代码和与之配合的页面变量来实现自动的组创建和设置。

缺点:它要求IT人员参与设置。但是,一旦配置成功,之后就不需要太多IT资源的支持了。

还有一种方法,是这种方法的升级版,即通过Google Tag Manager(Google标签管理器)来设置内容组。

如何用java将一个der编码的证书转化成一个b

public class Text {

private int n;

public Text(int n) {

this.n = n;

}

public void fun() {

int a[] = new int[50], i = 0;

while (n != 0) {

if (n % 2 == 0)

a[i++] = 0;

else

a[i++] = 1;

n /= 2;

}

for (int j = i – 1; j >= 0; j–)

System.out.print(a[j]);

}

public static void main(String args[]) {

new Text(4563).fun();

/*此处没有用输入,要用的话比较烦,你说的要简单的,直接在代码中改数据好了*/

}

}

这种文件的后缀名是什么?有哪些?

这种文件一般都是你电脑上安装没有打开某文件的程序软件,那么该文件就会显示此图标的.

说几个文件类型的缩写(如.DOC)

我所知道的:

1、可执行文件(程序):.exe/.com/.bat/.cmd……

2、Office文件:.txt/.doc/.xls/.ppt/.rtf……

3、压缩文件:.rar/.zip/.7z/.cab/.iso……

4、图片文件:.jpg/.bmp/.png/.gif/.tiff……

5、声音文件:.mp3/.mid/.wav/.aac……

6、影像文件:.mp4/.avi/.rm/.rmvb/.flv/.wma/.3gp……

7、系统文件:我的电脑、回收站、网上邻居、控制面板【都是特殊的文件】……

如何用C++实现读取证书文件中的公钥数据?

在C++下,我使用OPENSSL库生成了RSA的公私钥对与DES加密之用的会话密钥,并将这三者及加密结果写入文件以备在Java环境下使用。

在C++程序中,我使用使用公钥来加密了DES的会话密钥,然后在Java下使用私钥来解密会话密钥;在运算结果中,我未做其它方面的码制转换,即按密钥的初始格式DER编码,数学运算结果也是按DER编码来实现。

在Java程序中,我从之前所存储的几个文件中取得密钥与加密结果来做解密。我使用了BC的JCE,即bcprov-jdk14-119.jar,在使用之前,需要先安装此JCE:

假设JDK:jdk1.4\jre\

把BC包放到JRE下的ext:jdk1.4\jre\lib\ext

修改文件jdk1.4\jre\lib\security\java.security:

#

# List of providers and their preference orders (see above):

#

security.provider.1=sun.security.provider.Sun

security.provider.2=com.sun.net.ssl.internal.ssl.Provider

security.provider.3=com.sun.rsajca.Provider

security.provider.4=com.sun.crypto.provider.SunJCE

security.provider.5=sun.security.jgss.SunProvider

security.provider.6=org.bouncycastle.jce.provider.BouncyCastleProvider

======================================================================

C++程序源码:

#include

#include

#include

//#define _RSA_KEY_PAIR_GENERATE_//密钥是否要生成 只需要在第一次运行时打开此宏

#define _RSA_KEY_PAIR_TOFILE_//密钥对是否要写入文件

#define MAX_RSA_KEY_LENGTH 512 //密钥的最大长度是512字节

#define PUBKEY_ENCRYPT

#define PRIKEY_DECRYPT

#pragma comment(lib, “../lib/libeay32.lib”)

static const char * PUBLIC_KEY_FILE = “pubkey.key”;

static const char * PRIVATE_KEY_FILE = “prikey.key”;

int RsaKeyPairGen(void)

{

RSA *rsa = NULL;

#ifdef_RSA_KEY_PAIR_GENERATE_

//生成RSA密钥对:

rsa = RSA_new();

rsa = RSA_generate_key(1024, 0x10001, NULL, NULL);

#endif

//把密钥对写入文件,以后从文件里读取

#ifdef _RSA_KEY_PAIR_TOFILE_

unsigned char ucPubKey[MAX_RSA_KEY_LENGTH] = {0}, ucPriKey[MAX_RSA_KEY_LENGTH] = {0};

int len = i2d_RSAPublicKey(rsa,NULL);

unsigned char* pt = ucPubKey;

len = i2d_RSAPublicKey(rsa, &pt);

FILE *fpubkey = NULL;

fpubkey = fopen(PUBLIC_KEY_FILE, “wb”);

if(fpubkey == NULL)

{

cout << "fopen pubkey.key failed!" << endl;

return 0x01;

}

fwrite(ucPubKey, 1, len, fpubkey);

fclose(fpubkey);

len = i2d_RSAPrivateKey(rsa,NULL);

unsigned char* pt2 = ucPriKey;

len = i2d_RSAPrivateKey(rsa,&pt2);

FILE *fprikey = NULL;

fprikey = fopen(PRIVATE_KEY_FILE, “wb”);

if(fprikey == NULL)

{

cout << "fopen prikey.key failed!" << endl;

return 0x02;

}

fwrite(ucPriKey, 1, len, fprikey);

fclose(fprikey);

#endif

if(rsa != NULL)

{

RSA_free(rsa);

rsa = NULL;

}

return 0;

}

//从文件里读取私钥的数据,取得RSA格式的私钥:

int GetPriKey(unsigned char *pucPriKeyData, unsigned long KeyDataLen, RSA* *priRsa)

{

unsigned char *Pt = pucPriKeyData;

*priRsa = d2i_RSAPrivateKey(NULL, &Pt, KeyDataLen);

if(priRsa == NULL)

{

cout << "priRsa == NULL!" << endl;

return 0x22;

}

return 0;

}

//取得RSA格式的公钥:

int GetPubKey(unsigned char *pucPubKeyData,unsigned long KeyDataLen, RSA* *pubRsa)

{

unsigned char *Pt = pucPubKeyData;

*pubRsa = d2i_RSAPublicKey(NULL, &Pt, KeyDataLen);

if(pubRsa == NULL)

{

cout << "pubRsa == NULL!" << endl;

return 0x31;

}

return 0;

}

//公钥加密会话密钥:

int encSessionKeybyRsaPubKey(RSA *rsa, unsigned char *ucKey, unsigned long ulKeyLen,

unsigned char *outData, unsigned long *pulOutLen)

{

return (*pulOutLen = RSA_public_encrypt(ulKeyLen, ucKey, outData, rsa, 1));

}

//私钥解密会话密钥:

int decSessionKeybyRsaPriKey(RSA *rsa, unsigned char *InData, unsigned long ulDataLen,

unsigned char *ucKey, unsigned long *pulKeyLen)

{

return (*pulKeyLen = RSA_private_decrypt(ulDataLen, InData, ucKey, rsa, 1));

}

int main(int argc, char* argv[])

{

unsigned char ucKey[8] = {0x01, 0x03, 0x99, 0x4, \

0x80, 0x65, 0x34, 0x08};

unsigned char ucEncryptedKey[512] = {0}, ucDecryptedKey[512] = {0};

unsigned long encrypted_len = 0, decrypted_len = 0;

#ifdef _RSA_KEY_PAIR_GENERATE_

RsaKeyPairGen();

#endif

//取得公钥:

unsigned char ucPubKey[MAX_RSA_KEY_LENGTH] = {0};

FILE *fpubkey = NULL;

fpubkey = fopen(PUBLIC_KEY_FILE, “rb”);

if(fpubkey == NULL)

{

cout << "fopen pubkey.key failed!" << endl;

return 0x03;

}

fseek(fpubkey, 0, SEEK_END);

int len_PK = ftell(fpubkey);

fseek(fpubkey, 0, SEEK_SET);

fread(ucPubKey, 1, len_PK, fpubkey);

fclose(fpubkey);

#ifdef PUBKEY_ENCRYPT

RSA *pRsaPubKey = NULL;

pRsaPubKey = RSA_new();

GetPubKey(ucPubKey, len_PK, &pRsaPubKey);

//公钥加密:

encSessionKeybyRsaPubKey(pRsaPubKey, ucKey, sizeof(ucKey), ucEncryptedKey, &encrypted_len);

//write to file:

FILE *fp = NULL;

fp = fopen(“ucKey.data”, “wb”);

fwrite(ucEncryptedKey, 1, encrypted_len, fp);

fclose(fp);

if(pRsaPubKey != NULL)

{

RSA_free(pRsaPubKey); pRsaPubKey = NULL;

}

#endif

//取得私钥:

unsigned char ucPriKey[MAX_RSA_KEY_LENGTH] = {0};

FILE *fprikey = NULL;

fprikey = fopen(PRIVATE_KEY_FILE, “rb”);

if(fprikey == NULL)

{

cout << "fopen prikey.key failed!" << endl;

return 0x02;

}

fseek(fprikey, 0, SEEK_END);

int len_SK = ftell(fprikey);

fseek(fprikey, 0, SEEK_SET);

fread(ucPriKey, 1, len_SK, fprikey);

fclose(fprikey);

#ifdef PRIKEY_DECRYPT

RSA *pRsaPriKey = NULL;

pRsaPriKey = RSA_new();

GetPriKey(ucPriKey, len_SK, &pRsaPriKey);

//私钥解密:

FILE *fp1 = NULL;

fp1 = fopen(“ucKey.data”, “rb”);

int len = ftell(fp1);

fseek(fp1, 0, SEEK_SET);

fread(ucPriKey, 1, len_SK, fp1);

fclose(fp1);

decSessionKeybyRsaPriKey(pRsaPriKey, ucEncryptedKey, encrypted_len, ucDecryptedKey, &decrypted_len);

if(pRsaPriKey != NULL)

{

RSA_free(pRsaPriKey); pRsaPriKey = NULL;

}

//数据对比:

if(0 == memcmp(ucKey, ucDecryptedKey, decrypted_len))

{

cout << "OK!" << endl;

}

else

{

cout << "FAILED!" << endl;

}

#endif

return 0;

}

polarssl证书解析key是使用的是pkcs1还是pkcs8

pkcs8格式的私钥转换工具。它处理在PKCS#8格式中的私钥文件。它可以用多样的PKCS#5 (v1.5 and v2.0)和 PKCS#12算法来处理没有解密的PKCS#8 PrivateKeyInfo格式和EncryptedPrivateKeyInfo格式。

用法:

[cpp] view plaincopy

openssl pkcs8 [-inform PEM|DER] [-outform PEM|DER] [-in filename] [-passin arg] [-out filename]

[-passout arg] [-topk8] [-noiter] [-nocrypt] [-nooct] [-embed] [-nsdb] [-v2 alg] [-v1 alg] [-engine id]

选项说明:

-inform PEM|DER::输入文件格式,DER或者PEM格式。DER格式采用ASN1的DER标准格式。一般用的多的都是PEM格式,就是base64编码格式。

-outform DER|PEM:输出文件格式,DER或者PEM格式。

-in filename:输入的密钥文件,默认为标准输入。如果密钥被加密,会提示输入一个密钥口令。

-passin arg:输入文件口令保护来源。

-out filename:输出文件,默认为标准输出。如果任何加密操作已经执行,会提示输入一个密钥值。输出的文件名字不能和输入的文件名一样。

-passout arg:输出文件口令保护来源。

如何将ASCII编码RSA公钥转换为publickey对象

我不知道你所指的 ASCII 编码的 RSA 公钥具体是什么?

下面这段代码使用 DER 或者 PEM 编码的 X.509 格式证书都可以获得公钥。

Java code?

import java.io.FileInputStream;

import java.security.PublicKey;

import java.security.cert.Certificate;

import java.security.cert.CertificateFactory;

public class Cert {

public static void main(String[] args) throws Exception {

CertificateFactory factory = CertificateFactory.getInstance(“X.509”);

Certificate cert = factory.generateCertificate(new FileInputStream(“e:/security/test.cert.pem”));

PublicKey pubKey = cert.getPublicKey();

}

}

如何在Kindle中安装KOReader

新版本不行了

kindle特别适合看小说 看英文版本的书籍,体验超级给力 ,对眼睛的伤害可以说很低,看久了也不疲劳, 待机也不错 手感也很棒,个人推荐KPW3,日版才600多,问日版国内能不能用,回答是肯定的。亚马逊资源也是很丰富的,但是kindle对PDF的书籍支持的很不好。

kindle原系统支持azw、pdf、mobi、prc、txt格式。其中mobi、azw和prc格式支持最为优秀。 PDF如果是扫描版的,因为不是为6寸量身定做的,所以,显示会不太清晰,或者由于本身扫描效果就不太好,所以会不太清晰。如果是字太小,原系统可以考虑局部放大,多看系统下可以用智能切边功能。 txt格式支持不是太好,有可能会出现乱码或者翻页有问题。把txt格式编码另存为UTF-8的编码的效果会好点(在电脑中打开一个txt文件,点击文件→另存为→编码选择UTF-8→保存),但是建议最好是转换成mobi。