青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉(zhuǎn),開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

OPENSSL 生成 CERT 參考

Posted on 2010-06-06 17:57 S.l.e!ep.¢% 閱讀(1159) 評論(1)  編輯 收藏 引用 所屬分類: OpenSSL
#pragma comment(lib,"libeay32.lib")
#pragma comment(lib,"ssleay32.lib")
char mainkey[17]="0123456789abcdef";
char *c1="CN";
char *pr1="hunan";
char *ct1="xiangtan";
char *or1="hnust";
char *dp1="computer";
char *co1="Ling";
char *c;
char *pr;
char *ct;
char *or;
char *dp;
char *co;
X509_REQ *req=X509_REQ_new(); ?
X509_NAME *subj=X509_NAME_new(); ?
EVP_PKEY *m_pClientKey=EVP_PKEY_new();
EVP_PKEY *m_pCAKey;
X509 *m_pCACert;
X509 *ptemp=NULL;
X509 *m_pClientCert=X509_new();
BIO *pbio;
FILE *fp;
char *Save="E:\\畢業(yè)設(shè)計\\openssl_help\\CCert.der";
char *KeyName="E:\\畢業(yè)設(shè)計\\openssl_help\\RootKey.pem";
char *CerName="E:\\畢業(yè)設(shè)計\\openssl_help\\RootCert.crt";
char *KeyPwd1="481511220";
char *KeyPwd2="srvca";
char *KeyPwd3="1tian=1day";
char *crp="e:\\畢業(yè)設(shè)計\\openssl_help\\RootCert.pem";
char *ck="e:\\畢業(yè)設(shè)計\\openssl_help\\RootKey.pem";
char *country="cn";
--------------------------------------加解密----------------------------------------------
void md5(unsigned char *str,unsigned char *md)
{

? EVP_Digest(str, strlen((char *)str), md, NULL, EVP_md5(), NULL);
}
void des_cpy(char *des,char *src)
{
int i;
for(i=0;i<8;i++)
{
des[i]=src[i];
}
}
void des_ini(DES_cblock cb)
{
int i;
for(i=0;i<8;i++)
cb[i]=0x00;
}
void des_e(unsigned char *key,char *input,char **output)
{
char *output1;
char *output2;
int i;
int l=strlen(input);
int m=l/8;
int n=l%8;
DES_cblock des_key;
DES_string_to_key((char *)key, &des_key);
DES_key_schedule schedule;
? DES_set_key_checked(&des_key, &schedule);
DES_cblock des_input;
DES_cblock des_output;
if(n==0)?
{
output1=(char *)malloc(m*8+1);
output2=(char *)malloc((m*8)*2+1);
output1[m*8]='\0';
output2[m*8*2]='\0';
for(i=0;i<m;i++)
{
des_cpy((char *)des_input,input+i*8);
DES_ecb_encrypt(&des_input, &des_output, &schedule, DES_ENCRYPT);
des_cpy(output1+i*8,(char *)des_output);
}
for(i=0;i<m*8;i++)
{
output2[i*2]=(((output1[i]>>4)&0x0f)|0x40)+1;
output2[i*2+1]=((output1[i]&0x0f)|0x40)+1;
}
}
else?
{
output1=(char *)malloc((m+1)*8+1);
output2=(char *)malloc(((m+1)*8)*2+1);
output1[(m+1)*8]='\0';
output2[(m+1)*8*2]='\0';
for(i=0;i<m;i++)
{
des_cpy((char *)des_input,input+i*8);
DES_ecb_encrypt(&des_input, &des_output, &schedule, DES_ENCRYPT);
des_cpy(output1+i*8,(char *)des_output);
}
des_ini(des_input);
for(i=0;i<n;i++)
{
des_input[i]=input[m*8+i];
}
DES_ecb_encrypt(&des_input, &des_output, &schedule, DES_ENCRYPT);
des_cpy(output1+m*8,(char *)des_output);
for(i=0;i<(m+1)*8;i++)
{
output2[i*2]=(((output1[i]>>4)&0x0f)|0x40)+1;
output2[i*2+1]=((output1[i]&0x0f)|0x40)+1;
}
}
*output=output2;
}
void des_d(unsigned char *key,char *input,char **output)
{
char *output1;
char *input1;
int l=strlen(input)/2;
input1=(char *)malloc(l+1);
int i;
input1[l]='\0';
int m=l/8;
int n=l%8;
for(i=0;i<l;i++)
{
? input[2*i]--;
? input[2*i+1]--;
input1[i]=((input[2*i]<<4)&0xf0)|(input[2*i+1]&0x0f);
}
DES_cblock des_key;
DES_string_to_key((char *)key, &des_key);
DES_key_schedule schedule;
? DES_set_key_checked(&des_key, &schedule);
DES_cblock des_input;
DES_cblock des_output;
output1=(char *)malloc(l+1);
output1[l]='\0';
for(i=0;i<m;i++)
{
des_cpy((char *)des_input,input1+i*8);
DES_ecb_encrypt(&des_input, &des_output, &schedule, DES_DECRYPT);
des_cpy(output1+i*8,(char *)des_output);
}
*output=output1;
}
void ent()
{
? char key[6][17];
? unsigned char md[6][16];
? int i;
? for(i=0;i<6;i++)
? {
strcpy(key[i],mainkey);
? }
? strcat(key[0],REQ_COUNTRY_NAME);
? strcat(key[1],REQ_STATA_OR_PROVINCE_NAME);
? strcat(key[2],REQ_LOCALITE_NAME);
? strcat(key[3],REQ_ORG_NAME);
? strcat(key[4],REQ_DEPT_NAME);
? strcat(key[5],REQ_COMMON_NAME);
? for(i=0;i<6;i++)
? {
md5((unsigned char *)key[i],md[i]);
md[i][8]='\0';
? }
? des_e((unsigned char *)key[0],c1,&c);
? des_e((unsigned char *)key[1],pr1,&pr);
? des_e((unsigned char *)key[2],ct1,&ct);
? des_e((unsigned char *)key[3],or1,&or);
? des_e((unsigned char *)key[4],dp1,&dp);
? des_e((unsigned char *)key[5],co1,&co);
}
------------------------------------------加解密部分完------------------------------------------------

主函數(shù)部分
void main(int argc,char* argv[])
{
? OpenSSL_add_all_ciphers();
? OpenSSL_add_all_digests();
? ERR_load_crypto_strings();
? /*pbio = BIO_new_file((LPSTR)(LPCTSTR)KeyName,"r");
? if(pbio==NULL)
? {
printf("CA私鑰文件讀取失敗\n");
return;
? }
? m_pCAKey = PEM_read_bio_PrivateKey(pbio,NULL,0,(unsigned char*)(LPCTSTR)KeyPwd1);
? if(m_pCAKey==NULL)
? {
printf("CA私鑰文件讀取失敗\n");
return;
? }
? BIO_free_all(pbio);
? pbio = BIO_new_file((LPSTR)(LPCTSTR)CerName,"r");
? if(pbio==NULL)
? {
printf("CA證書文件讀取失敗\n");
return;
? }
? m_pCACert=d2i_X509_bio(pbio,NULL);
? if(m_pCACert==NULL)
? {
printf("CA證書讀取失敗\n");
return;
? }
? BIO_free_all(pbio);*/
?/*if(!(pbio = BIO_new_file((LPSTR)(LPCTSTR)crp,"r")))
? {
printf("打開CA證書失敗");
BIO_free_all(pbio);
return;
? }
? m_pCACert=d2i_X509_bio(pbio,NULL);
? if(m_pCACert==NULL)
? {
printf("打開證書失敗");
BIO_free_all(pbio);
return;
? }
? m_pCAKey = PEM_read_bio_PrivateKey(pbio,NULL,0,(unsigned char*)(LPCTSTR)KeyPwd2);
? if(m_pCAKey==NULL)
? {
printf("打開私鑰失敗");
BIO_free_all(pbio);
return;
? }*/
? if (!(pbio = BIO_new_file((LPSTR)(LPCTSTR)crp,"r")))
? printf("打開CA文件時出錯");
? if (!(m_pCACert = PEM_read_bio_X509(pbio,NULL,NULL,NULL)))
? printf("從CA證書文件中讀取證書時出錯");
? BIO_free_all(pbio);
? if (!(pbio = BIO_new_file((LPSTR)(LPCTSTR)ck,"r")))
? printf("打開CA私鑰時出錯");
? if (!(m_pCAKey = PEM_read_bio_PrivateKey(pbio, NULL, NULL,KeyPwd3)))
? printf("從文件中讀取CA私鑰時出錯");
? BIO_free_all(pbio);

? ent();//<-------------------------------------------------------------------------------加密屬性值

? EVP_PKEY_assign_RSA(m_pClientKey,RSA_generate_key(1024,0x10001,NULL,NULL));
? X509_NAME_add_entry_by_txt(subj,REQ_COUNTRY_NAME,MBSTRING_ASC,(unsigned char *)c,-1,-1,0);
? X509_NAME_add_entry_by_txt(subj,REQ_STATA_OR_PROVINCE_NAME,MBSTRING_ASC,(unsigned char *)pr,-1,-1,0);
? X509_NAME_add_entry_by_txt(subj,REQ_LOCALITE_NAME,MBSTRING_ASC,(unsigned char *)ct,-1,-1,0);
? X509_NAME_add_entry_by_txt(subj,REQ_ORG_NAME,MBSTRING_ASC,(unsigned char *)or,-1,-1,0);
? X509_NAME_add_entry_by_txt(subj,REQ_DEPT_NAME,MBSTRING_ASC,(unsigned char *)dp,-1,-1,0);
? X509_NAME_add_entry_by_txt(subj,REQ_COMMON_NAME,MBSTRING_ASC,(unsigned char *)co,-1,-1,0);
? //if(X509_REQ_set_subject_name(req,subj)!=1)
? //if(X509_NAME_set(&req->req_info->subject,subj)!=1)
? req->req_info->subject=X509_NAME_dup(subj);
? if(req->req_info->subject==NULL)
? {
printf("加入主體信息失敗\n");
return;
? }
??
? //加入一個主體公鑰(上小節(jié)生成的m_pClientKey)
? //X509_REQ_set_pubkey(req, m_pClientKey);
? X509_PUBKEY_set(&req->req_info->pubkey,m_pClientKey);
? //加入一組可選的擴展屬性
? STACK_OF(X509_EXTENSION) *extlist=sk_X509_EXTENSION_new_null();//<--------------------調(diào)試出錯在這行
? X509_EXTENSION *ext=X509V3_EXT_conf(NULL,NULL,"addr","hunanust");?
? //生成擴展對象
? sk_X509_EXTENSION_push(extlist,ext);
? X509_REQ_add_extensions(req,extlist);//加入擴展項目。
? //用主體的私鑰對上面的req進行簽名。在簽名是需要選擇摘要算法,
? EVP_MD const *digest=EVP_md5();//(選擇MD5算法)
? X509_REQ_sign(req,m_pClientKey,digest);
? ptemp=m_pClientCert;
? //設(shè)置版本號
? X509_set_version(ptemp, 2);
? //設(shè)置證書序列號,這個sn就是CA中心頒發(fā)的第N份證書
? ASN1_INTEGER_set(X509_get_serialNumber(ptemp),0);
? //設(shè)置證書開始時間
? X509_gmtime_adj(X509_get_notBefore(ptemp),0);
? //設(shè)置證書結(jié)束時間
? X509_gmtime_adj(X509_get_notAfter(ptemp), (long)60*60*24*365);
? //設(shè)置證書的主體名稱,req就是剛剛生成的請求證書
? X509_set_subject_name(ptemp, X509_REQ_get_subject_name(req));
? //設(shè)置證書的公鑰信息
? X509_set_pubkey(ptemp, X509_PUBKEY_get(req->req_info->pubkey));
? //設(shè)置證書的簽發(fā)者信息,m_pCACert是CA證書
? X509_set_issuer_name(ptemp, X509_get_subject_name(m_pCACert));
? //設(shè)置擴展項目
? X509V3_CTX ctx;
? X509V3_set_ctx(&ctx, m_pCACert, m_pClientCert, NULL, NULL, 0);
? X509_EXTENSION *x509_ext = X509_EXTENSION_new();
? x509_ext = X509V3_EXT_conf(NULL,NULL, "hellomsg","good luck");
? X509_add_ext(m_pClientCert,x509_ext,-1);
? //設(shè)置簽名值
? X509_sign(m_pClientCert,m_pCAKey,EVP_md5());
? pbio = BIO_new_file((LPSTR)(LPCTSTR)Save,"w");
? i2d_X509_bio(pbio, m_pClientCert); //DER格式
? printf("OK\n");

}

Feedback

# re: OPENSSL 生成 CERT 參考  回復(fù)  更多評論   

2013-04-18 19:29 by 呂文華
REQ_DEPT_NAME 等 這些定義在哪? 最好把頭文件都給列出來。謝謝!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人tv| 好吊成人免视频| 亚洲视频在线看| 久久99在线观看| 在线欧美小视频| 欧美全黄视频| 亚洲一区免费观看| 米奇777超碰欧美日韩亚洲| 亚洲福利在线观看| 欧美三级网页| 久久精品免费看| 亚洲精品日韩欧美| 欧美呦呦网站| 亚洲区一区二| 国产精品日韩欧美综合| 久久噜噜亚洲综合| 亚洲色图制服丝袜| 榴莲视频成人在线观看| 一本到12不卡视频在线dvd| 国产九九视频一区二区三区| 久久久久九九九| 99综合电影在线视频| 玖玖在线精品| 亚洲曰本av电影| 亚洲高清在线观看| 国产美女搞久久| 欧美精品一区二区三区很污很色的| 亚洲先锋成人| 亚洲人成人99网站| 久久av一区二区三区漫画| 最新国产精品拍自在线播放| 国产精品五区| 欧美激情一区三区| 久久黄色小说| 亚洲香蕉网站| 91久久久久| 蜜臀va亚洲va欧美va天堂| 亚洲欧美精品在线观看| 亚洲伦理在线观看| 激情婷婷久久| 国产日韩1区| 国产精品swag| 欧美大片在线影院| 久久久高清一区二区三区| 一区二区三区日韩欧美精品| 亚洲第一黄网| 玖玖综合伊人| 久久精品成人一区二区三区蜜臀| 亚洲性感激情| 99在线精品视频在线观看| 亚洲第一二三四五区| 国产日韩1区| 国产精品尤物| 国产精品免费区二区三区观看| 欧美高清视频www夜色资源网| 久久精品一区二区三区四区| 午夜精品福利一区二区三区av | 美玉足脚交一区二区三区图片| 亚洲欧美日韩在线播放| 亚洲午夜一区| 亚洲伊人久久综合| 亚洲先锋成人| 亚洲自拍三区| 亚洲男女毛片无遮挡| 一区二区三区国产盗摄| 亚洲美女视频在线观看| 亚洲美女视频在线免费观看| 亚洲国产成人在线| 亚洲狠狠丁香婷婷综合久久久| 伊人久久亚洲影院| 亚洲二区视频在线| 亚洲日本中文字幕区| 日韩系列欧美系列| 在线视频精品一区| 亚洲一区二区三区精品动漫| 亚洲永久免费视频| 欧美在线视屏| 卡一卡二国产精品| 亚洲福利在线看| 日韩网站在线观看| 亚洲午夜精品久久| 午夜视黄欧洲亚洲| 久久久精品国产免费观看同学| 久久裸体艺术| 欧美精品18| 国产精品久久久999| 国产精品视频内| 激情五月***国产精品| 亚洲激情亚洲| 亚洲一级片在线观看| 欧美制服丝袜第一页| 巨乳诱惑日韩免费av| 亚洲国内在线| 亚洲夜间福利| 久久激情综合| 欧美精品一区在线观看| 国产精品家庭影院| 狠狠干综合网| 一本久道久久综合婷婷鲸鱼| 亚洲网站啪啪| 久久视频在线视频| 亚洲区免费影片| 亚洲综合不卡| 免费看的黄色欧美网站| 欧美午夜不卡影院在线观看完整版免费| 国产精品女主播| 亚洲丁香婷深爱综合| 亚洲一二三区在线| 蜜桃av噜噜一区二区三区| 日韩视频在线观看国产| 久久99在线观看| 欧美日韩天堂| 国产一二三精品| 一区二区成人精品 | 一区二区三区波多野结衣在线观看| 亚洲欧美999| 欧美国产一区在线| 国内精品模特av私拍在线观看| 亚洲日本理论电影| 久久精品人人爽| 亚洲精品裸体| 久久久久久一区二区三区| 欧美视频免费| 亚洲精品日本| 久久先锋影音| 亚洲一区二区少妇| 欧美精品亚洲| 在线观看国产成人av片| 欧美在线视频导航| 99这里只有精品| 欧美成年网站| 一区二区视频免费完整版观看| 亚洲专区一区二区三区| 欧美激情在线| 久久久久国产成人精品亚洲午夜| 欧美手机在线| 9人人澡人人爽人人精品| 蜜桃精品久久久久久久免费影院| 亚洲网站视频| 欧美日韩精品伦理作品在线免费观看| 娇妻被交换粗又大又硬视频欧美| 西西裸体人体做爰大胆久久久| 亚洲裸体俱乐部裸体舞表演av| 久久综合狠狠综合久久综青草| 国产亚洲欧美日韩在线一区 | 亚洲人成人99网站| 美腿丝袜亚洲色图| 1000部国产精品成人观看| 久久久人成影片一区二区三区| 亚洲欧美日本日韩| 国产精品男女猛烈高潮激情| 亚洲一区综合| 亚洲视频中文字幕| 国产精品另类一区| 亚洲欧美久久久| 亚洲一区二区三区精品在线| 国产精品成人在线| 亚洲制服少妇| 亚洲在线电影| 国产亚洲女人久久久久毛片| 欧美在线免费观看亚洲| 亚洲欧美在线一区| 国产午夜精品理论片a级大结局| 欧美制服丝袜| 久久精品免费| 亚洲国产欧美日韩| 欧美激情亚洲另类| 欧美精品二区三区四区免费看视频| 亚洲狠狠婷婷| 亚洲久久一区| 国产精品欧美日韩久久| 性久久久久久久久久久久| 香蕉免费一区二区三区在线观看| 国产一区二区三区免费不卡| 久久久久久久成人| 久久综合成人精品亚洲另类欧美| 亚洲国产色一区| 99re66热这里只有精品4| 国产精品久久7| 久久久久久久高潮| 麻豆精品在线视频| 中日韩午夜理伦电影免费| 亚洲一区二区三区在线| 国产综合在线视频| 欧美国产日韩一区| 国产精品a久久久久久| 欧美在线亚洲一区| 美女黄色成人网| 一区二区三区 在线观看视频| 中文欧美字幕免费| 黄色精品在线看| 亚洲精品黄色| 国产人成一区二区三区影院| 免费在线国产精品| 欧美日韩综合网| 久久永久免费| 欧美精品在线免费| 久久精品国产久精国产思思| 嫩草伊人久久精品少妇av杨幂| 亚洲一区二区四区|