Guest User

client_program_with_ssl

a guest
Mar 12th, 2018
113
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 3.68 KB | None | 0 0
  1. #include "header.h"
  2. //#include "osal.h"
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>
  6. #include <netinet/in.h>
  7. #include <sys/socket.h>
  8. #include <unistd.h>
  9. #include <arpa/inet.h>
  10. #include <openssl/ssl.h>
  11. #include <openssl/err.h>
  12. #include <openssl/x509.h>
  13.  
  14.  
  15. #define SERVER_IP "127.0.0.1"
  16. #define PORT 7788
  17. #define MAXBUF 1024
  18.  
  19. #define CAFILE   "./ca.pem"
  20.  
  21.  
  22.  
  23. void ShowCerts(SSL * ssl)//�õ��������˵�֤����Ϣ������ӡ����(��ѡ�������DZ�����)
  24. {
  25.     X509 *cert;
  26.     char *line;
  27.  
  28.     if(X509_V_OK != SSL_get_verify_result(ssl))//��֤����������Ҫ��Ӧ����CA֤�飬��������֤���Ϸ������������Ӳ��ܼ������У�ֻ����Ҫ�ͻ������߾���
  29.     {
  30.        printf("warning!!!!!!\n Failed verify the server certificate!\n");
  31.     }
  32.  
  33.     cert = SSL_get_peer_certificate(ssl);//��ssl�ṹ����ȡ���Է���֤��(ע:��ʱ֤���Ѿ��õ����Ѿ�������֤)
  34.     if (cert != NULL)
  35.     {
  36.         line = X509_NAME_oneline(X509_get_subject_name(cert), 0, 0);
  37.         printf("certificate: %s\n", line);
  38.         free(line);
  39.         line = X509_NAME_oneline(X509_get_issuer_name(cert), 0, 0);
  40.         printf("issuer: %s\n", line);
  41.         free(line);
  42.         X509_free(cert);
  43.     }
  44.     else
  45.     {
  46.         printf("No certificate information\n");
  47.     }
  48. }
  49.  
  50. int connect2server()
  51. {
  52.     int iret,sockfd,len;
  53.     SSL_CTX *ctx;
  54.     SSL *ssl;
  55.     char ssl_buf[MAXBUF];
  56.     struct sockaddr_in server;
  57.     char connected[]="connected.";
  58.     char recv[]="Recv";
  59.     char send[]="Send";
  60.  
  61.     SSL_library_init();
  62.     OpenSSL_add_all_algorithms();
  63.     SSL_load_error_strings();
  64.     ctx = SSL_CTX_new(SSLv23_client_method());
  65.     if(ctx == NULL)
  66.     {
  67.         ERR_print_errors_fp(stdout);
  68.         exit(1);
  69.     }
  70.  
  71.     if((iret = SSL_CTX_load_verify_locations(ctx,CAFILE,NULL)) == 0)
  72.     {
  73.         printf("SSL_CTX_load_verify_locations err: %d\n", iret);
  74.     }
  75.  
  76.     if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
  77.     {
  78.         perror("Socket");
  79.         exit(errno);
  80.     }
  81.  
  82.     bzero(&server, sizeof(server));
  83.     server.sin_family = AF_INET;
  84.     server.sin_port = htons(PORT);
  85.     if(inet_aton(SERVER_IP, (struct in_addr *)&server.sin_addr.s_addr) == 0)
  86.     {
  87.         perror(SERVER_IP);
  88.         exit(errno);
  89.     }
  90.  
  91.     if((iret = connect(sockfd, (struct sockaddr *)&server, sizeof(server))) != 0)
  92.     {
  93.         perror("Connect");
  94.         exit(errno);
  95.     }
  96.  
  97.  
  98.     printf("Connected\n");
  99.     ssl = SSL_new(ctx);
  100.     SSL_set_fd(ssl, sockfd);
  101.  
  102.     printf("start SSL_connect.\n");
  103.     if(SSL_connect(ssl) == -1)
  104.     {
  105.         ERR_print_errors_fp(stderr);
  106.     }
  107.     else
  108.     {
  109.         ShowCerts(ssl);
  110. //      printf("SSL_connect.\n");
  111.         printf("Connected with %s encryption\n", SSL_get_cipher(ssl));//��ӡ����֧�ֵļ����㷨��Ϣ
  112.     }
  113.  
  114.  
  115.     bzero(ssl_buf, MAXBUF);
  116.     strcpy(ssl_buf, "Hello Server: This is ssl client!\n");
  117.  
  118.     printf("Send\n");
  119.     len = SSL_write(ssl, ssl_buf, strlen(ssl_buf));
  120.     if (len <= 0)
  121.     {
  122.         printf ("SSL_write error, errno=%d(%s)\n",errno, strerror(errno));
  123.         goto error;
  124.     }
  125.     else
  126.     {
  127.         printf("SSL_write %d bytes: %s\n", len, ssl_buf);
  128.     }
  129.    
  130.     printf("Receive\n");
  131.     bzero(ssl_buf, MAXBUF);
  132.  
  133.     while(1)
  134.     {
  135.         len = SSL_read(ssl, ssl_buf, MAXBUF);
  136.         if(len < 0)
  137.         {
  138.             printf("SSL_read error, errno=%d(%s)\n", errno, strerror(errno));
  139.             ERR_print_errors_fp(stdout);
  140.             goto error;
  141.         }
  142.  
  143.         if(0 == len)
  144.          continue;
  145.  
  146.         break;
  147.     }
  148.  
  149.     printf("SSL_read %d bytes: %s\n",len, ssl_buf);
  150.     usleep(100*2000);
  151.  
  152.    error:
  153.      SSL_shutdown(ssl);
  154.      SSL_free(ssl);
  155.      close(sockfd);
  156.      SSL_CTX_free(ctx);
  157.  
  158.   return 0;
  159. }
  160.  
  161.  
  162.  
  163. int SslClient()
  164. {    
  165.    connect2server();   
  166.     usleep(100*1000);
  167.     return 0;
  168. }
  169.  
  170.  
  171. int main()
  172. {
  173.     SslClient();
  174.     return 0;
  175. }
Add Comment
Please, Sign In to add comment