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

📄 smime.c

📁 mediastreamer2是开源的网络传输媒体流的库
💻 C
📖 第 1 页 / 共 2 页
字号:
			{			BIO_printf(bio_err, "No recipient(s) certificate(s) specified\n");			badarg = 1;			}		need_rand = 1;		}	else if (!operation)		badarg = 1;	if (badarg)		{		BIO_printf (bio_err, "Usage smime [options] cert.pem ...\n");		BIO_printf (bio_err, "where options are\n");		BIO_printf (bio_err, "-encrypt       encrypt message\n");		BIO_printf (bio_err, "-decrypt       decrypt encrypted message\n");		BIO_printf (bio_err, "-sign          sign message\n");		BIO_printf (bio_err, "-verify        verify signed message\n");		BIO_printf (bio_err, "-pk7out        output PKCS#7 structure\n");#ifndef OPENSSL_NO_DES		BIO_printf (bio_err, "-des3          encrypt with triple DES\n");		BIO_printf (bio_err, "-des           encrypt with DES\n");#endif#ifndef OPENSSL_NO_RC2		BIO_printf (bio_err, "-rc2-40        encrypt with RC2-40 (default)\n");		BIO_printf (bio_err, "-rc2-64        encrypt with RC2-64\n");		BIO_printf (bio_err, "-rc2-128       encrypt with RC2-128\n");#endif#ifndef OPENSSL_NO_AES		BIO_printf (bio_err, "-aes128, -aes192, -aes256\n");		BIO_printf (bio_err, "               encrypt PEM output with cbc aes\n");#endif		BIO_printf (bio_err, "-nointern      don't search certificates in message for signer\n");		BIO_printf (bio_err, "-nosigs        don't verify message signature\n");		BIO_printf (bio_err, "-noverify      don't verify signers certificate\n");		BIO_printf (bio_err, "-nocerts       don't include signers certificate when signing\n");		BIO_printf (bio_err, "-nodetach      use opaque signing\n");		BIO_printf (bio_err, "-noattr        don't include any signed attributes\n");		BIO_printf (bio_err, "-binary        don't translate message to text\n");		BIO_printf (bio_err, "-certfile file other certificates file\n");		BIO_printf (bio_err, "-signer file   signer certificate file\n");		BIO_printf (bio_err, "-recip  file   recipient certificate file for decryption\n");		BIO_printf (bio_err, "-in file       input file\n");		BIO_printf (bio_err, "-inform arg    input format SMIME (default), PEM or DER\n");		BIO_printf (bio_err, "-inkey file    input private key (if not signer or recipient)\n");		BIO_printf (bio_err, "-keyform arg   input private key format (PEM or ENGINE)\n");		BIO_printf (bio_err, "-out file      output file\n");		BIO_printf (bio_err, "-outform arg   output format SMIME (default), PEM or DER\n");		BIO_printf (bio_err, "-content file  supply or override content for detached signature\n");		BIO_printf (bio_err, "-to addr       to address\n");		BIO_printf (bio_err, "-from ad       from address\n");		BIO_printf (bio_err, "-subject s     subject\n");		BIO_printf (bio_err, "-text          include or delete text MIME headers\n");		BIO_printf (bio_err, "-CApath dir    trusted certificates directory\n");		BIO_printf (bio_err, "-CAfile file   trusted certificates file\n");		BIO_printf (bio_err, "-crl_check     check revocation status of signer's certificate using CRLs\n");		BIO_printf (bio_err, "-crl_check_all check revocation status of signer's certificate chain using CRLs\n");#ifndef OPENSSL_NO_ENGINE		BIO_printf (bio_err, "-engine e      use engine e, possibly a hardware device.\n");#endif		BIO_printf (bio_err, "-passin arg    input file pass phrase source\n");		BIO_printf(bio_err,  "-rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);		BIO_printf(bio_err,  "               load the file (or the files in the directory) into\n");		BIO_printf(bio_err,  "               the random number generator\n");		BIO_printf (bio_err, "cert.pem       recipient certificate(s) for encryption\n");		goto end;		}#ifndef OPENSSL_NO_ENGINE        e = setup_engine(bio_err, engine, 0);#endif	if (!app_passwd(bio_err, passargin, NULL, &passin, NULL))		{		BIO_printf(bio_err, "Error getting password\n");		goto end;		}	if (need_rand)		{		app_RAND_load_file(NULL, bio_err, (inrand != NULL));		if (inrand != NULL)			BIO_printf(bio_err,"%ld semi-random bytes loaded\n",				app_RAND_load_files(inrand));		}	ret = 2;	if (operation != SMIME_SIGN)		flags &= ~PKCS7_DETACHED;	if (operation & SMIME_OP)		{		if (flags & PKCS7_BINARY)			inmode = "rb";		if (outformat == FORMAT_ASN1)			outmode = "wb";		}	else		{		if (flags & PKCS7_BINARY)			outmode = "wb";		if (informat == FORMAT_ASN1)			inmode = "rb";		}	if (operation == SMIME_ENCRYPT)		{		if (!cipher)			{#ifndef OPENSSL_NO_RC2						cipher = EVP_rc2_40_cbc();#else			BIO_printf(bio_err, "No cipher selected\n");			goto end;#endif			}		encerts = sk_X509_new_null();		while (*args)			{			if (!(cert = load_cert(bio_err,*args,FORMAT_PEM,				NULL, e, "recipient certificate file")))				{#if 0				/* An appropriate message is already printed */				BIO_printf(bio_err, "Can't read recipient certificate file %s\n", *args);#endif				goto end;				}			sk_X509_push(encerts, cert);			cert = NULL;			args++;			}		}	if (signerfile && (operation == SMIME_SIGN))		{		if (!(signer = load_cert(bio_err,signerfile,FORMAT_PEM, NULL,			e, "signer certificate")))			{#if 0			/* An appropri message has already been printed */			BIO_printf(bio_err, "Can't read signer certificate file %s\n", signerfile);#endif			goto end;			}		}	if (certfile)		{		if (!(other = load_certs(bio_err,certfile,FORMAT_PEM, NULL,			e, "certificate file")))			{#if 0			/* An appropriate message has already been printed */			BIO_printf(bio_err, "Can't read certificate file %s\n", certfile);#endif			ERR_print_errors(bio_err);			goto end;			}		}	if (recipfile && (operation == SMIME_DECRYPT))		{		if (!(recip = load_cert(bio_err,recipfile,FORMAT_PEM,NULL,			e, "recipient certificate file")))			{#if 0			/* An appropriate message has alrady been printed */			BIO_printf(bio_err, "Can't read recipient certificate file %s\n", recipfile);#endif			ERR_print_errors(bio_err);			goto end;			}		}	if (operation == SMIME_DECRYPT)		{		if (!keyfile)			keyfile = recipfile;		}	else if (operation == SMIME_SIGN)		{		if (!keyfile)			keyfile = signerfile;		}	else keyfile = NULL;	if (keyfile)		{		key = load_key(bio_err, keyfile, keyform, 0, passin, e,			       "signing key file");		if (!key)			goto end;		}	if (infile)		{		if (!(in = BIO_new_file(infile, inmode)))			{			BIO_printf (bio_err,				 "Can't open input file %s\n", infile);			goto end;			}		}	else		in = BIO_new_fp(stdin, BIO_NOCLOSE);	if (outfile)		{		if (!(out = BIO_new_file(outfile, outmode)))			{			BIO_printf (bio_err,				 "Can't open output file %s\n", outfile);			goto end;			}		}	else		{		out = BIO_new_fp(stdout, BIO_NOCLOSE);#ifdef OPENSSL_SYS_VMS		{		    BIO *tmpbio = BIO_new(BIO_f_linebuffer());		    out = BIO_push(tmpbio, out);		}#endif		}	if (operation == SMIME_VERIFY)		{		if (!(store = setup_verify(bio_err, CAfile, CApath)))			goto end;		X509_STORE_set_verify_cb_func(store, smime_cb);		if (vpm)			X509_STORE_set1_param(store, vpm);		}	ret = 3;	if (operation == SMIME_ENCRYPT)		p7 = PKCS7_encrypt(encerts, in, cipher, flags);	else if (operation == SMIME_SIGN)		{		/* If detached data and SMIME output enable partial		 * signing.		 */		if ((flags & PKCS7_DETACHED) && (outformat == FORMAT_SMIME))			flags |= PKCS7_STREAM;		p7 = PKCS7_sign(signer, key, other, in, flags);		/* Don't need to rewind for partial signing */		if (!(flags & PKCS7_STREAM) && (BIO_reset(in) != 0))			{			BIO_printf(bio_err, "Can't rewind input file\n");			goto end;			}		}	else		{		if (informat == FORMAT_SMIME) 			p7 = SMIME_read_PKCS7(in, &indata);		else if (informat == FORMAT_PEM) 			p7 = PEM_read_bio_PKCS7(in, NULL, NULL, NULL);		else if (informat == FORMAT_ASN1) 			p7 = d2i_PKCS7_bio(in, NULL);		else			{			BIO_printf(bio_err, "Bad input format for PKCS#7 file\n");			goto end;			}		if (!p7)			{			BIO_printf(bio_err, "Error reading S/MIME message\n");			goto end;			}		if (contfile)			{			BIO_free(indata);			if (!(indata = BIO_new_file(contfile, "rb")))				{				BIO_printf(bio_err, "Can't read content file %s\n", contfile);				goto end;				}			}		}	if (!p7)		{		BIO_printf(bio_err, "Error creating PKCS#7 structure\n");		goto end;		}	ret = 4;	if (operation == SMIME_DECRYPT)		{		if (!PKCS7_decrypt(p7, key, recip, out, flags))			{			BIO_printf(bio_err, "Error decrypting PKCS#7 structure\n");			goto end;			}		}	else if (operation == SMIME_VERIFY)		{		STACK_OF(X509) *signers;		if (PKCS7_verify(p7, other, store, indata, out, flags))			BIO_printf(bio_err, "Verification successful\n");		else			{			BIO_printf(bio_err, "Verification failure\n");			goto end;			}		signers = PKCS7_get0_signers(p7, other, flags);		if (!save_certs(signerfile, signers))			{			BIO_printf(bio_err, "Error writing signers to %s\n",								signerfile);			ret = 5;			goto end;			}		sk_X509_free(signers);		}	else if (operation == SMIME_PK7OUT)		PEM_write_bio_PKCS7(out, p7);	else		{		if (to)			BIO_printf(out, "To: %s\n", to);		if (from)			BIO_printf(out, "From: %s\n", from);		if (subject)			BIO_printf(out, "Subject: %s\n", subject);		if (outformat == FORMAT_SMIME) 			SMIME_write_PKCS7(out, p7, in, flags);		else if (outformat == FORMAT_PEM) 			PEM_write_bio_PKCS7(out,p7);		else if (outformat == FORMAT_ASN1) 			i2d_PKCS7_bio(out,p7);		else			{			BIO_printf(bio_err, "Bad output format for PKCS#7 file\n");			goto end;			}		}	ret = 0;end:	if (need_rand)		app_RAND_write_file(NULL, bio_err);	if (ret) ERR_print_errors(bio_err);	sk_X509_pop_free(encerts, X509_free);	sk_X509_pop_free(other, X509_free);	if (vpm)		X509_VERIFY_PARAM_free(vpm);	X509_STORE_free(store);	X509_free(cert);	X509_free(recip);	X509_free(signer);	EVP_PKEY_free(key);	PKCS7_free(p7);	BIO_free(in);	BIO_free(indata);	BIO_free_all(out);	if (passin) OPENSSL_free(passin);	return (ret);}static int save_certs(char *signerfile, STACK_OF(X509) *signers)	{	int i;	BIO *tmp;	if (!signerfile)		return 1;	tmp = BIO_new_file(signerfile, "w");	if (!tmp) return 0;	for(i = 0; i < sk_X509_num(signers); i++)		PEM_write_bio_X509(tmp, sk_X509_value(signers, i));	BIO_free(tmp);	return 1;	}	/* Minimal callback just to output policy info (if any) */static int smime_cb(int ok, X509_STORE_CTX *ctx)	{	int error;	error = X509_STORE_CTX_get_error(ctx);	if ((error != X509_V_ERR_NO_EXPLICIT_POLICY)		&& ((error != X509_V_OK) || (ok != 2)))		return ok;	policies_print(NULL, ctx);	return ok;	}

⌨️ 快捷键说明

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