有時候你所在的公司基於安全因素考慮,要求你使用通過安全認證的代理訪問因特網。這種情況下,就需要爲Maven配置HTTP代理,才能讓它正常訪問外部倉庫,以下載所需要的資源。
首先確認自己無法直接訪問公共的Maven中央倉庫,直接運行命令ping repol.maven.org可以檢查網絡。如果真的需要代理,先檢查一下代理服務器是否暢通。比如現在有一個IP地址爲218.14.227.197,端口爲3128的代理服務,我們可以運行telnet218.14.227.197 3128來檢測該地址的該端口是否暢通。如果得到出錯信息,需要先獲取正確的代理服務信息;如果telnet連接正確,則輸入ctrl+],然後q,回車,退出即可。
檢查完畢後,編輯#/.m2/setting.xml文件(如果沒有該文件,則複製$M2_HOME/conf/settings.xml)。添加代理配置如下:
<settings>
…
<proxies>
<proxy>
<id>my-proxy</id>
<active>true</active>
<protocol>http</protocol>
<host>218.12.227.197</host>
<port>3128</port>
<--
<username>***</username>
<password>***</password>
<nonProxyHosts>repository.mycom.com|*.google.com<nonProxyHosts>
-->
</proxy>
</proxies>
…
</settings>
Proxies下可以有多個proxy元素,如果聲明瞭多個proxy元素,則默認情況下第一個被激活的proxy會生效。這裏聲明瞭一個id爲my-proxy的代理,active的值爲true表示激活該代理,protocol表示使用的代理協議,這裏是http。當然,最重要的是指定正確的主機名(host元素)和端口(port元素)。當服務器需要認證時,就需要配置username和password。nonProxyHost元素用來指定哪些主機名不需要代理,可以使用“|”符號來分隔多個主機名。此外,該配置也支持通配符,如*.google.com表示所有以google.com結尾的域名訪問都不要通過代理。