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

📄 tls_certificate.cxx

📁 这是国外的resip协议栈
💻 CXX
字号:
/* * Copyright (C) 2001-2003 Peter J Jones (pjones@pmade.org) * All Rights Reserved *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: *  * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. 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. * 3. 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 AUTHOR 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 AUTHOR * 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. */// Netxx Includes#include "TLS_cert_pimpl.h"// OpenSSL includes#include <openssl/ssl.h>#include <openssl/x509.h>#include <openssl/x509v3.h>// standard includes#include <string>//####################################################################namespace {    const char const_subject_alt_name[]	    = "subjectAltName";    const char const_field_dns[]	    = "DNS";} // end anonymous namespace//####################################################################Netxx::TLS::Certificate::Certificate (void) {}//####################################################################Netxx::TLS::Certificate::~Certificate (void) {}//####################################################################Netxx::TLS::cert_impl::cert_impl() : x509_(0), x509_name_(0) {}//####################################################################Netxx::TLS::cert_impl::~cert_impl (void) {}//####################################################################Netxx::TLS::cert_impl::operator void* (void) const {    return x509_name_;}//####################################################################bool Netxx::TLS::cert_impl::operator! (void) const {    return !x509_name_;}//####################################################################std::string Netxx::TLS::cert_impl::get_fqdn (void) const {    int extcount;    if (x509_ && ( extcount = X509_get_ext_count(x509_)) > 0) {	X509_EXTENSION *ext;	const char *extstr;	for (int i=0; i<extcount; ++i) {	    ext = X509_get_ext(x509_, i);	    extstr = OBJ_nid2sn(OBJ_obj2nid(X509_EXTENSION_get_object(ext)));	    if (std::strcmp(extstr, const_subject_alt_name) == 0) {		X509V3_EXT_METHOD *meth;		STACK_OF(CONF_VALUE) *val;		CONF_VALUE *nval;		if ( (meth = X509V3_EXT_get(ext)) == 0) break;		val = meth->i2v(meth, meth->d2i(0, &(ext->value->data), ext->value->length), 0);		for (int j=0; j<sk_CONF_VALUE_num(val); ++j) {		    nval = sk_CONF_VALUE_value(val, j);		    if (std::strcmp(nval->name, const_field_dns) == 0) return std::string(nval->value);		}	    }	}    }    return get_text(NID_commonName);}//####################################################################std::string Netxx::TLS::cert_impl::get_country (void) const {    return get_text(NID_countryName);}//####################################################################std::string Netxx::TLS::cert_impl::get_locality (void) const {    return get_text(NID_localityName);}//####################################################################std::string Netxx::TLS::cert_impl::get_region (void) const {    return get_text(NID_stateOrProvinceName);}//####################################################################std::string Netxx::TLS::cert_impl::get_organization (void) const {    return get_text(NID_organizationName);}//####################################################################std::string Netxx::TLS::cert_impl::get_organization_unit (void) const {    return get_text(NID_organizationalUnitName);}//####################################################################std::string Netxx::TLS::cert_impl::get_text (int nid) const {    std::string rc;    char name[128];    if (x509_name_ && X509_NAME_get_text_by_NID(x509_name_, nid, name, sizeof(name)) > 0) {	rc = name;    }    return rc;}//####################################################################void Netxx::TLS::cert_impl::set(X509 *x, X509_NAME *xn) {    x509_ = x;    x509_name_ = xn;}//####################################################################

⌨️ 快捷键说明

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