jabberd2 伺服器的工作 TLS 憑證

jabberd2 伺服器的工作 TLS 憑證

我想運行具有安全客戶端連接的 jabberd2 伺服器(V 2.40)。
我按照文檔中的說明進行操作,伺服器已啟動並運行:
https://github.com/jabberd2/jabberd2/wiki/InstallGuide-OpenSSLConfiguration

但似乎沒有安全的客戶端連線。
當我按照請求證書的提示進行操作時,沒有對等證書:
從 jabber 伺服器取得 SSL 憑證鏈

openssl s_client -connect my.jabber.server.net:5222 </dev/null

CONNECTED(00000003)
---
no peer certificate available
---
No client certificate CA names sent
---
SSL handshake has read 648 bytes and written 117 bytes
---
New, (NONE), Cipher is (NONE)
Secure Renegotiation IS NOT supported
Compression: NONE
Expansion: NONE

實際配置是

  <local>
         <pemfile>/etc/jabberd2/jabber.pem</pemfile>
         <verify-mode>7</verify-mode>
         <require-starttls>1</require-starttls>
         <ciphers>EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH</ciphers>
    <id register-enable='mu'>domainname.de</id>
  </local>

按照 c2s.xml 中的提示,我將其更改為

  <local>
    <id realm='domainname.de'
        pemfile='/etc/jabberd2/jabber.pem'
        ciphers='EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH'
        verify-mode='7'
        require-starttls='mu'
        instructions='Geben Sie einen gueltigen Benutzernamen mit Passwort an um einzuloggen!'
    >domainname.de</id>
    <id password-change='mu' />
  </local>

然後 openssl 測試成功

---
No client certificate CA names sent
---
SSL handshake has read 1700 bytes and written 138 bytes
---
New, TLSv1/SSLv3, Cipher is ECDHE-RSA-AES256-GCM-SHA384
Server public key is 1024 bit
Secure Renegotiation IS supported
Compression: NONE
Expansion: NONE
SSL-Session:
    Protocol  : TLSv1.2
    Cipher    : ECDHE-RSA-AES256-GCM-SHA384
    Session-ID:
    Session-ID-ctx:
    Master-Key: 720846E32D...CA23
    Key-Arg   : None
    PSK identity: None
    PSK identity hint: None
    SRP username: None
    Start Time: 1484331794
    Timeout   : 300 (sec)
    Verify return code: 18 (self signed certificate)
---

但現在沒有客戶端會連接到伺服器!
我用 pidgin 和 psi 測試了它,都報告了 ssl 握手錯誤!

閱讀範例 c2s.xml 我發現:

<id realm='company.int'
    pemfile='/etc/jabberd2/server.pem'
    verify-mode='7'
    cachain='/etc/jabberd2/client_ca_certs.pem'
    require-starttls='mu'
    register-enable='mu'
    instructions='Enter a username and password to register with this server.'
    register-oob='http://example.org/register'
    password-change='mu'
>example.net</id>

那也許 client_ca_certs.pem 遺失了?
但我不知道如何生成它?

任何幫助都會很棒。

答案1

-starttls xmppJabber 在連接埠 5222 上使用 STARTTLS 協定擴展,因此測試時需要啟用該擴展:

openssl s_client -connect my.jabber.server.net:5222 -starttls xmpp </dev/null

5222 虛擬主機的所有連線選項都直接設定為<id ... />標記上的屬性。

啟用後,可以在連接埠 5223 上使用 SSL 中的直接 XMPP 隧道。您在<local> ... <pemfile> etc...配置 5223 連接埠下配置為標記的選項。如果啟用此功能,您可以在沒有-startls選項的情況下進行測試:

openssl s_client -connect my.jabber.server.net:5223 </dev/null

相關內容