心有多大舞臺便有多大

          Embrace changes, pursue excellence, share niceness.

          apache2.2中配置ssl

          一.首先要安裝好openssl
              下載openssl:
               wget http://www.openssl.org/source/openssl-0.9.8a.tar.gz
               ./configure --prefix=/usr/local/openssl
               make
               sudo make install
               也可以直接用apt安裝:
                sudo apt-get install openssl libssl-dev
                注意一定要安裝openssl的開發庫,否則編譯apache的時候會報錯誤,不能編譯ssl的.
          二.編譯安裝apache
               這里不多說了,主要是configure的時候加上ssl的選項

          三.創建ssl所需要的證書
          (這里所有的文件都是創建在/etc/httpd目錄中)
          1.創建key文件:
          sudo openssl genrsa -des3 -out server.key 1024
          執行完后應該在當前目錄中有一個server.key文件


          2.查看創建的key文件:(不是必須)
          openssl rsa -noout -text -in server.key
          3.創建pem文件:(不是必須)
          sudo openssl rsa -in server.key -out server.key.unsecure
          4.創建scr文件:
          sudo openssl req -new -key server.key -out server.csr
          執行完后應該在當前目錄中有一個server.csr文件
          5.創建crt文件:
          sudo openssl x509 -req -days 3650 -in server.csr -signkey server.key -out server.crt
          執行完后應該在當前目錄中有一個server.crt文件

          四.修改apache的ssl配置文件
          1.修改httpd.conf
          在文件中找到下面一行,把注釋去掉
          #Include conf/extra/httpd-ssl.conf
          2.修改httpd-ssl.conf
          在extra目錄中,修改ssl的配置文件
          找到SSLCertificateFile和SSLCertificateKeyFile的配置,修改文件路徑到上面創建的目錄

          五.啟動apache
          sudo /usr/local/apache/bin/apachectl start
          這時應該要求你回答證書密鑰,回答后即可啟動
          打開瀏覽器測試下吧!這時候應該能以https訪問你的站點了.

          但這時,是所有的用戶都可以訪問你的https站點的,如果你希望只有認證的用戶才能訪問的話,請繼續下面的配置!


          六.創建認證客戶所需要的證書
          1.創建用戶的key文件:
          sudo openssl genrsa -des3 -out client.key 1024
          2.創建用戶的crt證書文件:
           sudo openssl req -new -x509 -days 3650 -key client.key -out client.crt
          修改SSLCACertificateFile的文件路徑
          3.創建訪問用戶的csr文件:
          sudo openssl req -new  -out pony.csr
          4.創建訪問用戶的crt證書文件:
          sudo openssl x509 -req -in pony.csr -out pony.crt -signkey client.key -CA client.crt -CAkey client.key -CAcreateserial -days 3650
          5.導出為pfx證書:(ie中只能導入pfx證書)
          sudo openssl pkcs12 -export -in pony.crt -inkey client.key -out pony.pfx
          在你的測試機的ie中導入這個pfx證書
          6.修改ssl配置文件:
          在httpd-ssl.conf文件中找到SSLCACertificateFile的配置,然后修改文件路徑為client.crt
          把以下兩行注釋去掉:
          SSLVerifyClient require
          SSLVerifyDepth  10

          重新啟動apache,再次訪問apache的時候,ie就會彈出窗口選擇證書了.
          that's all

          (本文參考了CU的文章:http://www.chinaunix.net/jh/13/469276.html,非常感謝作者!)

           

          posted on 2008-04-25 14:39 pony 閱讀(3031) 評論(1)  編輯  收藏 所屬分類: linux

          評論

          # re: apache2.2中配置ssl 2009-02-19 15:00 pony

          今天下載試用天威誠信的ssl正式,收到郵件后把-----BEGIN CERTIFICATE----- -----END CERTIFICATE-----的內容拷貝到server.crt文件中,結果因為是用的editplus拷貝的,搞了半天apache都沒有通過,后來發現要用記事本才可以!  回復  更多評論   

          主站蜘蛛池模板: 乌拉特前旗| 荔波县| 浦江县| 曲靖市| 平陆县| 瓦房店市| 分宜县| 磐安县| 建宁县| 永春县| 丰台区| 德州市| 墨江| 安远县| 阿克| 南丹县| 许昌市| 宜昌市| 和硕县| 合川市| 达拉特旗| 开封市| 上犹县| 翁牛特旗| 衡东县| SHOW| 阜南县| 常州市| 武威市| 泉州市| 嘉祥县| 达州市| 南宁市| 英吉沙县| 乐陵市| 江陵县| 福贡县| 鄢陵县| 彭泽县| 南京市| 铁岭县|