⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pki_pkcs12.cpp

📁 一个跨平台的CA系统 实现了数字证书的制作、SSL安全通讯、加解密操作等功能
💻 CPP
字号:
/* vi: set sw=4 ts=4: *//* * Copyright (C) 2001 Christian Hohnstaedt. * *  All rights reserved. * * *  Redistribution and use in source and binary forms, with or without  *  modification, are permitted provided that the following conditions are met: * *  - Redistributions of source code must retain the above copyright notice, *    this list of conditions and the following disclaimer. *  - Redistributions in binary form must reproduce the above copyright notice, *    this list of conditions and the following disclaimer in the documentation *    and/or other materials provided with the distribution. *  - Neither the name of the author nor the names of its contributors may be  *    used to endorse or promote products derived from this software without *    specific prior written permission. * * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * * This program links to software with different licenses from: * *	http://www.openssl.org which includes cryptographic software * 	written by Eric Young (eay@cryptsoft.com)" * *	http://www.sleepycat.com * *	http://www.trolltech.com *  * * * http://www.hohnstaedt.de/xca * email: christian@hohnstaedt.de * * $Id: pki_pkcs12.cpp,v 1.23 2004/04/15 11:47:19 chris2511 Exp $ * */                           #include "pki_pkcs12.h"#include "pass_info.h"#include "exception.h"#include <openssl/err.h>#include <qmessagebox.h>pki_pkcs12::pki_pkcs12(const QString d, pki_x509 *acert, pki_key *akey, pem_password_cb *cb):	pki_base(d){	class_name="pki_pkcs12";	key = new pki_key(akey);	cert = new pki_x509(acert);	certstack = sk_X509_new_null();	passcb = cb;	openssl_error();	}pki_pkcs12::pki_pkcs12(const QString fname, pem_password_cb *cb)	:pki_base(fname){ 	FILE *fp;	char pass[30];	EVP_PKEY *mykey = NULL;	X509 *mycert = NULL;	key=NULL; cert=NULL;	passcb = cb;	class_name="pki_pkcs12";	certstack = sk_X509_new_null();	pass_info p(XCA_TITLE, tr("Please enter the password to decrypt the PKCS#12 file.")		+ "\n'" + fname + "'");	fp = fopen(fname, "rb");	if (fp) {		PKCS12 *pkcs12 = d2i_PKCS12_fp(fp, NULL);		fclose(fp);		openssl_error();		if (passcb(pass, 30, 0, &p) == 0) {			if (pass[0] != '\0') {				/* cancel pressed */				PKCS12_free(pkcs12);				throw errorEx("","");			}		}		PKCS12_parse(pkcs12, pass, &mykey, &mycert, &certstack);		if ( ERR_peek_error() != 0) {			ign_openssl_error();			//QMessageBox::warning(NULL, XCA_TITLE, 			//	tr(), tr("&OK"));			PKCS12_free(pkcs12);			throw errorEx(getClassName(),"The supplied password was wrong");		}		openssl_error();		if (mykey) {			key = new pki_key(mykey);		}		if (mycert) {			cert = new pki_x509(mycert);			cert->autoIntName();		}		PKCS12_free(pkcs12);	}	else fopen_error(fname);}	pki_pkcs12::~pki_pkcs12(){	if (sk_X509_num(certstack)>0) {		// free the certs itself, because we own a copy of them		sk_X509_pop_free(certstack, X509_free);	}	if (key) { 		delete(key); 	}	if (cert) {		delete(cert);	}	openssl_error();}void pki_pkcs12::addCaCert(pki_x509 *ca){ 	if (!ca) return;	sk_X509_push(certstack, X509_dup(ca->getCert()));	openssl_error();}	void pki_pkcs12::writePKCS12(const QString fname){ 	char pass[30];	char desc[100];	strncpy(desc,getIntName(),100);	pass_info p(XCA_TITLE, tr("Please enter the password to encrypt the PKCS#12 file"));	if (cert == NULL || key == NULL) {		openssl_error("No key or no Cert and no pkcs12....");	}	FILE *fp = fopen(fname,"wb");	if (fp != NULL) {		passcb(pass, 30, 0, &p); 		PKCS12 *pkcs12 = PKCS12_create(pass, desc, key->getKey(),			cert->getCert(), certstack, 0, 0, 0, 0, 0);		i2d_PKCS12_fp(fp, pkcs12);		openssl_error();		fclose (fp);		PKCS12_free(pkcs12);	}	else fopen_error(fname);}int pki_pkcs12::numCa() {	int n= sk_X509_num(certstack);	openssl_error();	return n;}pki_key *pki_pkcs12::getKey() {	if (!key) return NULL;	return new pki_key(key);}pki_x509 *pki_pkcs12::getCert() {	if (!cert) return NULL;	pki_x509 *c = new pki_x509(cert);	c->autoIntName();	return c;}pki_x509 *pki_pkcs12::getCa(int x) {	pki_x509 *cert = NULL;	X509 *crt = X509_dup(sk_X509_value(certstack, x));	if (crt) {		cert = new pki_x509(crt);		cert->autoIntName();	}	openssl_error();	return cert;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -