当前位置: 首页 > wzjs >正文

苹果手机做网站友链价格

苹果手机做网站,友链价格,网站建设团队管理怎么写,wordpress首页阅读全文1、首先使用gmssl命令生成根证书、客户端公私钥,然后使用根证书签发客户端证书; 2、然后编写代码完成认证功能,使用根证书验证客户端证书是否由自己签发,然后使用客户端证书验证客户端私钥对随机数的签名是否正确。 第一部分生成根…

        1、首先使用gmssl命令生成根证书、客户端公私钥,然后使用根证书签发客户端证书;

        2、然后编写代码完成认证功能,使用根证书验证客户端证书是否由自己签发,然后使用客户端证书验证客户端私钥对随机数的签名是否正确。

        第一部分生成根证书和客户端证书的命令:

# 生成私钥,用于生成根证书
# gmssl 3.1.1要求必须使用密码加密私钥
gmssl sm2keygen -pass 123456 -out root.key# 生成自签名根证书
gmssl certgen \-C CN \-ST Beijing \-L Beijing \-O MyCA \-OU RootCA \-CN RootCA \-days 3650 \-key root.key \-pass 123456 \-key_usage keyCertSign \-out root.crt# 生成客户端公私钥
gmssl sm2keygen -pass 123456 -out client.key# 生成客户端证书请求(CSR)
gmssl reqgen \-C CN \-ST Beijing \-L Beijing \-O MyClient \-OU Client \-CN client.example.com \-key client.key \-pass 123456 \-out client.csr# 签发客户端证书
gmssl reqsign \-in client.csr \-days 3650 \-key_usage digitalSignature \-cacert root.crt \-key root.key \-pass 123456 \-out client.crt

        第二部分进行客户端证书认证和签名验签的代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <gmssl/x509.h>
#include <gmssl/sm2.h>
#include <gmssl/sm3.h>
#include <gmssl/pem.h>
#include <gmssl/error.h>
#include <gmssl/base64.h>#define ROOT_CERT_FILE   "root.crt"
#define CLIENT_CERT_FILE "client.crt"
#define CLIENT_KEY_FILE  "client.key"
#define ROOT_KEY_FILE    "root.key"
#define DATA_TO_SIGN     "This is the data to sign."// 读取加密的SM2私钥(PKCS#8 PEM),解密并导入SM2_KEY
int load_encrypted_sm2_private_key(const char *filename, const char *password, SM2_KEY *key) {FILE *fp = fopen(filename, "r");if (!fp) {perror(filename);return -1;}if (sm2_private_key_info_decrypt_from_pem(key, password, fp) != 1) {fprintf(stderr, "Failed to decrypt/load private key: %s\n", filename);fclose(fp);return -1;}fclose(fp);return 0;
}int main(void) {uint8_t root_cert[4096], client_cert[4096];size_t root_cert_len = 0, client_cert_len = 0;SM2_KEY client_key, client_pubkey;uint8_t dgst[32];uint8_t sig[SM2_MAX_SIGNATURE_SIZE];size_t siglen = 0;int ret = 1;// 1. 读取根证书FILE *fp = fopen(ROOT_CERT_FILE, "r");if (!fp) {perror("open root.crt");return 1;}if (x509_cert_from_pem(root_cert, &root_cert_len, sizeof(root_cert), fp) != 1) {fprintf(stderr, "Failed to load root certificate\n");fclose(fp);return 1;}fclose(fp);// 2. 读取客户端证书fp = fopen(CLIENT_CERT_FILE, "r");if (!fp) {perror("open client.crt");return 1;}if (x509_cert_from_pem(client_cert, &client_cert_len, sizeof(client_cert), fp) != 1) {fprintf(stderr, "Failed to load client certificate\n");fclose(fp);return 1;}fclose(fp);// 3. 验证客户端证书if (x509_cert_verify_by_ca_cert(client_cert, client_cert_len, root_cert,root_cert_len, SM2_DEFAULT_ID, SM2_DEFAULT_ID_LENGTH) != 1) {fprintf(stderr, "Client certificate verify failed\n");goto end;}printf("Client certificate verified successfully.\n");// 4. 读取加密的客户端私钥(需要口令)char client_pass[7] = {0x31,0x32,0x33,0x34,0x35,0x36,0x00};if (load_encrypted_sm2_private_key(CLIENT_KEY_FILE, client_pass, &client_key) != 0) {fprintf(stderr, "Failed to load client private key\n");goto end;}// 5. 计算数据摘要const uint8_t *data = (const uint8_t *)DATA_TO_SIGN;size_t data_len = strlen(DATA_TO_SIGN);sm3_digest(data, data_len, dgst);// 6. 签名if (sm2_sign(&client_key, dgst, sig, &siglen) != 1) {fprintf(stderr, "SM2 sign failed\n");goto end;}printf("Data signed successfully.\nSignature: ");for (size_t i = 0; i < siglen; i++) printf("%02x", sig[i]);printf("\n");// 7. 从证书中提取公钥if (x509_cert_get_subject_public_key(client_cert, client_cert_len, &client_pubkey) != 1) {fprintf(stderr, "Failed to extract public key from client certificate\n");goto end;}// 8. 验签if (sm2_verify(&client_pubkey, dgst, sig, siglen) != 1) {fprintf(stderr, "Signature verification failed\n");goto end;}printf("Signature verified successfully.\n");ret = 0;end://sm2_key_cleanup(&client_key);//sm2_key_cleanup(&client_pubkey);return ret;
}

        在centos7平台使用GmSSL V3.1.1亲测可行。

http://www.dtcms.com/wzjs/152725.html

相关文章:

  • c#网站购物车怎么做网络营销的八大能力
  • 外贸网站关键词优化seo搜索引擎推广
  • 宜宾网站建设公司今日热搜榜排名最新
  • 电子商务网站建设规划范文百度退款客服电话
  • wordpress如何生成网站地图百度快照手机入口
  • 网站建设中 模板北京网站seo技术厂家
  • 哪些网站可以做邀请函武汉刚刚发生的新闻
  • 做电子商务网站价格推广计划方案模板
  • 网站优化怎么做关键词排名线下推广有哪些渠道
  • 做啥网站好企业营销策划书如何编写
  • 做我女朋友网站河南今日重大新闻
  • 网站建设推广语推广产品怎么发朋友圈
  • 怎么自己网站建设最近七天的新闻大事
  • 网页设计师联盟网站怎么网络推广的优势有哪些
  • 淘宝购物网seo最好的工具
  • 做网站 有哪些问题百度一下百度搜索网站
  • 关于seo关键词选择有哪些方法东莞seo收费
  • 网络优化器福建seo排名培训
  • 拱墅网站建设网页加速器
  • 湖南住房城乡建设厅网站小程序制作费用一览表
  • 厦门住房建设局网站关键词优化哪家强
  • 广告设计图网站免费的网站推广
  • 网站建设行业 前景竞价sem托管公司
  • 南城东莞网站建设公司推广发帖网站怎么做
  • 网站建设 电商百度爱采购推广怎么收费
  • 迁西县住房和城乡规划建设局网站网站关键词优化费用
  • 网站页面图片布局如何设计营销页面
  • wordpress仿一淘seo推广优化排名软件
  • 做单机游戏破解的网站阿里巴巴数据分析官网
  • 采用css div做网站优化关键词排名seo软件