linux openssl 编程 Server端

OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

直接进行编程步骤:

1.首先确保电脑端拥有openssl库,我这采用的方式是直接使用源码,然后进行编译,编译方式可以参考以下链接地址:

http://www.wangyan.org/blog/install-openssl-from-source.html

2.Server端源码:

openssl_server.c

[cpp]  view plain  copy
  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3. #include <errno.h>  
  4. #include <string.h>  
  5. #include <sys/types.h>  
  6. #include <netinet/in.h>  
  7. #include <sys/socket.h>  
  8. #include <sys/wait.h>  
  9. #include <unistd.h>  
  10. #include <arpa/inet.h>  
  11. #include <openssl/ssl.h>  
  12. #include <openssl/err.h>  
  13.   
  14. #define MAXBUF  1024  
  15.   
  16. int main(int argc,char **argv)  
  17. {  
  18.     struct sockaddr_in  my_addr,their_addr;  
  19.     unsigned int    myport;  
  20.     char        buf[MAXBUF + 1] = { 0 };  
  21.     SSL_CTX     *ctx;  
  22.     int         sockfd,new_fd;  
  23.     socklen_t   len;  
  24.       
  25.     if (argc != 4)  
  26.     {  
  27.         printf("Usage:%s [bind port] [CERT_PATH] [PRI_KEY_PATH]\n",argv[0]);  
  28.         return -1;  
  29.     }  
  30.       
  31.     if (argv[1])  
  32.         myport = atoi(argv[1]);  
  33.       
  34.     /*初始化openssl库*/  
  35.     SSL_library_init();  
  36.     OpenSSL_add_all_algorithms();  
  37.     SSL_load_error_strings();  
  38.     ctx = SSL_CTX_new(SSLv23_server_method());  
  39.     if (ctx == NULL)  
  40.     {  
  41.         ERR_print_errors_fp(stdout);  
  42.         exit(-1);  
  43.     }  
  44.   
  45.     /*加载服务器证书*/  
  46.     if (SSL_CTX_use_certificate_file(ctx, argv[2], SSL_FILETYPE_PEM) <= 0)  
  47.     {  
  48.         ERR_print_errors_fp(stdout);  
  49.         exit(-1);  
  50.     }  
  51.   
  52.     /*加载服务器私钥*/  
  53.     if (SSL_CTX_use_PrivateKey_file(ctx,argv[3],SSL_FILETYPE_PEM) <= 0)  
  54.     {  
  55.         ERR_print_errors_fp(stdout);  
  56.         exit(-1);  
  57.     }  
  58.   
  59.     if (!SSL_CTX_check_private_key(ctx))   
  60.     {  
  61.             ERR_print_errors_fp(stdout);  
  62.             exit(-1);  
  63.         }  
  64.   
  65.     if ((sockfd = socket(PF_INET,SOCK_STREAM,0)) == -1)  
  66.     {  
  67.         perror("socket");  
  68.         exit(-1);  
  69.     }  
  70.     else  
  71.     {  
  72.         printf("socket created\n");  
  73.     }  
  74.   
  75.     bzero(&my_addr,sizeof(my_addr));  
  76.     my_addr.sin_family = PF_INET;  
  77.     my_addr.sin_port = htons(myport);  
  78.     my_addr.sin_addr.s_addr = INADDR_ANY;  
  79.   
  80.     if (bind(sockfd,(struct sockaddr*)&my_addr,sizeof(struct sockaddr)) == -1)  
  81.     {  
  82.         perror("bind");  
  83.         exit(-1);  
  84.     }  
  85.     else  
  86.         printf("binded\n");  
  87.   
  88.     if (listen(sockfd,5) == -1)  
  89.     {  
  90.         perror("listen");  
  91.         exit(-1);  
  92.     }  
  93.     else  
  94.         printf("begin to listen\n");  
  95.   
  96.     while(1)  
  97.     {  
  98.         SSL *ssl;  
  99.         len = sizeof(struct sockaddr);  
  100.         if ((new_fd = accept(sockfd,(struct sockaddr*)&their_addr,&len)) == -1)  
  101.         {  
  102.             perror("accept");  
  103.             exit(-1);  
  104.         }  
  105.         else  
  106.             printf("server:got connection from %s,port %d,sockfd %d\n",inet_ntoa(their_addr.sin_addr),ntohs(their_addr.sin_port),new_fd);  
  107.   
  108.             ssl = SSL_new(ctx);  
  109.             SSL_set_fd(ssl, new_fd);  
  110.             if (SSL_accept(ssl) == -1) {  
  111.                     perror("accept");  
  112.                     close(new_fd);  
  113.                     break;  
  114.             }  
  115.   
  116.             bzero(buf, MAXBUF + 1);  
  117.             strcpy(buf, "server->client");  
  118.             len = SSL_write(ssl, buf, strlen(buf));  
  119.         if (len <= 0) {  
  120.                     printf("message '%s' send error! error code:'%d',error info:'%s'\n",  
  121.                         buf, errno, strerror(errno));  
  122.                     goto finish;  
  123.             } else  
  124.                     printf("message '%s' send success!message total size:'%d'\n",  
  125.                     buf, len);  
  126.   
  127.                 bzero(buf, MAXBUF + 1);  
  128.                 len = SSL_read(ssl, buf, MAXBUF);  
  129.                 if (len > 0)  
  130.                         printf("recv message:'%s' ok!message total size:'%d'\n",  
  131.                             buf, len);  
  132.                 else  
  133.                         printf("recv message error.error code:'%d',error info:'%s'\n",  
  134.                             errno, strerror(errno));  
  135.       finish:  
  136.         SSL_shutdown(ssl);  
  137.             SSL_free(ssl);  
  138.             close(new_fd);  
  139.     }  
  140.     close(sockfd);  
  141.     SSL_CTX_free(ctx);  
  142.     return 0;  
  143. }  
3.编译

[plain]  view plain  copy
  1. gcc -o ssl_server ssl_server.c -Wall -g -lssl  
在我的机子上不能直接编译通过,提示没法找到相关的libssl.so库和libcrypto.so库,所以我利用了在第一步中编译出来的openssl库文件,修改gcc为:

[plain]  view plain  copy
  1. gcc -o openssl_server openssl_server.c -Wall -lssl -lcrypto -L./openssl-1.0.2d/ -Wl,-rpath=./openssl-1.0.2d  
openssl-1.0.2d为源码的文件夹,-Wl,rpath表示编译链接的时候的路径。

4.证书申请

私钥

[plain]  view plain  copy
  1. openssl genrsa -out privkey.pem 1024  
证书(试玩的证书,未向证书中心认证的)

[plain]  view plain  copy
  1. openssl req -new -x509 -key privkey.pem -out CAcert.pem -days 1095  
5.运行

[plain]  view plain  copy
  1. Usage:openssl_server [bind port] [CERT_PATH] [PRI_KEY_PATH]  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值