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

📄 pki_pkcs7.cpp

📁 一个跨平台的CA系统 实现了数字证书的制作、SSL安全通讯、加解密操作等功能
💻 CPP
字号:
/* * 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_pkcs7.cpp,v 1.14 2003/12/09 17:25:22 chris2511 Exp $ * */                           #include "pki_pkcs7.h"#include "exception.h"pki_pkcs7::pki_pkcs7(const QString name)	:pki_base(name){ 	p7 = PKCS7_new();	PKCS7_set_type(p7, NID_pkcs7_signed);	PKCS7_content_new(p7, NID_pkcs7_data);	class_name = "pki_pkcs7";}	pki_pkcs7::~pki_pkcs7(){	if (p7) PKCS7_free(p7);}void pki_pkcs7::encryptFile(pki_x509 *crt, QString filename){	BIO *bio = NULL;	bio = BIO_new_file(filename, "r");        openssl_error();	encryptBio(crt, bio);	BIO_free(bio);}void pki_pkcs7::encryptBio(pki_x509 *crt, BIO *bio){	STACK_OF(X509) *certstack;	if (!crt) return;	certstack = sk_X509_new_null();	sk_X509_push(certstack, crt->getCert());	openssl_error();	if (p7) PKCS7_free(p7);	p7 = PKCS7_encrypt(certstack, bio, EVP_des_ede3_cbc(), PKCS7_BINARY);	openssl_error();		sk_X509_free(certstack);}void pki_pkcs7::signBio(pki_x509 *crt, BIO *bio){	pki_key *privkey;	STACK_OF(X509) *certstack;	if (!crt) return;	privkey = crt->getRefKey();	if (!privkey) throw errorEx("No private key for signing found", class_name);	certstack = sk_X509_new_null();	pki_x509 *signer = crt->getSigner();	if (signer == crt) signer = NULL;	while (signer != NULL ) {		sk_X509_push(certstack, signer->getCert());	        openssl_error();		if (signer == signer->getSigner() ) signer = NULL;		else signer = signer->getSigner();	}	if (p7) PKCS7_free(p7);	p7 = PKCS7_sign(crt->getCert(), privkey->getKey(), certstack, bio, PKCS7_BINARY);	openssl_error();		sk_X509_free(certstack);}void pki_pkcs7::signFile(pki_x509 *crt, QString filename){	BIO *bio = NULL;	if (!crt) return;	bio = BIO_new_file(filename, "r");        openssl_error();	signBio(crt, bio);	BIO_free(bio);}	void pki_pkcs7::signCert(pki_x509 *crt, pki_x509 *contCert){	BIO *bio = NULL;	if (!crt) return;	bio = BIO_new(BIO_s_mem());        openssl_error();	i2d_X509_bio(bio, contCert->getCert());	signBio(crt, bio);	BIO_free(bio);}void pki_pkcs7::writeP7(QString fname,bool PEM){	FILE *fp;        fp = fopen(fname,"w");        if (fp != NULL) {           if (p7){                if (PEM)                   PEM_write_PKCS7(fp, p7);                else                   i2d_PKCS7_fp(fp, p7);                openssl_error();           }        }        else fopen_error(fname);        fclose(fp);}pki_x509 *pki_pkcs7::getCert(int x) {	pki_x509 *cert;	cert = new pki_x509(X509_dup(sk_X509_value(getCertStack(), x)));	openssl_error();	cert->autoIntName();	return cert;}int pki_pkcs7::numCert() {	int n= sk_X509_num(getCertStack());	openssl_error();	return n;}void pki_pkcs7::fload(const QString fname){	FILE *fp;	fp = fopen(fname, "rb");       	if (fp) {		p7 = PEM_read_PKCS7(fp, NULL, NULL, NULL);	               	if (!p7) {			ign_openssl_error();			rewind(fp);			p7 = d2i_PKCS7_fp(fp, &p7);		}		fclose(fp);		openssl_error();	}	else fopen_error(fname);}STACK_OF(X509) *pki_pkcs7::getCertStack() {	STACK_OF(X509) *certstack = NULL; 	int i;        if (p7 == NULL) return NULL;	i = OBJ_obj2nid(p7->type);	switch (i) {		case NID_pkcs7_signed:			certstack = p7->d.sign->cert;			break;									    		case NID_pkcs7_signedAndEnveloped:			certstack = p7->d.signed_and_enveloped->cert;			break;									    		default:			break;	}	openssl_error();	return certstack;}void pki_pkcs7::addCert(pki_x509 *crt) {	if (p7 == NULL || crt == NULL) return;	PKCS7_add_certificate(p7, crt->getCert());	openssl_error();}

⌨️ 快捷键说明

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