如何配置Java HTTPS CA證書(shū)(Jetty,Tomcat)

應(yīng)蘋(píng)果APP Store 要求(蘋(píng)果要求所有iOS應(yīng)用必須使用ATS(App Transport Security)峰档,不少項(xiàng)目已啟用HTTPS協(xié)議禁添,當(dāng)然網(wǎng)上已有很多列子撮胧,但多數(shù)都是講解自定義簽名證書(shū)

一般來(lái)說(shuō),主流的Web服務(wù)軟件老翘,通常都基于兩種基礎(chǔ)密碼庫(kù):OpenSSL和Java芹啥。
Tomcat锻离、Weblogic、JBoss等墓怀,使用Java提供的密碼庫(kù)汽纠。通過(guò)Java的Keytool工具,生成Java Keystore(JKS)格式的證書(shū)文件傀履。
Apache虱朵、Nginx等,使用OpenSSL提供的密碼庫(kù)钓账,生成PEM碴犬、KEY、CRT等格式的證書(shū)文件官扣。

Tomcat翅敌、Jetty服務(wù)器

如果是自定義簽名證書(shū),直接Java JDK keytool生成簽名文件keystore或jks文件

找到安裝Tomcat目錄下該文件server.xml,一般默認(rèn)路徑都是在 conf 文件夾中惕蹄。找到 <Connection port="8443" 標(biāo)簽蚯涮,增加如下屬性:

<Connector port="8443"
    protocol="HTTP/1.1"
    SSLEnabled="true"
    scheme="https"
    secure="true"
    keystoreFile="server.keystore"
    keystorePass="證書(shū)密碼"
    clientAuth="false"/>

如果是CA分發(fā)證書(shū),需要下載證書(shū)(一般包含pem和key文件)卖陵,若下載文件里面有pfx文件遭顶,可以直接使用它作為簽名文件
若沒(méi)有需要自己去制作一個(gè)pfx文件或jks文件,命令如下:

openssl pkcs12 -export -out 213981318100861.pfx -inkey 213981318100861.key -in 213981318100861.pem

Tomcat配置如下:

<Connector port="8443"
    protocol="HTTP/1.1"
    SSLEnabled="true"
    scheme="https"
    secure="true"
    keystoreFile="cert/213981318100861.pfx"
    keystoreType="PKCS12"
    keystorePass="證書(shū)密碼"
    clientAuth="false"
    ciphers="TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256"
    SSLProtocol="TLSv1+TLSv1.1+TLSv1.2"
    SSLCipherSuite="ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4"/>

####### JKS證書(shū)安裝
( 1 ) 使用java jdk將PFX格式證書(shū)轉(zhuǎn)換為JKS格式證書(shū)(windows環(huán)境注意在%JAVA_HOME%/jdk/bin目錄下執(zhí)行)

keytool -importkeystore -srckeystore 213981318100861.pfx -destkeystore your-name.jks -srcstoretype PKCS12 -deststoretype JKS

回車(chē)后輸入JKS證書(shū)密碼和PFX證書(shū)密碼泪蔫,強(qiáng)烈推薦將JKS密碼與PFX證書(shū)密碼相同棒旗,否則可能會(huì)導(dǎo)致Tomcat啟動(dòng)失敗。

( 2 ) 找到安裝 Tomcat 目錄下該文件Server.xml撩荣,一般默認(rèn)路徑都是在 conf 文件夾中铣揉。找到 <Connection port="8443" 標(biāo)簽,增加如下屬性:

<Connector port="8443"
    protocol="HTTP/1.1"
    SSLEnabled="true"
    scheme="https"
    secure="true"
    keystoreFile="cert/your-name.jks"
    keystorePass="證書(shū)密碼"
    clientAuth="false"
    ciphers="TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256"
    SSLProtocol="TLSv1+TLSv1.1+TLSv1.2"
    SSLCipherSuite="ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4"/>

( 注意:不要直接拷貝所有配置餐曹,只需添加 keystoreFile,keystorePass等參數(shù)即可逛拱,其它參數(shù)請(qǐng)根據(jù)自己的實(shí)際情況修改 )

OK,搞定台猴,重啟Tomcat

Jetty配置

簽名生成也和以上一樣朽合,就不說(shuō)了
pom文件添加以下配置:

<plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>maven-jetty-plugin</artifactId>
        <version>6.1.7</version>
        <configuration>
          <webAppSourceDirectory>${project.basedir}/src/main/webapp</webAppSourceDirectory>
          <connectors>
            <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector">
              <port>10092</port>
              <maxIdleTime>30000</maxIdleTime>
            </connector>
            <connector implementation="org.mortbay.jetty.security.SslSocketConnector">
              <port>10093</port>
              <maxIdleTime>60000</maxIdleTime>
              <keystore>cert/your-name.jks</keystore>
              <password>證書(shū)密碼</password>
              <keyPassword>證書(shū)密碼</keyPassword>
            </connector>
          </connectors>
          <webAppConfig>
            <contextPath>/</contextPath>
          </webAppConfig>
          <scanIntervalSeconds>2</scanIntervalSeconds>
        </configuration>
      </plugin>

檢測(cè)HTTPS是否完全符合ATS的要求,命令如下:

nscurl --ats-diagnostics --verbose 網(wǎng)址

如果HTTPS服務(wù)器能通過(guò)ATS特性饱狂,則上面所有測(cè)試案例都是PASS曹步;如果某一項(xiàng)的Reuslt是FAIL,就找到ATS Dictionary來(lái)查看休讳,就能知道HTTPS服務(wù)器不滿(mǎn)足ATS哪個(gè)條件讲婚。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市俊柔,隨后出現(xiàn)的幾起案子筹麸,更是在濱河造成了極大的恐慌纳猫,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件竹捉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡尚骄,警方通過(guò)查閱死者的電腦和手機(jī)块差,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)倔丈,“玉大人憨闰,你說(shuō)我怎么就攤上這事⌒栉澹” “怎么了鹉动?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)宏邮。 經(jīng)常有香客問(wèn)我泽示,道長(zhǎng),這世上最難降的妖魔是什么蜜氨? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任械筛,我火速辦了婚禮,結(jié)果婚禮上飒炎,老公的妹妹穿的比我還像新娘埋哟。我一直安慰自己,他們只是感情好郎汪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布赤赊。 她就那樣靜靜地躺著,像睡著了一般煞赢。 火紅的嫁衣襯著肌膚如雪抛计。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,488評(píng)論 1 302
  • 那天耕驰,我揣著相機(jī)與錄音爷辱,去河邊找鬼。 笑死朦肘,一個(gè)胖子當(dāng)著我的面吹牛饭弓,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播媒抠,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼弟断,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了趴生?” 一聲冷哼從身側(cè)響起阀趴,我...
    開(kāi)封第一講書(shū)人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤昏翰,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后刘急,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體棚菊,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年叔汁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了统求。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡据块,死狀恐怖码邻,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情另假,我是刑警寧澤像屋,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站边篮,受9級(jí)特大地震影響己莺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜戈轿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一篇恒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧凶杖,春花似錦胁艰、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至杈湾,卻和暖如春解虱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背漆撞。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工殴泰, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浮驳。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓悍汛,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親至会。 傳聞我的和親對(duì)象是個(gè)殘疾皇子离咐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容