ios 企業應用"無法安裝應用程序 因爲證書無效"的解決方案

http://blog.csdn.net/zhaoxy_thu/article/details/21133399

今天升級了iOS7.1後發現通過之前的url無法安裝企業應用了,一直提示“無法安裝應用程序 因爲http://xxx.xxx.xxx證書無效”,折騰了一番,終於在StackOverFlow上找到了答案。在這裏分享給大家。

StackOverFlow鏈接:http://stackoverflow.com/questions/20276907/enterprise-app-deployment-doesnt-work-on-ios-7-1/22325916#22325916

原因是由於iOS7.1要安裝企業應用,url必須是https的,不能是http,這就要求我們的服務器要支持https。因此,只要將原鏈接:

  1. itms-services://?action=download-manifest&url=http://example.com/manifest.plist  

改爲

[plain] view plaincopy
  1. itms-services://?action=download-manifest&url=https://example.com/manifest.plist  

即可。

對於服務器,則需要增加對https的支持,本人用的是apache服務器,所以在這裏以apache服務器爲例:

1. 安裝配有SSL模塊的apache版本,本人使用的是httpd-2.0.65-win32-x86-openssl-0.9.8y

2. 打開apache的配置文件conf/httpd.conf,去掉以下內容前的#

[plain] view plaincopy
  1. LoadModule ssl_module modules/mod_ssl.so  

並在文件最後加上:

[plain] view plaincopy
  1. <VirtualHost *:8080>  
  2.     ServerAdmin [email protected](隨意)  
  3.     DocumentRoot D:/Server(服務器根目錄)  
  4.     ServerName 166.111.81.xxx(服務器域名或ip地址)  
  5.     ErrorLog logs/test-error_log  
  6.     CustomLog logs/test-access_log common  
  7.     SSLEngine on  
  8.     SSLCertificateFile "D:/Program Files/Apache Group/Apache2/conf/ssl.crt/server.crt"(之後生成證書的完整路徑)  
  9.     SSLCertificateKeyFile "D:/Program Files/Apache Group/Apache2/conf/ssl.key/server.key" (之後生成密鑰的完整路徑)  
  10.   
  11. </VirtualHost>  

3. 修改conf/ssl.conf文件的以下內容:(以下爲修改完的,大家可以參考下)
[plain] view plaincopy
  1. #SSLSessionCache        none  
  2. #SSLSessionCache        shmht:logs/ssl_scache(512000)  
  3. SSLSessionCache        shmcb:logs/ssl_scache(512000)  
  4. #SSLSessionCache         dbm:logs/ssl_scache  
  5. ...  
  6. SSLCertificateFile conf/ssl.crt/server.crt  
  7. ...  
  8. SSLCertificateKeyFile conf/ssl.key/server.key  
4. 在conf目錄下創建ssl.crt和ssl.key目錄(不創建也行,只要保證以上兩個路徑和之後的文件路徑對應即可)

5. 在命令行下切換到apache目錄下的bin目錄,運行以下命令

生成服務器的私鑰:

[plain] view plaincopy
  1. openssl genrsa -out server.key 1024  
6. 生成簽署申請(注意除Common Name以外可以爲空,Common Name必須爲服務器的ip或域名):
[plain] view plaincopy
  1. openssl req -new –out server.csr -key server.key -config ..\conf\openssl.cnf  
7. 生成CA私鑰:
[plain] view plaincopy
  1. openssl genrsa  -out ca.key 1024  
8. 利用CA的私鑰產生CA的自簽署證書(注意除Common Name以外可以爲空,Common Name必須爲服務器的ip或域名):
[plain] view plaincopy
  1. openssl req  -new -x509 -days 365 -key ca.key -out ca.crt  -config ..\conf\openssl.cnf  

9. 在當前目錄創建demoCA,裏面創建文件index.txt和serial,serial內容爲01,index.txt爲空,以及文件夾newcerts。

10. CA爲網站服務器簽署證書:
[plain] view plaincopy
  1. openssl ca -in server.csr -out server.crt -cert ca.crt -keyfile ca.key -config ..\conf\openssl.cnf  
11. 最後將server.crt,server.key複製到上文對應的路徑下:
[plain] view plaincopy
  1. conf/ssl.crt/server.crt  
  2. conf/ssl.key/server.key  
12. 重啓Apache服務器,即增加了https的支持。可以在瀏覽器訪問https://localhost試試。如果不行,可以在logs\test-error_log文件中看看出了什麼錯誤。

13. 最後,我們要將自己創建的CA證書安裝到iphone上。將第10步生成的ca.crt文件通過郵件發送到iphone上,用自帶的Mail程序(別的程序不行)打開安裝即可。

14. 現在,再次訪問我們之前的itms-services鏈接,就可以正常安裝了。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章