-dcert filename, -dkey keyname
specify an additional certificate and private key, these behave in the same manner as the -cert and -key options except there is no default if they are not specified (no additional certificate and key is used). As noted above some cipher suites require a certificate containing a key of a certain type. Some cipher suites need a certificate carrying an RSA key and some a DSS (DSA) key. By using RSA and DSS certificates and keys a server can support clients which only support RSA or DSS cipher suites by using an appropriate certificate.
-dcert文件名,-dkey密钥名
指定一个额外的证书和私钥,它们的行为方式与-cert和-key选项相同,除非没有指定它们,否则没有默认值(不使用额外的证书和密钥)。如上所述,一些密码套件需要包含特定类型密钥的证书。一些密码套件需要携带RSA密钥和一些DSS (DSA)密钥的证书。通过使用RSA和DSS证书和密钥,服务器可以通过使用适当的证书来支持仅支持RSA或DSS密码套件的客户端。
- chy-cpabe@ubuntu:~/GMSSL_certificate/sm2Certs$ gmssl s_server -gmtls -accept 44330 -key SS.key.pem -cert SS.cert.pem -dkey SE.key.pem -dcert SE.cert.pem -CAfile CA.cert.pem -state -verify 1
- verify depth is 1
- Using default temp DH parameters
- [GMTLS_DEBUG] set sm2 signing certificate
- [GMTLS_DEBUG] set sm2 signing private key
- [GMTLS_DEBUG] set sm2 encryption certificate
- [GMTLS_DEBUG] set sm2 decryption private key
- ACCEPT
- SSL_accept:before SSL initialization
- SSL_accept:before SSL initialization
- SSL_accept:SSLv3/TLS read client hello
- SSL_accept:SSLv3/TLS write server hello
- SSL_accept:SSLv3/TLS write certificate
- SSL_accept:SSLv3/TLS write key exchange
- SSL_accept:SSLv3/TLS write certificate request
- SSL_accept:SSLv3/TLS write server done
- SSL_accept:SSLv3/TLS write server done
- depth=1 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = SORB of TASS, CN = Test CA (SM2)
- verify return:1
- depth=0 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = BSRC of TASS, CN = client sign (SM2)
- verify return:1
- SSL_accept:SSLv3/TLS read client certificate
- ssl_get_algorithm2=f227000008x
- SSL_accept:SSLv3/TLS read client key exchange
- SSL_accept:SSLv3/TLS read certificate verify
- SSL_accept:SSLv3/TLS read change cipher spec
- SSL_accept:SSLv3/TLS read finished
- SSL_accept:SSLv3/TLS write change cipher spec
- SSL_accept:SSLv3/TLS write finished
- -----BEGIN SSL SESSION PARAMETERS-----
- MIICmAIBAQICAQEEAuATBCAWcAdtfPyMiEJmINUd/e/AmYdNqNTalV1AAbACRSQE
- CgQwtuURXPYQpQ7gQIZ3fWRd9QpsP0Zi57oDT1D/X1xVBL3wy9yrr/BOpRw2afsu
- 4DH3oQYCBGMw/gSiBAICHCCjggIfMIICGzCCAcGgAwIBAgIJAIVjx+dwZIdmMAoG
- CCqBHM9VAYN1MIGCMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDFNPUkIgb2YgVEFTUzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAe
- Fw0yMDA2MjAxMDE4MjZaFw0yNDA3MjkxMDE4MjZaMIGGMQswCQYDVQQGEwJDTjEL
- MAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcg
- Sk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDEJTUkMgb2YgVEFTUzEaMBgG
- A1UEAwwRY2xpZW50IHNpZ24gKFNNMikwWTATBgcqhkjOPQIBBggqgRzPVQGCLQNC
- AARV/eII1n2NVqYjwt9r9A5Eh6Z0iG+WUpsw4sGxhfKL0vr0OKcur6DZqjqLDSCr
- ZEhU6yuntNtaW+pexPblqXAroxowGDAJBgNVHRMEAjAAMAsGA1UdDwQEAwIGwDAK
- BggqgRzPVQGDdQNIADBFAiEAiX+PoCNW/n9SDbv6/o+NyCCV/7kBgunc7w5b7xGm
- 4RICIBMDlLjPZE2ACYhu1Wjqph23PfMPMgae4+Gtd7wzFz2UpAYEBAEAAAA=
- -----END SSL SESSION PARAMETERS-----
- Client certificate
- -----BEGIN CERTIFICATE-----
- MIICGzCCAcGgAwIBAgIJAIVjx+dwZIdmMAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjZaFw0yNDA3
- MjkxMDE4MjZaMIGGMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDEJTUkMgb2YgVEFTUzEaMBgGA1UEAwwRY2xpZW50IHNpZ24gKFNN
- MikwWTATBgcqhkjOPQIBBggqgRzPVQGCLQNCAARV/eII1n2NVqYjwt9r9A5Eh6Z0
- iG+WUpsw4sGxhfKL0vr0OKcur6DZqjqLDSCrZEhU6yuntNtaW+pexPblqXAroxow
- GDAJBgNVHRMEAjAAMAsGA1UdDwQEAwIGwDAKBggqgRzPVQGDdQNIADBFAiEAiX+P
- oCNW/n9SDbv6/o+NyCCV/7kBgunc7w5b7xGm4RICIBMDlLjPZE2ACYhu1Wjqph23
- PfMPMgae4+Gtd7wzFz2U
- -----END CERTIFICATE-----
- subject=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=client sign (SM2)
- issuer=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- Shared ciphers:SM9-WITH-SMS4-SM3:SM9DHE-WITH-SMS4-SM3:SM2-WITH-SMS4-SM3:SM2DHE-WITH-SMS4-SM3:RSA-WITH-SMS4-SHA1:RSA-WITH-SMS4-SM3
- CIPHER is SM2-WITH-SMS4-SM3
- Secure Renegotiation IS supported
- chy-cpabe@ubuntu:~/GMSSL_certificate/sm2Certs$ gmssl s_client -gmtls -connect localhost:44330 -key CS.key.pem -cert CS.cert.pem -dkey CE.key.pem -dcert CE.cert.pem -CAfile CA.cert.pem -state -showcerts
- [GMTLS_DEBUG] set sm2 signing certificate
- [GMTLS_DEBUG] set sm2 signing private key
- [GMTLS_DEBUG] set sm2 encryption certificate
- [GMTLS_DEBUG] set sm2 decryption private key
- CONNECTED(00000003)
- SSL_connect:before SSL initialization
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS read server hello
- depth=1 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = SORB of TASS, CN = Test CA (SM2)
- verify return:1
- depth=0 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = BSRC of TASS, CN = server sign (SM2)
- verify return:1
- SSL_connect:SSLv3/TLS read server certificate
- Z=BCDCCB61AADD790C076DAC60ED09DDD5285A906A4025DD748DA2FB5816464C58
- C=00021E3082021A308201C0A0030201020209008563C7E770648765300A06082A811CCF55018375308182310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C534F5242206F6620544153533116301406035504030C0D546573742043412028534D3229301E170D3230303632303130313832365A170D3234303732393130313832365A308185310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C42535243206F6620544153533119301706035504030C1073657276657220656E632028534D32293059301306072A8648CE3D020106082A811CCF5501822D03420004B999853302F02CC522CC4CCA287019E86B901FC24E3CCF9A61B93BB177B28C2CE8E23C5C522DF73C23F7AC36FF688CB2E685A3FA4770103F7C99EFC32D06C11FA31A301830090603551D1304023000300B0603551D0F040403020338300A06082A811CCF550183750348003045022100EC4368F400870BED441817AF4D359BDC61A9EDFDDEE54AB0C185084B450C46B902206E0C3A08BC584590046DC85603CD4E8A51F97D9669B1ACA3E2A3627BE61D49A2
- SSL_connect:SSLv3/TLS read server key exchange
- SSL_connect:SSLv3/TLS read server certificate request
- SSL_connect:SSLv3/TLS read server done
- SSL_connect:SSLv3/TLS write client certificate
- SSL_connect:SSLv3/TLS write client key exchange
- ssl_get_algorithm2=3268600008x
- SSL_connect:SSLv3/TLS write certificate verify
- SSL_connect:SSLv3/TLS write change cipher spec
- SSL_connect:SSLv3/TLS write finished
- SSL_connect:SSLv3/TLS write finished
- SSL_connect:SSLv3/TLS read change cipher spec
- SSL_connect:SSLv3/TLS read finished
- ---
- Certificate chain
- 0 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- -----BEGIN CERTIFICATE-----
- MIICGjCCAcGgAwIBAgIJAIVjx+dwZIdkMAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjVaFw0yNDA3
- MjkxMDE4MjVaMIGGMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDEJTUkMgb2YgVEFTUzEaMBgGA1UEAwwRc2VydmVyIHNpZ24gKFNN
- MikwWTATBgcqhkjOPQIBBggqgRzPVQGCLQNCAAS0lHzt7CkOzCtyf6VwCqoT2PYD
- CL/AJrCsHa+6lE8wDZ7DShI2bvfmrpavndEW67CHQOlO0q6/aoEB0PoAgpopoxow
- GDAJBgNVHRMEAjAAMAsGA1UdDwQEAwIGwDAKBggqgRzPVQGDdQNHADBEAiB06JWp
- uxFbGBfvG9juhe2Umu/auI1H2XeMdvDjbOtfuQIgMXT8jewkzq9TR3OPzRTkZCRH
- 3H+xKEb8r8JsEEStwaU=
- -----END CERTIFICATE-----
- 1 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server enc (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- -----BEGIN CERTIFICATE-----
- MIICGjCCAcCgAwIBAgIJAIVjx+dwZIdlMAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjZaFw0yNDA3
- MjkxMDE4MjZaMIGFMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDEJTUkMgb2YgVEFTUzEZMBcGA1UEAwwQc2VydmVyIGVuYyAoU00y
- KTBZMBMGByqGSM49AgEGCCqBHM9VAYItA0IABLmZhTMC8CzFIsxMyihwGehrkB/C
- TjzPmmG5O7F3sows6OI8XFIt9zwj96w2/2iMsuaFo/pHcBA/fJnvwy0GwR+jGjAY
- MAkGA1UdEwQCMAAwCwYDVR0PBAQDAgM4MAoGCCqBHM9VAYN1A0gAMEUCIQDsQ2j0
- AIcL7UQYF69NNZvcYant/d7lSrDBhQhLRQxGuQIgbgw6CLxYRZAEbchWA81OilH5
- fZZpsayj4qNie+YdSaI=
- -----END CERTIFICATE-----
- 2 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- -----BEGIN CERTIFICATE-----
- MIICWjCCAgCgAwIBAgIJAP5W2mLaOWq5MAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjVaFw0yNDA3
- MjkxMDE4MjVaMIGCMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDFNPUkIgb2YgVEFTUzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTBZ
- MBMGByqGSM49AgEGCCqBHM9VAYItA0IABArjN7ag+H8D12eqXJpMeTOR9m3sB2RC
- ojH7fZPB77SDfHZb9g1lcqUhrug0nw2F8wBMsLfjvsK3wQn/ryi3YvSjXTBbMB0G
- A1UdDgQWBBRCcBGiEpd09qSpUlkiGkZ+q+CFbDAfBgNVHSMEGDAWgBRCcBGiEpd0
- 9qSpUlkiGkZ+q+CFbDAMBgNVHRMEBTADAQH/MAsGA1UdDwQEAwIBBjAKBggqgRzP
- VQGDdQNIADBFAiBjdylWVsUoTRcHu9DoMHv4lgtYJMf2xHAGLoJUjmbizAIhAOFD
- i3EmFVUgGVdgbnztFZcBLxtBzIAh/Q4Q3dm3/MFu
- -----END CERTIFICATE-----
- ---
- Server certificate
- subject=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- issuer=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- ---
- Acceptable client certificate CA names
- /C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- Client Certificate Types: RSA sign, DSA sign
- ---
- SSL handshake has read 2121 bytes and written 2115 bytes
- Verification: OK
- ---
- New, GMTLSv1.1, Cipher is SM2-WITH-SMS4-SM3
- Server public key is 256 bit
- Secure Renegotiation IS NOT supported
- Compression: NONE
- Expansion: NONE
- No ALPN negotiated
- SSL-Session:
- Protocol : GMTLSv1.1
- Cipher : SM2-WITH-SMS4-SM3
- Session-ID: 1670076D7CFC8C88426620D51DFDEFC099874DA8D4DA955D4001B0024524040A
- Session-ID-ctx:
- Master-Key: B6E5115CF610A50EE04086777D645DF50A6C3F4662E7BA034F50FF5F5C5504BDF0CBDCABAFF04EA51C3669FB2EE031F7
- PSK identity: None
- PSK identity hint: None
- SRP username: None
- Start Time: 1664155140
- Timeout : 7200 (sec)
- Verify return code: 0 (ok)
- Extended master secret: no
- ---
-
- s_server: Cannot open input file gmcrt/2_sign.crt, No such file or directory
- s_server: Use -help for summary.
- chy-cpabe@ubuntu:~/test_double_ssl/GMSSL双证书demo/sm2Certs$ ls
- CA.cert.pem CA.key.pem CA.pem CE.cert.pem CE.key.pem CE.pem CS.cert.pem CS.key.pem CS.pem SE.cert.pem SE.key.pem SE.pem SS.cert.pem SS.key.pem SS.pem
- chy-cpabe@ubuntu:~/test_double_ssl/GMSSL双证书demo/sm2Certs$ gmssl s_server -gmtls -accept 44330 -key SS.key.pem -cert SS.cert.pem -dkey SE.key.pem -dcert SE.cert.pem -CAfile CA.cert.pem -state
- Using default temp DH parameters
- [GMTLS_DEBUG] set sm2 signing certificate
- [GMTLS_DEBUG] set sm2 signing private key
- [GMTLS_DEBUG] set sm2 encryption certificate
- [GMTLS_DEBUG] set sm2 decryption private key
- ACCEPT
- SSL_accept:before SSL initialization
- SSL_accept:before SSL initialization
- ssl_get_algorithm2=2b81000008x
- SSL_accept:SSLv3/TLS read client hello
- SSL_accept:SSLv3/TLS write server hello
- SSL_accept:SSLv3/TLS write certificate
- SSL_accept:SSLv3/TLS write key exchange
- SSL_accept:SSLv3/TLS write server done
- SSL_accept:SSLv3/TLS write server done
- SSL_accept:SSLv3/TLS read client key exchange
- SSL_accept:SSLv3/TLS read change cipher spec
- SSL_accept:SSLv3/TLS read finished
- SSL_accept:SSLv3/TLS write change cipher spec
- SSL_accept:SSLv3/TLS write finished
- -----BEGIN SSL SESSION PARAMETERS-----
- MHUCAQECAgEBBALgEwQg4tsFtm05e9thEdmOsDjCdEY797x1PAcVaGWd8chdLuoE
- MDqjvlXZek3vSlC1q+aYT7NA40D6C7sbR0gNowPIhMfVan396kWxthLUmXIgz3t1
- 5qEGAgRjAfsxogQCAhwgpAYEBAEAAAA=
- -----END SSL SESSION PARAMETERS-----
- Shared ciphers:SM9-WITH-SMS4-SM3:SM9DHE-WITH-SMS4-SM3:SM2-WITH-SMS4-SM3:SM2DHE-WITH-SMS4-SM3:RSA-WITH-SMS4-SHA1:RSA-WITH-SMS4-SM3
- CIPHER is SM2-WITH-SMS4-SM3
- Secure Renegotiation IS supported
-
- [GMTLS_DEBUG] set sm2 signing certificate
- [GMTLS_DEBUG] set sm2 signing private key
- [GMTLS_DEBUG] set sm2 encryption certificate
- [GMTLS_DEBUG] set sm2 decryption private key
- CONNECTED(00000003)
- SSL_connect:before SSL initialization
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS read server hello
- depth=1 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = SORB of TASS, CN = Test CA (SM2)
- verify return:1
- depth=0 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = BSRC of TASS, CN = server sign (SM2)
- verify return:1
- SSL_connect:SSLv3/TLS read server certificate
- Z=BCDCCB61AADD790C076DAC60ED09DDD5285A906A4025DD748DA2FB5816464C58
- C=00021E3082021A308201C0A0030201020209008563C7E770648765300A06082A811CCF55018375308182310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C534F5242206F6620544153533116301406035504030C0D546573742043412028534D3229301E170D3230303632303130313832365A170D3234303732393130313832365A308185310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C42535243206F6620544153533119301706035504030C1073657276657220656E632028534D32293059301306072A8648CE3D020106082A811CCF5501822D03420004B999853302F02CC522CC4CCA287019E86B901FC24E3CCF9A61B93BB177B28C2CE8E23C5C522DF73C23F7AC36FF688CB2E685A3FA4770103F7C99EFC32D06C11FA31A301830090603551D1304023000300B0603551D0F040403020338300A06082A811CCF550183750348003045022100EC4368F400870BED441817AF4D359BDC61A9EDFDDEE54AB0C185084B450C46B902206E0C3A08BC584590046DC85603CD4E8A51F97D9669B1ACA3E2A3627BE61D49A2
- SSL_connect:SSLv3/TLS read server key exchange
- SSL_connect:SSLv3/TLS read server done
- SSL_connect:SSLv3/TLS write client key exchange
- SSL_connect:SSLv3/TLS write change cipher spec
- ssl_get_algorithm2=2790100008x
- SSL_connect:SSLv3/TLS write finished
- SSL_connect:SSLv3/TLS write finished
- SSL_connect:SSLv3/TLS read change cipher spec
- SSL_connect:SSLv3/TLS read finished
- ---
- Certificate chain
- 0 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- 1 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server enc (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- 2 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- ---
- Server certificate
- -----BEGIN CERTIFICATE-----
- MIICGjCCAcGgAwIBAgIJAIVjx+dwZIdkMAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjVaFw0yNDA3
- MjkxMDE4MjVaMIGGMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDEJTUkMgb2YgVEFTUzEaMBgGA1UEAwwRc2VydmVyIHNpZ24gKFNN
- MikwWTATBgcqhkjOPQIBBggqgRzPVQGCLQNCAAS0lHzt7CkOzCtyf6VwCqoT2PYD
- CL/AJrCsHa+6lE8wDZ7DShI2bvfmrpavndEW67CHQOlO0q6/aoEB0PoAgpopoxow
- GDAJBgNVHRMEAjAAMAsGA1UdDwQEAwIGwDAKBggqgRzPVQGDdQNHADBEAiB06JWp
- uxFbGBfvG9juhe2Umu/auI1H2XeMdvDjbOtfuQIgMXT8jewkzq9TR3OPzRTkZCRH
- 3H+xKEb8r8JsEEStwaU=
- -----END CERTIFICATE-----
- subject=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- issuer=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- ---
- No client certificate CA names sent
- ---
- SSL handshake has read 1973 bytes and written 320 bytes
- Verification: OK
- ---
- New, GMTLSv1.1, Cipher is SM2-WITH-SMS4-SM3
- Server public key is 256 bit
- Secure Renegotiation IS NOT supported
- Compression: NONE
- Expansion: NONE
- No ALPN negotiated
- SSL-Session:
- Protocol : GMTLSv1.1
- Cipher : SM2-WITH-SMS4-SM3
- Session-ID: E24D8195A9D25F9A6B877C63A85979492FA5199E58FA512A95915E33BA7A418B
- Session-ID-ctx:
- Master-Key: 2ED26139965074A55F65D011A370DF7A4672A0FC7BBB4A0ED991DCD55A6231E92B5A09225BFE9F1ABD0546F1F75885A2
- PSK identity: None
- PSK identity hint: None
- SRP username: None
- Start Time: 1661073328
- Timeout : 7200 (sec)
- Verify return code: 0 (ok)
- Extended master secret: no
- ---
-
- gmssl s_client -gmtls -connect localhost:44330 -key CS.key.pem -cert CS.cert.pem -dkey CE.key.pem -dcert CE.cert.pem -CAfile CA.cert.pem -state
- [GMTLS_DEBUG] set sm2 signing certificate
- [GMTLS_DEBUG] set sm2 signing private key
- [GMTLS_DEBUG] set sm2 encryption certificate
- [GMTLS_DEBUG] set sm2 decryption private key
- CONNECTED(00000003)
- SSL_connect:before SSL initialization
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS write client hello
- SSL_connect:SSLv3/TLS read server hello
- depth=1 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = SORB of TASS, CN = Test CA (SM2)
- verify return:1
- depth=0 C = CN, ST = BJ, L = HaiDian, O = Beijing JNTA Technology LTD., OU = BSRC of TASS, CN = server sign (SM2)
- verify return:1
- SSL_connect:SSLv3/TLS read server certificate
- Z=BCDCCB61AADD790C076DAC60ED09DDD5285A906A4025DD748DA2FB5816464C58
- C=00021E3082021A308201C0A0030201020209008563C7E770648765300A06082A811CCF55018375308182310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C534F5242206F6620544153533116301406035504030C0D546573742043412028534D3229301E170D3230303632303130313832365A170D3234303732393130313832365A308185310B300906035504061302434E310B300906035504080C02424A3110300E06035504070C074861694469616E31253023060355040A0C1C4265696A696E67204A4E544120546563686E6F6C6F6779204C54442E31153013060355040B0C0C42535243206F6620544153533119301706035504030C1073657276657220656E632028534D32293059301306072A8648CE3D020106082A811CCF5501822D03420004B999853302F02CC522CC4CCA287019E86B901FC24E3CCF9A61B93BB177B28C2CE8E23C5C522DF73C23F7AC36FF688CB2E685A3FA4770103F7C99EFC32D06C11FA31A301830090603551D1304023000300B0603551D0F040403020338300A06082A811CCF550183750348003045022100EC4368F400870BED441817AF4D359BDC61A9EDFDDEE54AB0C185084B450C46B902206E0C3A08BC584590046DC85603CD4E8A51F97D9669B1ACA3E2A3627BE61D49A2
- SSL_connect:SSLv3/TLS read server key exchange
- SSL_connect:SSLv3/TLS read server certificate request
- SSL_connect:SSLv3/TLS read server done
- SSL_connect:SSLv3/TLS write client certificate
- SSL_connect:SSLv3/TLS write client key exchange
- ssl_get_algorithm2=3c3f900008x
- SSL_connect:SSLv3/TLS write certificate verify
- SSL_connect:SSLv3/TLS write change cipher spec
- SSL_connect:SSLv3/TLS write finished
- SSL3 alert read:fatal:decrypt error
- SSL_connect:error in SSLv3/TLS write finished
- 140016949239808:error:1409441B:SSL routines:ssl3_read_bytes:tlsv1 alert decrypt error:ssl/record/rec_layer_s3.c:1385:SSL alert number 51
- ---
- Certificate chain
- 0 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- 1 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server enc (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- 2 s:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- i:/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- ---
- Server certificate
- -----BEGIN CERTIFICATE-----
- MIICGjCCAcGgAwIBAgIJAIVjx+dwZIdkMAoGCCqBHM9VAYN1MIGCMQswCQYDVQQG
- EwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcMB0hhaURpYW4xJTAjBgNVBAoMHEJl
- aWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4xFTATBgNVBAsMDFNPUkIgb2YgVEFT
- UzEWMBQGA1UEAwwNVGVzdCBDQSAoU00yKTAeFw0yMDA2MjAxMDE4MjVaFw0yNDA3
- MjkxMDE4MjVaMIGGMQswCQYDVQQGEwJDTjELMAkGA1UECAwCQkoxEDAOBgNVBAcM
- B0hhaURpYW4xJTAjBgNVBAoMHEJlaWppbmcgSk5UQSBUZWNobm9sb2d5IExURC4x
- FTATBgNVBAsMDEJTUkMgb2YgVEFTUzEaMBgGA1UEAwwRc2VydmVyIHNpZ24gKFNN
- MikwWTATBgcqhkjOPQIBBggqgRzPVQGCLQNCAAS0lHzt7CkOzCtyf6VwCqoT2PYD
- CL/AJrCsHa+6lE8wDZ7DShI2bvfmrpavndEW67CHQOlO0q6/aoEB0PoAgpopoxow
- GDAJBgNVHRMEAjAAMAsGA1UdDwQEAwIGwDAKBggqgRzPVQGDdQNHADBEAiB06JWp
- uxFbGBfvG9juhe2Umu/auI1H2XeMdvDjbOtfuQIgMXT8jewkzq9TR3OPzRTkZCRH
- 3H+xKEb8r8JsEEStwaU=
- -----END CERTIFICATE-----
- subject=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=BSRC of TASS/CN=server sign (SM2)
- issuer=/C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- ---
- Acceptable client certificate CA names
- /C=CN/ST=BJ/L=HaiDian/O=Beijing JNTA Technology LTD./OU=SORB of TASS/CN=Test CA (SM2)
- Client Certificate Types: RSA sign, DSA sign
- ---
- SSL handshake has read 2037 bytes and written 2116 bytes
- Verification: OK
- ---
- New, GMTLSv1.1, Cipher is SM2-WITH-SMS4-SM3
- Server public key is 256 bit
- Secure Renegotiation IS NOT supported
- Compression: NONE
- Expansion: NONE
- No ALPN negotiated
- SSL-Session:
- Protocol : GMTLSv1.1
- Cipher : SM2-WITH-SMS4-SM3
- Session-ID: 12664AE82CE989580C27B14AFF7487B19FF1C159C94291A0B76AA5F80D28317F
- Session-ID-ctx:
- Master-Key: AD4D5164B7F54B9FA1F74A7A569C6B6E75CFD96967AB7519658C33E9C6FB8851EBCF1B10E175E736E9C7127E5FA8D32D
- PSK identity: None
- PSK identity hint: None
- SRP username: None
- Start Time: 1661074697
- Timeout : 7200 (sec)
- Verify return code: 0 (ok)
- Extended master secret: no
- ---
- // 是否要求校验对方证书 此处不验证客户端身份所以为: SSL_VERIFY_NONE
- SSL_CTX_set_verify(ctx, SSL_VERIFY_NONE, NULL);
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
-
- #define MAXBUF 1500
-
- //#define CA_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CA.cert.pem"
- //#define SIGN_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/SS.cert.pem"
- //#define SIGN_KEY_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/SS.key.pem"
- //#define ENCODE_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/SE.cert.pem"
- //#define ENCODE_KEY_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/SE.key.pem"
-
- #define CA_CERT_FILE "/home/chy-cpabe/tmp/second/rootcert.pem"
- #define SIGN_CERT_FILE "/home/chy-cpabe/tmp/second/sign.pem"
- #define SIGN_KEY_FILE "/home/chy-cpabe/tmp/second/sign.key"
- #define ENCODE_CERT_FILE "/home/chy-cpabe/tmp/second/encrypt.pem"
- #define ENCODE_KEY_FILE "/home/chy-cpabe/tmp/second/encrypt.key"
-
- void ShowCerts(SSL * ssl)
- {
- X509 *cert;
- char *line;
-
- cert = SSL_get_peer_certificate(ssl);
- // SSL_get_verify_result()是重点,SSL_CTX_set_verify()只是配置启不启用并没有执行认证,调用该函数才会真证进行证书认证
- // 如果验证不通过,那么程序抛出异常中止连接
- if(SSL_get_verify_result(ssl) == X509_V_OK){
- printf("证书验证通过\n");
- }
- if (cert != nullptr) {
- printf("数字证书信息:\n");
- line = X509_NAME_oneline(X509_get_subject_name(cert), nullptr, 0);
- printf("证书: %s\n", line);
- free(line);
- line = X509_NAME_oneline(X509_get_issuer_name(cert), nullptr, 0);
- printf("颁发者: %s\n", line);
- free(line);
- X509_free(cert);
- } else
- printf("无证书信息!\n");
- }
-
- int main(int argc, char **argv) {
- int listen_fd = -1; /* TCP监听套接字 */
- int accept_fd = -1; /* 已连接TCP套接字 */
- struct sockaddr_in server_addr, client_addr;
- bzero(&server_addr, sizeof(server_addr));
-
- SSL_CTX *ctx = nullptr; /* SSL会话环境 */
-
- SSL *ssl = nullptr; /* SSL安全套接字 */
- socklen_t len;
- char buf[MAXBUF]={0}; /* 服务器接收数据buffer */
-
-
- if( 3!=argc )
- {
- printf("argcment wrong:ip port\n");
- }
-
- SSL_library_init(); /* SSL 库初始化 */
- SSLeay_add_ssl_algorithms();
- OpenSSL_add_all_algorithms(); /* 载入所有 SSL 算法 */
- SSL_load_error_strings(); /* 载入所有 SSL 错误消息 */
- // ERR_load_BIO_strings();
-
-
- //TCP服务器:创建、绑定、监听
- if ((listen_fd = socket(PF_INET, SOCK_STREAM, 0)) == -1) {
- perror("socket create wrong\n");
- exit(1);
- } else
- printf("socket created\n");
-
- server_addr.sin_family = PF_INET;
- server_addr.sin_port = htons(atoi(argv[2]));
- server_addr.sin_addr.s_addr = inet_addr(argv[1]);;
-
- if (bind(listen_fd, (struct sockaddr *) &server_addr, sizeof(struct sockaddr))
- == -1) {
- perror("bind wrong\n");
- exit(1);
- } else
- printf("binded success\n");
- int lisnum = 2;
-
- do{
- //使用SSL_CTX_new()创建会话环境,建立连接时要使用协议由TLS_server_method()来定。如果这一步出错,需要查看错误栈来查看原因
- if(nullptr == (ctx = SSL_CTX_new( GMTLS_server_method()))) //using sm3, TLSv1_2_method
- {
- ERR_print_errors_fp(stderr);
- break;
- }
- // SSL_CTX_set_security_level(ctx,0);
-
-
- // 双向验证
- // SSL_VERIFY_PEER---要求对证书进行认证,没有证书也会放行
- // SSL_VERIFY_FAIL_IF_NO_PEER_CERT---要求客户端需要提供证书,但验证发现单独使用没有证书也会放行
- SSL_CTX_set_verify(ctx, SSL_VERIFY_PEER|SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr);
-
- // 设置信任根证书
- if(SSL_CTX_load_verify_locations(ctx, CA_CERT_FILE, nullptr) != 1)
- {
- printf("SSL_CTX_load_verify_locations error\n");
- ERR_print_errors_fp(stderr);
- break;
- }
-
- // 签名证书和对应私钥
- if( 0>=SSL_CTX_use_certificate_file(ctx, SIGN_CERT_FILE, SSL_FILETYPE_PEM/*SSL_FILETYPE_ASN1*/) ) /* 为SSL会话加载用户证书 */
- {
- printf("SSL_CTX_use_certificate_file error!\n");
- ERR_print_errors_fp(stderr);
- break;
- }
- if( 0>=SSL_CTX_use_PrivateKey_file(ctx, SIGN_KEY_FILE, SSL_FILETYPE_PEM/*SSL_FILETYPE_ASN1*/) ) /* 为SSL会话加载用户私钥 */
- {
- printf("SSL_CTX_use_PrivateKey_file error!\n");
- ERR_print_errors_fp(stderr);
- break;
- }
- // 加密证书和对应私钥
- if(SSL_CTX_use_certificate_file(ctx, ENCODE_CERT_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_certificate_file error!\n");
- ERR_print_errors_fp(stderr);
- return -1;
- }
- if(SSL_CTX_use_PrivateKey_file(ctx, ENCODE_KEY_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_PrivateKey_file error!\n");
- ERR_print_errors_fp(stderr);
- return -1;
- }
-
- /* 检查用户私钥是否正确 */
- if(!SSL_CTX_check_private_key(ctx)) /* 验证私钥和证书是否相符 */
- {
- printf("SSL_CTX_check_private_key error!\n");
- ERR_print_errors_fp(stderr);
- break;
- }
-
- if (listen(listen_fd, lisnum) == -1) {
- perror("listen wrong\n");
- exit(1);
- } else
- printf("begin listen\n");
-
- len = sizeof(struct sockaddr);
- /* 等待客户端连上来 */
- if ((accept_fd = accept(listen_fd, (struct sockaddr *) &client_addr, &len))
- == -1) {
- perror("accept wrong\n");
- exit(errno);
- } else{
- printf("server: got connection from %s, port %d, socket %d\n",
- inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port),
- accept_fd);
- }
-
- ssl = SSL_new(ctx); /* 基于 ctx 产生一个新的 SSL */
- SSL_set_fd(ssl, accept_fd); /* 将连接用户的 socket 加入到 SSL */
- /* 建立 SSL 连接 */
- if (SSL_accept(ssl) == -1) {
- perror("accept wrong\n");
- SSL_shutdown(ssl);
- SSL_free(ssl);
- ssl= nullptr;
- close(accept_fd);
- accept_fd=-1;
- break;
- }
- ShowCerts(ssl);
-
- /* 开始处理每个新连接上的数据收发 */
- bzero(buf, MAXBUF + 1);
- strcpy(buf, "server->client");
- /* 发消息给客户端 */
- len = SSL_write(ssl, buf, strlen(buf));
-
- if (len <= 0) {
- printf("消息'%s'发送失败!错误代码是%d,错误信息是'%s'\n", buf, errno,
- strerror(errno));
- goto finish;
- } else
- printf("消息'%s'发送成功,共发送了%d个字节!\n", buf, len);
-
- bzero(buf, MAXBUF + 1);
- /* 接收客户端的消息 */
- len = SSL_read(ssl, buf, MAXBUF);
- if (len > 0)
- printf("接收消息成功:'%s',共%d个字节的数据\n", buf, len);
- else
- printf("消息接收失败!错误代码是%d,错误信息是'%s'\n",
- errno, strerror(errno));
- /* 处理每个新连接上的数据收发结束 */
- finish:
- /* 关闭 SSL 连接 */
- SSL_shutdown(ssl);
- /* 释放 SSL */
- SSL_free(ssl);
- ssl = nullptr;
- /* 关闭 socket */
- close(accept_fd);
- accept_fd = -1;
- }while(1);
-
- /* 关闭监听的 socket */
- close(listen_fd);
- listen_fd = -1;
- /* 释放 CTX */
- SSL_CTX_free(ctx);
- ctx = nullptr;
- return 0;
- }
-
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
- #include
-
- #define MAXBUF 1024
- //#define CA_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CA.cert.pem"
- //#define CS_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CS.cert.pem"
- //#define CS_KEY_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CS.key.pem"
- //#define CE_CERT_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CE.cert.pem"
- //#define CE_KEY_FILE "/home/chy-cpabe/GMSSL_certificate/sm2Certs/CE.key.pem"
-
- #define CA_CERT_FILE "/home/chy-cpabe/tmp/first/rootcert.pem"
- #define CS_CERT_FILE "/home/chy-cpabe/tmp/first/sign.pem"
- #define CS_KEY_FILE "/home/chy-cpabe/tmp/first/sign.key"
- #define CE_CERT_FILE "/home/chy-cpabe/tmp/first/encrypt.pem"
- #define CE_KEY_FILE "/home/chy-cpabe/tmp/first/encrypt.key"
- void ShowCerts(SSL * ssl)
- {
- X509 *cert;
- char *line;
-
- cert = SSL_get_peer_certificate(ssl);
- // SSL_get_verify_result()是重点,SSL_CTX_set_verify()只是配置启不启用并没有执行认证,调用该函数才会真证进行证书认证
- // 如果验证不通过,那么程序抛出异常中止连接
- if(SSL_get_verify_result(ssl) == X509_V_OK){
- printf("证书验证通过\n");
- }
- if (cert != nullptr) {
- printf("数字证书信息:\n");
- line = X509_NAME_oneline(X509_get_subject_name(cert), nullptr, 0);
- printf("证书: %s\n", line);
- free(line);
- line = X509_NAME_oneline(X509_get_issuer_name(cert), nullptr, 0);
- printf("颁发者: %s\n", line);
- free(line);
- X509_free(cert);
- } else
- printf("无证书信息!\n");
- }
-
- static void PrintData(char *p, char *buf,int len,char *filename)
- {
- char *name=p;
- printf("%s[%d]:\n",p,len);
- for (p=buf; p && p++-buf
- printf("%02x%c",(unsigned char)p[-1],(!((p-buf)%16) || p-buf==len)?'\n':' ');
- // if (filename) FileWrite(name,buf,len,filename);
- }
-
- int main(int argc, char **argv)
- {
- int sock_fd = -1; /* TCP套接字 */
- int len = 0; /* SSL会话环境 */
- SSL *ssl = nullptr; /* SSL安全套接字 */
- struct sockaddr_in ser_addr; /* 服务器地址 */
- bzero(&ser_addr, sizeof(ser_addr));
- SSL_CTX *ctx = nullptr;
- char buffer[MAXBUF + 1];
-
- if( argc != 3 )
- {
- printf("argcment wrong:ip port content\n");
- exit(0);
- }
-
- /* SSL 库初始化,参看 ssl-server.c 代码 */
- SSL_library_init();
- SSLeay_add_ssl_algorithms();
- OpenSSL_add_all_algorithms();
- SSL_load_error_strings();
- // ERR_load_BIO_strings();
-
- do{
- /* 申请SSL会话环境 */
- if( nullptr==(ctx=SSL_CTX_new(GMTLS_client_method())) ) //使用SSL_CTX_new()创建会话环境,建立连接时要使用协议由TLS_client_method()来定,服务器由对应的TLS_server_method()来定。如果这一步出错,需要查看错误栈来查看原因
- {
- printf("SSL_CTX_new error!\n");
- ERR_print_errors_fp(stderr);
- break;
- }
- // 双向验证
- // SSL_VERIFY_PEER---要求对证书进行认证,没有证书也会放行
- // SSL_VERIFY_FAIL_IF_NO_PEER_CERT---要求客户端需要提供证书,但验证发现单独使用没有证书也会放行
- SSL_CTX_set_verify(ctx, SSL_VERIFY_PEER|SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr);
- // if(SSL_CTX_set_cipher_list(ctx, "ECC-SM2-WITH-SM4-SM3") <= 0){
- // printf("SSL_CTX_set_cipher_list error!\n");
- // ERR_print_errors_fp(stderr);
- // exit(1);
- // }
- // 设置信任根证书
- if(SSL_CTX_load_verify_locations(ctx, CA_CERT_FILE, nullptr) != 1)
- {
- printf("SSL_CTX_load_verify_locations error!\n");
- ERR_print_errors_fp(stderr);
- exit(1);
- }
-
- // 签名证书和对应私钥
- if (SSL_CTX_use_certificate_file(ctx, CS_CERT_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_certificate_file error!\n");
- ERR_print_errors_fp(stderr);
- exit(1);
- }
- if (SSL_CTX_use_PrivateKey_file(ctx, CS_KEY_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_PrivateKey_file error!\n");
- ERR_print_errors_fp(stderr);
- exit(1);
- }
- // 加密证书和对应私钥
- if(SSL_CTX_use_certificate_file(ctx, CE_CERT_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_certificate_file error!\n");
- ERR_print_errors_fp(stderr);
- return -1;
- }
-
- if(SSL_CTX_use_PrivateKey_file(ctx, CE_KEY_FILE, SSL_FILETYPE_PEM) <= 0)
- {
- printf("SSL_CTX_use_PrivateKey_file error!\n");
- ERR_print_errors_fp(stderr);
- return -1;
- }
- //判定私钥是否正确
- if (!SSL_CTX_check_private_key(ctx)) {
- printf("SSL_CTX_check_private_key error!\n");
- ERR_print_errors_fp(stderr);
- exit(1);
- }
- // SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
- /* 创建一个 socket 用于 tcp 通信 */
- if(-1==(sock_fd=socket(AF_INET, SOCK_STREAM, 0)) )
- {
- printf("creat socket wrong\n");
- break;
- }
- printf("socket created\n");
- /* 初始化服务器端(对方)的地址和端口信息 */
- ser_addr.sin_family = AF_INET;
- ser_addr.sin_port = htons(atoi(argv[2]));
- ser_addr.sin_addr.s_addr = inet_addr(argv[1]);
-
- printf("address created\n");
- //建立连接
- if( -1==(connect(sock_fd, (struct sockaddr *)&ser_addr, sizeof(ser_addr))) )
- {
- printf("connect wrong\n");
- break;
- }
- printf("server connected\n");
-
- /* 基于 ctx 产生一个新的 SSL */
- ssl = SSL_new(ctx);
- SSL_set_fd(ssl, sock_fd);
- /* 建立 SSL 连接 */
- if (SSL_connect(ssl) == -1)
- ERR_print_errors_fp(stderr);
- else {
- printf("The relevant information is as follows:\n");
- printf("-->ssl version %s\n",SSL_get_version(ssl));
- printf("-->ssleay version %s\n",SSLeay_version(0));
- printf("-->Connected with %s encryption\n", SSL_get_cipher(ssl));
- ShowCerts(ssl);
- }
-
- //导出key和salt
- unsigned char buf[16];
- int err = -1;
- err = SSL_export_keying_material(ssl, buf, 16, nullptr,0, nullptr, 0, 1);
- if(err != 1){
- printf("SSL_export_keying_material error,err=%d\n",err);
- }else{
- PrintData("SSL_export_keying_material", (char*)buf, 16, nullptr);
- }
-
-
- /* 接收对方发过来的消息,最多接收 MAXBUF 个字节 */
- bzero(buffer, MAXBUF + 1);
- /* 接收服务器来的消息 */
- len = SSL_read(ssl, buffer, MAXBUF);
- if (len > 0)
- printf("接收消息成功:'%s',共%d个字节的数据\n",
- buffer, len);
- else {
- printf
- ("消息接收失败!错误代码是%d,错误信息是'%s'\n",
- errno, strerror(errno));
- goto finish;
- }
- bzero(buffer, MAXBUF + 1);
- strcpy(buffer, "from client->server");
- /* 发消息给服务器 */
- len = SSL_write(ssl, buffer, strlen(buffer));
- if (len < 0)
- printf
- ("消息'%s'发送失败!错误代码是%d,错误信息是'%s'\n",
- buffer, errno, strerror(errno));
- else
- printf("消息'%s'发送成功,共发送了%d个字节!\n",
- buffer, len);
-
- /* 处理每个新连接上的数据收发结束 */
- finish:
- /* 关闭 SSL 连接 */
- SSL_shutdown(ssl);
- /* 释放 SSL */
- SSL_free(ssl);
- ssl = nullptr;
- }while(0);
-
- /* 关闭socket */
- close(sock_fd);
- sock_fd = -1;
- /* 释放 CTX */
- SSL_CTX_free(ctx);
- ctx = nullptr;
- return 0;
- }
注意事项
- GitHub - jntass/TASSL: 已升级到TASSL-1.1.1k,下载链接https://github.com/jntass/TASSL-1.1.1k
- GitHub - jntass/TASSL-1.1.1k 目前最新的版本
- TASSL为了支持国密双证书体系添加了很多函数