天天看點

java中設定代理的兩種方式1 前言2 采用設定系統屬性3  使用Proxy4 總結

有時候我們的程式中要提供可以使用代理通路網絡,代理的方式包括http、https、ftp、socks代理。比如在IE浏覽器設定代理。

那我們在我們的java程式中使用代理呢,有如下兩種方式。直接上代碼.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

<code>import</code> <code>java.net.Authenticator;</code>

<code>import</code> <code>java.net.PasswordAuthentication;</code>

<code>import</code> <code>java.util.Properties;</code>

<code>public</code> <code>class</code> <code>ProxyDemo1 {</code>

<code>    </code><code>public</code>

<code>static</code> <code>void</code> <code>main(String[] args) {</code>

<code>        </code><code>Properties prop = System.getProperties();</code>

<code>        </code><code>// 設定http通路要使用的代理伺服器的位址</code>

<code>        </code><code>prop.setProperty(</code><code>"http.proxyHost"</code><code>,</code><code>"183.45.78.31"</code><code>);</code>

<code>        </code><code>// 設定http通路要使用的代理伺服器的端口</code>

<code>        </code><code>prop.setProperty(</code><code>"http.proxyPort"</code><code>,</code><code>"8080"</code><code>);</code>

<code>        </code><code>// 設定不需要通過代理伺服器通路的主機,可以使用*通配符,多個位址用|分隔</code>

<code>        </code><code>prop.setProperty(</code><code>"http.nonProxyHosts"</code><code>,</code><code>"localhost|192.168.0.*"</code><code>);</code>

<code>        </code><code>// 設定安全通路使用的代理伺服器位址與端口</code>

<code>        </code><code>// 它沒有https.nonProxyHosts屬性,它按照http.nonProxyHosts 中設定的規則通路</code>

<code>        </code><code>prop.setProperty(</code><code>"https.proxyHost"</code><code>,</code><code>"183.45.78.31"</code><code>);</code>

<code>        </code><code>prop.setProperty(</code><code>"https.proxyPort"</code><code>,</code><code>"443"</code><code>);</code>

<code>        </code><code>// 使用ftp代理伺服器的主機、端口以及不需要使用ftp代理伺服器的主機</code>

<code>        </code><code>prop.setProperty(</code><code>"ftp.proxyHost"</code><code>,</code><code>"183.45.78.31"</code><code>);</code>

<code>        </code><code>prop.setProperty(</code><code>"ftp.proxyPort"</code><code>,</code><code>"21"</code><code>);</code>

<code>        </code><code>prop.setProperty(</code><code>"ftp.nonProxyHosts"</code><code>,</code><code>"localhost|192.168.0.*"</code><code>);</code>

<code>        </code><code>// socks代理伺服器的位址與端口</code>

<code>        </code><code>prop.setProperty(</code><code>"socksProxyHost"</code><code>,</code><code>"183.45.78.31"</code><code>);</code>

<code>        </code><code>prop.setProperty(</code><code>"socksProxyPort"</code><code>,</code><code>"1080"</code><code>);</code>

<code>        </code><code>// 設定登陸到代理伺服器的使用者名和密碼</code>

<code>        </code><code>Authenticator.setDefault(</code><code>new</code>

<code>MyAuthenticator(</code><code>"userName"</code><code>,</code><code>"Password"</code><code>));</code>

<code>    </code><code>}</code>

<code>    </code><code>static</code>

<code>class</code> <code>MyAuthenticator</code><code>extends</code>

<code>Authenticator {</code>

<code>        </code><code>private</code>

<code>String user =</code><code>""</code><code>;</code>

<code>String password =</code><code>""</code><code>;</code>

<code>        </code><code>public</code>

<code>MyAuthenticator(String user, String password) {</code>

<code>            </code><code>this</code><code>.user = user;</code>

<code>            </code><code>this</code><code>.password = password;</code>

<code>        </code><code>}</code>

<code>        </code><code>protected</code>

<code>PasswordAuthentication getPasswordAuthentication() {</code>

<code>            </code><code>return</code>

<code>new</code> <code>PasswordAuthentication(user, password.toCharArray());</code>

<code>}</code>

<code>import</code> <code>java.io.BufferedReader;</code>

<code>import</code> <code>java.io.InputStreamReader;</code>

<code>import</code> <code>java.net.HttpURLConnection;</code>

<code>import</code> <code>java.net.InetSocketAddress;</code>

<code>import</code> <code>java.net.Proxy;</code>

<code>import</code> <code>java.net.URL;</code>

<code>public</code>

<code>class</code> <code>ProxyDemo2 {</code>

<code>static</code> <code>void</code> <code>main(String[] args)</code><code>throws</code>

<code>Exception {</code>

<code>        </code><code>URL url =</code><code>new</code>

<code>URL(</code><code>""</code><code>);</code>

<code>        </code><code>// /建立代理伺服器</code>

<code>        </code><code>InetSocketAddress addr =</code><code>new</code>

<code>InetSocketAddress(</code><code>"192.168.0.254"</code><code>,</code><code>8080</code><code>);</code>

<code>        </code><code>// Proxy proxy = new Proxy(Proxy.Type.SOCKS, addr); // Socket 代理</code>

<code>        </code><code>Proxy proxy =</code><code>new</code>

<code>Proxy(Proxy.Type.HTTP, addr);</code><code>// http 代理</code>

<code>MyAuthenticator(</code><code>"username"</code><code>,</code><code>"password"</code><code>));</code><code>// 設定代理的使用者和密碼</code>

<code>        </code><code>HttpURLConnection connection = (HttpURLConnection) url.openConnection(proxy);</code><code>// 設定代理通路</code>

<code>        </code><code>InputStreamReader in =</code><code>new</code>

<code>InputStreamReader(connection.getInputStream());</code>

<code>        </code><code>BufferedReader reader =</code><code>new</code>

<code>BufferedReader(in);</code>

<code>        </code><code>while</code>

<code>(</code><code>true</code><code>) {</code>

<code>            </code><code>String s = reader.readLine();</code>

<code>            </code><code>if</code>

<code>(s !=</code><code>null</code><code>) {</code>

<code>                </code><code>System.out.println(s);</code>

<code>            </code><code>}</code>

OK,就這麼的簡單,搞定,用第一種方式是一種全局的代理,用第種方式可以針對具體的哪一個使用代理。知道了這些我們就可以做我們想做的事情了哦!