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

企业网站建设xplogo大濮网最新濮阳消息

企业网站建设xplogo,大濮网最新濮阳消息,做阿里巴巴还是做网站好,大连的网站制作公司参考链接 Ubuntu安装GmSSL库适用于ubuntu18和ubuntu20版本_MY CUP OF TEA的博客-CSDN博客CLion运行程序时添加命令行参数 即设置argv输入参数_MY CUP OF TEA的博客-CSDN博客基于SM2证书实现SSL通信_MY CUP OF TEA的博客-CSDN博客基于Gmssl库静态编译#xff0c;实现服务端和客…参考链接 Ubuntu安装GmSSL库适用于ubuntu18和ubuntu20版本_MY CUP OF TEA的博客-CSDN博客CLion运行程序时添加命令行参数 即设置argv输入参数_MY CUP OF TEA的博客-CSDN博客基于SM2证书实现SSL通信_MY CUP OF TEA的博客-CSDN博客基于Gmssl库静态编译实现服务端和客户端之间的SSL通信_MY CUP OF TEA的博客-CSDN博客基于openssl和国密算法生成CA、服务器和客户端证书_MY CUP OF TEA的博客-CSDN博客openssl实现双向认证教程服务端代码客户端代码证书生成_MY CUP OF TEA的博客-CSDN博客mac系统使用 clion远程调试redis4源码_迹忆客   target_link_libraries Server 层次结构 lib存放静态编译gmssl代码生成的静态库即libssl.a和libcrypto.apem存放证书文件因为SSL双向验证服务端会验证客户端的证书因此服务端存放客户端的证书和私钥以及生成客户端证书时用于签名的ca证书Code #include stdio.h #include stdlib.h #include errno.h #include string.h #include sys/types.h #include netinet/in.h #include sys/socket.h #include sys/wait.h #include unistd.h #include arpa/inet.h #include openssl/ssl.h #include openssl/err.h#define MAXBUF 1024void 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 ! NULL) {printf(数字证书信息:\n);line X509_NAME_oneline(X509_get_subject_name(cert), 0, 0);printf(证书: %s\n, line);free(line);line X509_NAME_oneline(X509_get_issuer_name(cert), 0, 0);printf(颁发者: %s\n, line);free(line);X509_free(cert);} elseprintf(无证书信息\n); }int main(int argc, char **argv) {int sockfd, new_fd;socklen_t len;struct sockaddr_in my_addr, their_addr;unsigned int myport, lisnum;char buf[MAXBUF 1];SSL_CTX *ctx;if (argv[1])myport atoi(argv[1]);elsemyport 7838;if (argv[2])lisnum atoi(argv[2]);elselisnum 2;/* SSL 库初始化 */SSL_library_init();/* 载入所有 SSL 算法 */OpenSSL_add_all_algorithms();/* 载入所有 SSL 错误消息 */SSL_load_error_strings();/* 以 SSL V2 和 V3 标准兼容方式产生一个 SSL_CTX 即 SSL Content Text */ctx SSL_CTX_new(SSLv23_server_method());/* 也可以用 SSLv2_server_method() 或 SSLv3_server_method() 单独表示 V2 或 V3标准 */if (ctx NULL) {ERR_print_errors_fp(stdout);exit(1);}// 双向验证// 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, NULL);// 设置信任根证书if (SSL_CTX_load_verify_locations(ctx, /home/chy-cpabe/CLionProjects/ssl_client/src/pem/CaCert.pem,NULL)0){ERR_print_errors_fp(stdout);exit(1);}/* 载入用户的数字证书 此证书用来发送给客户端。 证书里包含有公钥 */if (SSL_CTX_use_certificate_file(ctx, argv[3], SSL_FILETYPE_PEM) 0) {ERR_print_errors_fp(stdout);exit(1);}/* 载入用户私钥 */if (SSL_CTX_use_PrivateKey_file(ctx, argv[4], SSL_FILETYPE_PEM) 0) {ERR_print_errors_fp(stdout);exit(1);}/* 检查用户私钥是否正确 */if (!SSL_CTX_check_private_key(ctx)) {ERR_print_errors_fp(stdout);exit(1);}/* 开启一个 socket 监听 */if ((sockfd socket(PF_INET, SOCK_STREAM, 0)) -1) {perror(socket);exit(1);} elseprintf(socket created\n);bzero(my_addr, sizeof(my_addr));my_addr.sin_family PF_INET;my_addr.sin_port htons(myport);my_addr.sin_addr.s_addr INADDR_ANY;if (bind(sockfd, (struct sockaddr *) my_addr, sizeof(struct sockaddr)) -1) {perror(bind);exit(1);} elseprintf(binded\n);if (listen(sockfd, lisnum) -1) {perror(listen);exit(1);} elseprintf(begin listen\n);while (1) {SSL *ssl;len sizeof(struct sockaddr);/* 等待客户端连上来 */if ((new_fd accept(sockfd, (struct sockaddr *) their_addr, len)) -1) {perror(accept);exit(errno);} elseprintf(server: got connection from %s, port %d, socket %d\n,inet_ntoa(their_addr.sin_addr), ntohs(their_addr.sin_port),new_fd);/* 基于 ctx 产生一个新的 SSL */ssl SSL_new(ctx);/* 将连接用户的 socket 加入到 SSL */SSL_set_fd(ssl, new_fd);/* 建立 SSL 连接 */if (SSL_accept(ssl) -1) {perror(accept);close(new_fd);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;} elseprintf(消息%s发送成功共发送了%d个字节\n, buf, len);bzero(buf, MAXBUF 1);/* 接收客户端的消息 */len SSL_read(ssl, buf, MAXBUF);if (len 0)printf(接收消息成功:%s共%d个字节的数据\n, buf, len);elseprintf(消息接收失败错误代码是%d错误信息是%s\n,errno, strerror(errno));/* 处理每个新连接上的数据收发结束 */finish:/* 关闭 SSL 连接 */SSL_shutdown(ssl);/* 释放 SSL */SSL_free(ssl);/* 关闭 socket */close(new_fd);}/* 关闭监听的 socket */close(sockfd);/* 释放 CTX */SSL_CTX_free(ctx);return 0; } CMakeLists.txt cmake_minimum_required(VERSION 3.22)project(ssl_server) set(CMAKE_CXX_STANDARD 11)# 忽略警告 set(CMAKE_CXX_FLAGS -Wno-errordeprecated-declarations -Wno-deprecated-declarations )# 指定lib目录link_directories(${PROJECT_SOURCE_DIR}/lib)# 指定头文件搜索策略 include_directories(/usr/local/gmssl/include)# 使用指定的源文件来生成目标可执行文件 add_executable(${PROJECT_NAME} ssl_server.cpp)# 将库链接到项目中 target_link_libraries(${PROJECT_NAME} libssl.a libcrypto.a pthread dl) 配置执行输入参数 CLion运行程序时添加命令行参数 即设置argv输入参数_MY CUP OF TEA的博客-CSDN博客7838 1 /home/chy-cpabe/CLionProjects/ssl_server/src/pem/HuiguanCert.pem /home/chy-cpabe/CLionProjects/ssl_server/src/pem/HuiguanKey.pem执行结果 Client 层次结构 lib存放静态编译gmssl代码生成的静态库即libssl.a和libcrypto.apem存放证书文件因为SSL双向验证客户端同样会验证客户端的证书因此客户端存放服务端的证书和私钥以及生成服务端证书时用于签名的ca证书Code #include stdio.h #include string.h #include errno.h #include sys/socket.h #include resolv.h #include stdlib.h #include netinet/in.h #include arpa/inet.h #include unistd.h #include openssl/ssl.h #include openssl/err.h#define MAXBUF 1024void 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 ! NULL) {printf(数字证书信息:\n);line X509_NAME_oneline(X509_get_subject_name(cert), 0, 0);printf(证书: %s\n, line);free(line);line X509_NAME_oneline(X509_get_issuer_name(cert), 0, 0);printf(颁发者: %s\n, line);free(line);X509_free(cert);} elseprintf(无证书信息\n); }int main(int argc, char **argv) {int sockfd, len;struct sockaddr_in dest;char buffer[MAXBUF 1];SSL_CTX *ctx;SSL *ssl;if (argc ! 5) {printf(参数格式错误正确用法如下\n\t\t%s IP地址 端口\n\t比如:\t%s 127.0.0.1 80\n此程序用来从某个IP 地址的服务器某个端口接收最多 MAXBUF 个字节的消息,argv[0], argv[0]);exit(0);}/* SSL 库初始化参看 ssl-server.c 代码 */SSL_library_init();OpenSSL_add_all_algorithms();SSL_load_error_strings();ctx SSL_CTX_new(SSLv23_client_method());if (ctx NULL) {ERR_print_errors_fp(stdout);exit(1);}// 双向验证// 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, NULL);// 设置信任根证书if (SSL_CTX_load_verify_locations(ctx, /home/chy-cpabe/CLionProjects/ssl_client/src/pem/CaCert.pem,NULL)0){ERR_print_errors_fp(stdout);exit(1);}/* 载入用户的数字证书 此证书用来发送给客户端。 证书里包含有公钥 */if (SSL_CTX_use_certificate_file(ctx, argv[3], SSL_FILETYPE_PEM) 0) {ERR_print_errors_fp(stdout);exit(1);}/* 载入用户私钥 */if (SSL_CTX_use_PrivateKey_file(ctx, argv[4], SSL_FILETYPE_PEM) 0) {ERR_print_errors_fp(stdout);exit(1);}/* 检查用户私钥是否正确 */if (!SSL_CTX_check_private_key(ctx)) {ERR_print_errors_fp(stdout);exit(1);}/* 创建一个 socket 用于 tcp 通信 */if ((sockfd socket(AF_INET, SOCK_STREAM, 0)) 0) {perror(Socket);exit(errno);}printf(socket created\n);/* 初始化服务器端对方的地址和端口信息 */bzero(dest, sizeof(dest));dest.sin_family AF_INET;dest.sin_port htons(atoi(argv[2]));if (inet_aton(argv[1], (struct in_addr *) dest.sin_addr.s_addr) 0) {perror(argv[1]);exit(errno);}printf(address created\n);/* 连接服务器 */if (connect(sockfd, (struct sockaddr *) dest, sizeof(dest)) ! 0) {perror(Connect );exit(errno);}printf(server connected\n);/* 基于 ctx 产生一个新的 SSL */ssl SSL_new(ctx);SSL_set_fd(ssl, sockfd);/* 建立 SSL 连接 */if (SSL_connect(ssl) -1)ERR_print_errors_fp(stderr);else {printf(Connected with %s encryption\n, SSL_get_cipher(ssl));ShowCerts(ssl);}/* 接收对方发过来的消息最多接收 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));elseprintf(消息%s发送成功共发送了%d个字节\n,buffer, len);finish:/* 关闭连接 */SSL_shutdown(ssl);SSL_free(ssl);close(sockfd);SSL_CTX_free(ctx);return 0; } CMakeLists.txt cmake_minimum_required(VERSION 3.22) project(ssl_client)set(CMAKE_CXX_STANDARD 11)# 忽略警告 set(CMAKE_CXX_FLAGS -Wno-errordeprecated-declarations -Wno-deprecated-declarations )# 指定lib目录 link_directories(${PROJECT_SOURCE_DIR}/lib)# 指定头文件搜索策略 include_directories(/usr/local/gmssl/include)link_libraries(ssl crypto)# 使用指定的源文件来生成目标可执行文件 add_executable(${PROJECT_NAME} ssl_client.cpp)# 将库链接到项目中 target_link_libraries(${PROJECT_NAME} libssl.a libcrypto.a pthread dl) 配置执行输入参数 127.0.0.1 7838 /home/chy-cpabe/CLionProjects/ssl_client/src/pem/TerminalCert.pem /home/chy-cpabe/CLionProjects/ssl_client/src/pem/TerminalKey.pem执行结果
http://www.sadfv.cn/news/62968/

相关文章:

  • 高端网站建设熊掌号wordpress 时钟插件
  • wordpress网站mip改造品牌策划与设计机构
  • 南京市玄武区建设局网站网站诊断方案
  • 网站空间 云端郑州哪个公司专业做网站
  • 漯河企业网站开发网站建设目标初步目标
  • 小型门户网站建设方案listify wordpress
  • 移动网站mip个人名片模板
  • 电脑网站与手机的区别是什么发行商城小程序
  • 陕西交通建设集团网站龙岗网站设计效果
  • 济南网站建设_美叶网络邢台市路桥建设总公司网站
  • 网站 流程优化什么网站可以做宣传
  • 福田公司官网刚做优化的网站什么能更新
  • 建设银行网站无法登陆flash网站建设个人简介
  • 网站前台和后台对接实例用模板快速建站
  • 打赏网站怎么建设学完网站建设再可以学什么
  • 网站开发 脚本怎么写网站建设推广注册公司
  • 做网站 图片需要多大的asp.net网站
  • 网站建设对企业的重要性网站建设近五年参考文献
  • 罗湖网站设计公司哪家好连云港网站关键词优化
  • 咸阳学校网站建设费用微信分享网站短链接怎么做的
  • 建设房屋出租网站手机软件开发教程
  • 安徽营销型网站建设wikidot网站怎么做
  • 做网站具体指什么网络营销服务的特点
  • 全国前十名校程序开发公司常州网站seo
  • 浙江网警优化方案官网电子版
  • 羊 东莞网站开发高性能标准网站建设进阶指南 pdf
  • 用户体验设计师证书广州新塘网站seo优化
  • 开发网站如何赚钱wordpress 清理数据库
  • 网站数据丢失记事本做网站
  • 哪个网站可以做字体大小申远空间设计公司官网