青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woomsg

在路上

openssl使用

1. website
SSL(secure Socket Layer)
TLS(transport Layer Security) - SSL3.0基礎之上提出的安全通信標準,目前版本是1.0
openssl 主頁 -> http://www.openssl.org/
openssl 中文文檔 -> http://www.chinaunix.net/jh/13/478901.html

2. 如何編譯OpenSSL in Windows?
a) 下載openssl -> openssl-0.9.8i
b) 下載perl -> http://downloads.activestate.com/ActivePerl/Windows/5.8/ActivePerl-5.8.8.822-MSWin32-x86-280952.zip
c) 安裝perl -> ActivePerl-5.8.8.822-MSWin32-x86-280952/Installer.bat (之前先運行vcvars32.bat,需要運行perf Configure VC-WIN32來設置環境變量)
d) 使windows支持nmake -> C:\Program Files\Microsoft Visual Studio 10.0\VC\bin\vcvars32.bat
e) 進入openssl路徑 -> cd C:\devdiv\openssl-0.9.8i    (工作路徑)
f) 創建Makefile文件: ms\do_ms     (出現%osversion% is not defined的錯誤忽略即可)
g) 編譯動態庫: nmake -f ms\ntdll.mak
   編譯靜態庫: nmake -f ms\nt.mak

   測試動態庫: nmake -f ms\ntdll.mak test
   測試靜態庫: nmake -f ms\nt.mak test

   安裝動態庫: nmake -f ms\ntdll.mak install
   安裝靜態庫: nmake -f ms\nt.mak install

   清除上次動態庫的編譯,以便重新編譯: nmake -f ms\ntdll.mak clean
   清除上次靜態庫的編譯,以便重新編譯: nmake -f ms\nt.mak clean
  
3. 如何使用openssl?
a) library path -> C:\devdiv\openssl-0.9.8i\out32
b) include path -> C:\devdiv\openssl-0.9.8i\include
c) 庫文件 -> libeay32.lib, ssleay32.lib

4. 配置文件在哪里?
C:\devdiv\openssl-0.9.8i\apps\openssl.cnf

5. 關于key:
key一般分為public key和private key,在openssl中,private key中包含了public key的信息,所以public key不需要單獨創建. 如何創建一個RSA key?
openssl.exe genrsa -des3 -out privatekey.pem 2048  (需要添加密碼保護)
openssl.exe genrsa -out privatekey.pem 2048

6. 關于certificates(證書文件), 如何創建一個證書呢?
一般流程是:
a. 創建一個private key
b. 創建一個certificate signing request(證書請求), 這個需要a#中創建的private key.因為證書中需要包含public key,
創建的priavate key中有這些信息.
(openssl.exe req -new -key privatekey.pem-out cacert.csr)
c. 把創建好的證書請求拿到CA(certificate authority)證書認證機構審批.

7. 如何做一個自簽名的證書呢?
openssl.exe req -new -x509 -key privatekey.pem -out cacert.pem -days 1095
(Note: privatekey.pem需要自己創建)

8. Demo: 來自openssl自帶的demo,略做修改.
Server:

  1#include <openssl/rsa.h>       /* SSLeay stuff */
  2#include <openssl/crypto.h>
  3#include <openssl/x509.h>
  4#include <openssl/pem.h>
  5#include <openssl/ssl.h>
  6#include <openssl/err.h>
  7
  8
  9#include <iostream>
 10#include <winsock2.h>
 11
 12#define SERVER_PORT    5003
 13
 14// certificate & key 的存放路徑
 15// Note: 必須是全路徑, 否則SSL_CTX_use_certificate_file等函數
 16//       無法找到文件在windows平臺上.
 17// How to:
 18// #privatekey.pem
 19// openssl.exe genrsa -out privatekey.pem 2048
 20// #cacert.pem
 21// openssl.exe req -new -x509 -key privatekey.pem -out cacert.pem -days 1095 -config openssl.cnf
 22//
 23#define SERVER_CERTIFICATE   "c:\\config\\cacert.pem"    
 24#define SERVER_KEY           "c:\\config\\privatekey.pem"
 25
 26#pragma comment( lib, "ws2_32.lib" )
 27#pragma comment( lib, "libeay32.lib" )
 28#pragma comment( lib, "ssleay32.lib" )
 29
 30int main( int argc, char* argv[] ) {
 31  int ret;
 32
 33  ////////////
 34  // 初始化 //
 35  ////////////
 36  SSL_CTX* ctx;
 37  SSL_METHOD *meth;
 38
 39  SSL_load_error_strings();
 40  SSLeay_add_ssl_algorithms();
 41  meth = SSLv23_server_method(); 
 42
 43  ctx = SSL_CTX_new (meth);
 44  if (!ctx) {
 45    ERR_print_errors_fp(stderr);
 46    std::cout<<"SSL_CTX_new error."<<std::endl;
 47    return -1;
 48  }

 49  
 50  if (SSL_CTX_use_certificate_file(ctx, SERVER_CERTIFICATE, SSL_FILETYPE_PEM) <= 0{
 51    ERR_print_errors_fp(stderr);
 52    std::cout<<"SSL_CTX_use_certificate_file error."<<std::endl;
 53    return -1;
 54  }

 55  if (SSL_CTX_use_PrivateKey_file(ctx, SERVER_KEY, SSL_FILETYPE_PEM) <= 0{
 56    ERR_print_errors_fp(stderr);
 57    std::cout<<"SSL_CTX_use_PrivateKey_file error."<<std::endl;
 58    return -1;
 59  }

 60
 61  if (!SSL_CTX_check_private_key(ctx)) {
 62    ERR_print_errors_fp(stderr);
 63    std::cout<<"SSL_CTX_check_private_key error."<<std::endl;
 64    return -1;
 65  }

 66
 67  ///////////////////////
 68  // 建立原始的TCP連接 //
 69  ///////////////////////
 70  WSADATA wsaData;
 71  SOCKET listen_socket;
 72  SOCKET accept_socket;
 73  struct sockaddr_in addr_server;
 74  struct sockaddr_in addr_client;
 75  int addr_client_len;
 76
 77  ret = WSAStartup( MAKEWORD(22), &wsaData );
 78  if ( ret != 0 ) {
 79    std::cout<<"WSAStartup error."<<std::endl;
 80    return -1;
 81  }

 82
 83  listen_socket = socket (AF_INET, SOCK_STREAM, 0);  
 84  if( listen_socket == INVALID_SOCKET  ) {
 85    std::cout<<"socket error."<<std::endl;
 86    return -1;
 87  }

 88  
 89  memset (&addr_server, 0sizeof(addr_server));
 90  addr_server.sin_family           = AF_INET;
 91  addr_server.sin_addr.S_un.S_addr = INADDR_ANY;
 92  addr_server.sin_port             = htons (SERVER_PORT);        
 93  
 94  ret = bind(listen_socket, (struct sockaddr*)&addr_server, sizeof(addr_server) ); 
 95  if( ret == SOCKET_ERROR )  {
 96     std::cout<<"bind error."<<std::endl;
 97     return -1;
 98  }

 99         
100  ret = listen (listen_socket, 5); 
101  if( ret == SOCKET_ERROR ) {
102    std::cout<<"listen error."<<std::endl;
103    return -1;
104  }

105  
106  addr_client_len = sizeof(addr_client);
107  accept_socket = accept (listen_socket, (struct sockaddr*&addr_client, &addr_client_len);
108  if( accept_socket == INVALID_SOCKET  ) {
109    std::cout<<"accept error."<<std::endl;
110    return -1;
111  }

112  closesocket(listen_socket);
113  std::cout<<" Connection from "<<addr_client.sin_addr.S_un.S_addr<<":"<<addr_client.sin_port<<std::endl;
114
115  /////////////////////////////////////
116  // TCP連接已經建立,執行Server SSL //
117  /////////////////////////////////////
118  SSL*     ssl;
119  X509*    client_certificate;
120  char*    str;
121
122  ssl = SSL_new (ctx);                           
123  if( ssl == NULL ) {
124    std::cout<<"SSL_new error."<<std::endl;
125    return -1;
126  }
 
127  SSL_set_fd (ssl, accept_socket);
128  ret = SSL_accept (ssl);                     
129  if( ret == -1 ) {
130    std::cout<<"SSL_accept error."<<std::endl;
131    return -1;
132  }

133  
134  // 獲取cipher
135  std::cout<<"SSL connection using: "<<SSL_get_cipher(ssl)<<std::endl;
136  
137  // 獲取客戶端的證書
138  client_certificate = SSL_get_peer_certificate (ssl);
139  if (client_certificate != NULL) {
140    std::cout<<"Client certificate:"<<std::endl;
141    
142    str = X509_NAME_oneline (X509_get_subject_name (client_certificate), 00);
143    if( str == NULL ) {
144      std::cout<<"X509_NAME_oneline error."<<std::endl;
145    }
 else {
146      std::cout<<"subject: "<<str<<std::endl;
147      OPENSSL_free (str);
148    }

149    
150    str = X509_NAME_oneline (X509_get_issuer_name  (client_certificate), 00);
151    if( str == NULL ) {
152      std::cout<<"X509_NAME_oneline error."<<std::endl;
153    }
 else {
154      std::cout<<"issuer: "<<str<<std::endl;
155      OPENSSL_free (str);
156    }

157
158    X509_free (client_certificate);
159  }
 else {
160    std::cout<<"Client does not have certificate. "<<std::endl;
161  }

162
163  ////////////////
164  //  數據交換  //
165  ////////////////
166  char     buf [4096];
167
168  ret = SSL_read (ssl, buf, sizeof(buf) - 1);    
169  if( ret == -1 ) {
170    std::cout<<"SSL_read error."<<std::endl;
171    return -1;
172  }

173  buf[ret] = '\0';
174  std::cout<<buf<<std::endl;
175  
176  ret = SSL_write (ssl, "I hear you.", strlen("I hear you.")); 
177  if( ret == -1 ) {
178    std::cout<<"SSL_write error."<<std::endl;
179    return -1;
180  }

181
182  /////////////
183  // Cleanup //
184  /////////////
185  closesocket(accept_socket);
186  SSL_free (ssl);
187  SSL_CTX_free (ctx);
188  WSACleanup();
189  return 0;
190}

Client:

  1#include <openssl/rsa.h>       /* SSLeay stuff */
  2#include <openssl/crypto.h>
  3#include <openssl/x509.h>
  4#include <openssl/pem.h>
  5#include <openssl/ssl.h>
  6#include <openssl/err.h>
  7
  8
  9#include <iostream>
 10#include <winsock2.h>
 11
 12#define SERVER_IP      "127.0.0.1"
 13#define SERVER_PORT    5003
 14
 15#pragma comment( lib, "ws2_32.lib" )
 16#pragma comment( lib, "libeay32.lib" )
 17#pragma comment( lib, "ssleay32.lib" )
 18
 19
 20int main( int argc, char* argv[] ) {
 21  int ret;
 22  ////////////
 23  // 初始化 //
 24  ////////////
 25  SSL_CTX* ctx;
 26  SSL_METHOD *meth;
 27
 28  SSL_load_error_strings();
 29  SSLeay_add_ssl_algorithms();
 30  meth = SSLv23_client_method();
 31
 32  ctx = SSL_CTX_new (meth);
 33  if (!ctx) {
 34    ERR_print_errors_fp(stderr);
 35    std::cout<<"SSL_CTX_new error."<<std::endl;
 36    return -1;
 37  }

 38
 39  ///////////////////////
 40  // 建立原始的TCP連接 //
 41  ///////////////////////
 42  WSADATA wsaData;
 43  SOCKET client_socket;
 44  struct sockaddr_in addr_server;
 45
 46  ret = WSAStartup( MAKEWORD(22), &wsaData );
 47  if ( ret != 0 ) {
 48    std::cout<<"WSAStartup error."<<std::endl;
 49    return -1;
 50  }

 51  client_socket = socket (AF_INET, SOCK_STREAM, 0);  
 52  if( client_socket == INVALID_SOCKET  ) {
 53    std::cout<<"socket error."<<std::endl;
 54    return -1;
 55  }

 56  
 57  memset (&addr_server, 0sizeof(addr_server));
 58  addr_server.sin_family           = AF_INET;
 59  addr_server.sin_addr.S_un.S_addr = inet_addr(SERVER_IP);
 60  addr_server.sin_port             = htons (SERVER_PORT);
 61
 62  ret = connect(client_socket, (struct sockaddr*&addr_server, sizeof(addr_server)); 
 63  if( client_socket == SOCKET_ERROR  ) {
 64    std::cout<<"connect error."<<std::endl;
 65    return -1;
 66  }

 67
 68  /////////////////////////////////////
 69  // TCP連接已經建立,執行Client SSL //
 70  /////////////////////////////////////
 71  SSL*     ssl;
 72  X509*    server_certificate;
 73  char*    str;
 74
 75  ssl = SSL_new (ctx);                         
 76  if( ssl == NULL ) {
 77    std::cout<<"SSL_new error."<<std::endl;
 78    return -1;
 79  }
 
 80  SSL_set_fd (ssl, client_socket);
 81  ret = SSL_connect (ssl);                     
 82  if( ret == -1 ) {
 83    std::cout<<"SSL_accept error."<<std::endl;
 84    return -1;
 85  }

 86    
 87  // 接下來的獲取密碼和獲取服務器端證書的兩部是可選的,不會影響數據交換
 88  
 89  // 獲取cipher
 90  std::cout<<"SSL connection using: "<<SSL_get_cipher(ssl)<<std::endl;
 91  
 92  // 獲取服務器端的證書
 93  server_certificate = SSL_get_peer_certificate (ssl);       
 94  if( server_certificate != NULL ) {
 95    std::cout<<"Server certificate:"<<std::endl;
 96
 97    str = X509_NAME_oneline (X509_get_subject_name (server_certificate),0,0);
 98    if( str == NULL ) {
 99      std::cout<<"X509_NAME_oneline error."<<std::endl;
100    }
 else {
101      std::cout<<"subject: "<<str<<std::endl;
102      OPENSSL_free (str);
103    }

104
105    str = X509_NAME_oneline (X509_get_issuer_name  (server_certificate),0,0);
106    if( str == NULL ) {
107      std::cout<<"X509_NAME_oneline error."<<std::endl;
108    }
 else {
109      std::cout<<"issuer: "<<str<<std::endl;
110      OPENSSL_free (str);
111    }

112
113    X509_free (server_certificate);
114  }
 else {
115    std::cout<<"Server does not have certificate. we sould Esc!"<<std::endl;
116    return -1;
117  }

118
119  ////////////////
120  //  數據交換  //
121  ////////////////
122  char     buf [4096];
123
124  ret = SSL_write (ssl, "Hello World!", strlen("Hello World!"));  
125  if( ret == -1 ) {
126    std::cout<<"SSL_write error."<<std::endl;
127    return -1;
128  }

129  ret = SSL_read (ssl, buf, sizeof(buf) - 1);  
130  if( ret == -1 ) {
131    std::cout<<"SSL_read error."<<std::endl;
132    return -1;
133  }

134  buf[ret] = '\0';
135  std::cout<<buf<<std::endl;
136  SSL_shutdown(ssl);  /* send SSL/TLS close_notify */
137  
138  /////////////
139  // Cleanup //
140  /////////////
141  closesocket(client_socket);
142  SSL_free (ssl);
143  SSL_CTX_free (ctx);
144  WSACleanup();
145  return 0;
146}

最后的輸出結果:
Server-Console:
Connection from 16777343:20314
SSL connection using: AES256-SHA
Client does not have certificate.
Hello World!


Client-Console:
SSL connection using: AES256-SHA
Server certificate:
subject: /C=cn/ST=shanghai/L=shanghai/O=shanghai/OU=shanghai/CN=shanghai/emailAd
dress=ysong.lee@gmail.com
issuer: /C=cn/ST=shanghai/L=shanghai/O=shanghai/OU=shanghai/CN=shanghai/emailAdd
ress=ysong.lee@gmail.com
I hear you.



posted on 2008-11-03 14:08 ysong.lee 閱讀(12189) 評論(1)  編輯 收藏 引用

Feedback

# re: openssl使用 2008-10-21 15:05 浪跡天涯

呵呵 編譯openvpn的時候需要編譯openssl 剛編譯過!  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲日本理论电影| 久久在线观看视频| 欧美黄网免费在线观看| 在线看视频不卡| 久久婷婷国产麻豆91天堂| 欧美一区二区三区精品| 黑人一区二区| 亚洲成人直播| 免费影视亚洲| 亚洲性视频h| 香蕉精品999视频一区二区| 黄色成人免费观看| 最新日韩在线视频| 国产精品婷婷午夜在线观看| 久久综合导航| 欧美日本一道本| 久久电影一区| 欧美成人小视频| 午夜视频在线观看一区二区| 久久精品一区二区三区不卡牛牛| 亚洲人成小说网站色在线| 制服诱惑一区二区| 影音先锋日韩精品| 在线综合亚洲| 亚洲清纯自拍| 亚洲专区国产精品| 亚洲精品美女久久久久| 亚洲欧美日韩直播| 亚洲精品久久嫩草网站秘色| 亚洲伦理久久| 好看的日韩av电影| 亚洲一区二区欧美| 亚洲看片免费| 久久久久久高潮国产精品视| 亚洲婷婷综合久久一本伊一区| 久久久久国产精品www| 午夜精彩视频在线观看不卡| 欧美激情五月| 亚洲视频免费看| 欧美成ee人免费视频| 久久久免费精品视频| 欧美亚州一区二区三区| 亚洲欧美中文在线视频| 欧美激情成人在线| 欧美二区在线观看| 黑丝一区二区三区| 欧美中文字幕在线播放| 亚洲欧美综合精品久久成人| 欧美日韩精品一区二区天天拍小说| 免费欧美日韩| 午夜精品久久久久久99热软件| 免费观看不卡av| 国产亚洲人成a一在线v站| 亚洲调教视频在线观看| 亚洲视频www| 欧美日韩免费一区二区三区视频| 老司机午夜精品视频在线观看| 国产视频观看一区| 亚洲欧美制服另类日韩| 亚洲女女女同性video| 欧美视频在线一区二区三区| 亚洲黄网站黄| 亚洲精品综合精品自拍| 欧美激情91| 亚洲高清视频中文字幕| 亚洲国内自拍| 蜜桃视频一区| 麻豆成人在线观看| 亚洲激情影院| 欧美激情精品久久久久久久变态| 亚洲国产天堂网精品网站| 亚洲精品欧洲精品| 欧美日一区二区三区在线观看国产免 | 女人天堂亚洲aⅴ在线观看| 韩国三级在线一区| 久久青草福利网站| 欧美国产1区2区| 亚洲精品一区二| 国产精品igao视频网网址不卡日韩| 一区二区国产精品| 久久福利视频导航| 伊人精品久久久久7777| 欧美激情精品久久久久久| 亚洲美女诱惑| 久久精品免费看| 亚洲国产精品电影| 欧美午夜影院| 欧美专区一区二区三区| 亚洲国产精品欧美一二99| 亚洲一区www| 国产综合色精品一区二区三区| 老色鬼精品视频在线观看播放| 亚洲日本中文字幕区| 亚洲欧美综合网| 在线视频国内自拍亚洲视频| 欧美日韩成人在线| 欧美伊久线香蕉线新在线| 欧美激情一区在线观看| 亚洲综合日韩中文字幕v在线| 国产真实精品久久二三区| 欧美成人激情视频免费观看| 亚洲深爱激情| 欧美激情一区二区久久久| 羞羞答答国产精品www一本| 在线观看的日韩av| 国产精品久久久久婷婷| 免费国产自线拍一欧美视频| 亚洲你懂的在线视频| 亚洲黄色成人网| 久久色在线播放| 亚洲自拍高清| 亚洲免费av电影| 一区三区视频| 国产欧美一区二区三区国产幕精品| 欧美成人午夜77777| 久久国产精品久久久久久| 一区二区三区精密机械公司 | 国产日韩免费| 老**午夜毛片一区二区三区| 99国产精品国产精品久久| 国产欧美日韩亚州综合| 欧美a级大片| 久久免费一区| 欧美一级日韩一级| 亚洲综合色噜噜狠狠| 亚洲国产精品尤物yw在线观看| 久久男人资源视频| 欧美一区二区在线观看| 亚洲在线观看免费视频| 一本久久综合亚洲鲁鲁| 亚洲精品久久久久久久久久久久久 | 一区二区免费在线播放| 亚洲国产一区二区在线| 狠狠做深爱婷婷久久综合一区| 国产精品久久久久久久久搜平片| 欧美激情在线观看| 免费在线一区二区| 免费成人黄色av| 久久香蕉国产线看观看网| 久久精品一区二区三区四区| 久久激五月天综合精品| 欧美一区二区在线免费播放| 欧美一级淫片播放口| 欧美一区二区大片| 欧美有码视频| 久久久美女艺术照精彩视频福利播放| 欧美一区二区三区电影在线观看| 午夜在线视频观看日韩17c| 香港久久久电影| 久久高清国产| 老司机精品视频网站| 欧美成人dvd在线视频| 欧美va亚洲va香蕉在线| 欧美日韩不卡视频| 欧美精品免费看| 国产精品电影观看| 国产一区二区av| 在线播放亚洲| 一本一道久久综合狠狠老精东影业| 在线性视频日韩欧美| 午夜在线成人av| 久久婷婷激情| 亚洲日本中文| 亚洲专区在线视频| 久久久91精品国产一区二区精品| 久久久久久一区| 欧美精品久久久久久久久老牛影院| 欧美日韩在线播放三区| 国产精品尤物福利片在线观看| 国模吧视频一区| 日韩视频在线观看免费| 亚洲四色影视在线观看| 久久久久久久综合色一本| 91久久国产综合久久91精品网站| 亚洲视频精选| 美女被久久久| 国产精品欧美经典| 亚洲黄色精品| 欧美在线一二三| 亚洲国产视频直播| 欧美影视一区| 欧美天天影院| 亚洲国产精品va在线看黑人动漫| 亚洲视频一区在线观看| 免费精品99久久国产综合精品| 一本色道久久综合狠狠躁篇怎么玩| 久久精品成人一区二区三区| 欧美日韩久久久久久| 亚洲第一天堂无码专区| 先锋资源久久| 亚洲精品午夜| 鲁大师成人一区二区三区| 国产欧美综合一区二区三区| 99国产精品| 亚洲国产乱码最新视频| 国产精品毛片a∨一区二区三区|国 | 亚洲日韩欧美一区二区在线| 欧美亚洲综合网| 国产精品裸体一区二区三区| 一区二区三区欧美日韩|