采用HTTPClient通过代理连接服务器

没有文采 专栏收录该内容
19 篇文章 0 订阅
 

使用代理一般的办法是用HTTPConnection的静态方法setProxyServer实现:

HTTPConnection.setProxyServer("my.proxy.dom", 8008);

调用该方法以后产生的HTTPConnection对象都会通过该代理建立服务器连接。

特定某一个连接使用代理:

setCurrentProxy()

你也可以设置连接某些服务器不要采用代理:

HTTPConnection.dontProxyFor("localhost");

假如代理服务器要求用户名密码认证:

AuthorizationInfo.addDigestAuthorization(host, proxyPort, "", name, pass);

其中第三个参数是认证域,一般代理服务器可以设为空字符串,除非你知道服务器的确切域。

还有另外一个方法就是使用DefaultAuthHandler

DefaultAuthHandler.setAuthorizationPrompter(new MyAuthPrompter(pa_name, pa_pass));

MyAuthPrompter是实现了AuthorizationPrompter接口的自定义类:

class MyAuthPrompter implements AuthorizationPrompter

{

    private String  pa_name, pa_pass;

    private boolean been_here = false;

    MyAuthPrompter(String pa_name, String pa_pass) {

       this.pa_name = pa_name;

       this.pa_pass = pa_pass;

    }

    public NVPair getUsernamePassword(AuthorizationInfo challenge, boolean forProxy) {

       if (forProxy  &&  pa_name != null){

           if (been_here) {

              System.out.println("Proxy authorization failed");

                  return null;

           }

           been_here = true;

           return new NVPair(pa_name, pa_pass);

       }

       if (been_here)    {

           System.out.println("Proxy authorization succeeded");

       }

       // print out all challenge info

       if (forProxy)

           System.out.println("The proxy requires authorization");

       else

           System.out.println("The server requires authorization for this resource");

       return null;

    }

}

关于页面认证

一个页面是否需要认证,以及要求认证的信息可以通过HTTPClient/doc/GetAuthInfo.java来获取:

java GetAuthInfo http://some.host.dom/the/file.html

程序会输出认证信息包括认证域。

 

附注:

下载要求用户认证的页面时, HTTPClient 会弹出用户名密码以及作用域输入框。假如需要取消输入弹出对话框的话,可以调用 HTTPConnection setAllowUserInteraction(false) 方法。
  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
<p style="color:#666666;"> <span style="font-size:14px;">本门课程重实战,将基础知识拆解到项目里,让你在项目情境里学知识。</span> </p> <p style="color:#666666;"> <span style="font-size:14px;">这样的学习方式能让你保持兴趣、充满动力,时刻知道学的东西能用在哪、能怎么用。</span> </p> <p style="color:#666666;"> <span style="font-size:14px;">平时不明白的知识点,放在项目里去理解就恍然大悟了。</span> </p> <p style="color:#666666;"> <span></span> </p> <p style="color:#666666;"> <span style="font-size:14px;"> </span> </p> <p style="color:#666666;"> <span style="color:#FF0000;font-size:14px;"><strong>一、融汇贯通</strong></span> </p> <p style="color:#666666;"> <span style="font-size:14px;">本视频采用了前后端分离的开发模式,前端使用Vue.js+Element UI实现了Web页面的呈现,后端使用Python 的Django框架实现了数据访问的接口,前端通过Axios访问后端接口获得数据。在学习完本章节后,真正理解前后端的各自承担的工作。</span> </p> <p style="color:#666666;"> <span style="font-size:14px;"> </span> </p> <p style="color:#666666;"> <span style="color:#FF0000;font-size:14px;"><strong>二、贴近实战</strong></span> </p> <p style="color:#666666;"> <span style="font-size:14px;">本系列课程为练手项目实战:学生管理系统v4.0的开发,项目包含了如下几个内容:项目的总体介绍、基本功能的演示、Vuejs的初始化、Element UI的使用、在Django中实现针对数据的增删改查的接口、在Vuejs中实现前端增删改查的调用、实现文件的上传、实现表格的分页、实现导出数据到Excel、实现通过Excel导入数据、实现针对表格的批量化操作等等,所有的功能都通过演示完成、贴近了实战</span> </p> <p style="color:#666666;"> <span style="font-size:14px;"> </span> </p> <p style="color:#666666;"> <span style="color:#FF0000;font-size:14px;"><strong>三、课程亮点</strong></span> </p> <p style="color:#666666;"> <span style="font-size:14px;">在本案例中,最大的亮点在于前后端做了分离,真正理解前后端的各自承担的工作。前端如何和后端交互</span> </p> <p style="color:#666666;"> <span style="font-size:14px;"> </span> </p> <p style="color:#666666;"> <span style="color:#FF0000;font-size:14px;"><strong>适合人群:</strong></span> </p> <p style="color:#666666;"> <span style="font-size:14px;">1、有Python语言基础、web前端基础,想要深入学习Python Web框架的朋友;</span> </p> <p style="color:#666666;"> <span style="font-size:14px;">2、有Django基础,但是想学习企业级项目实战的朋友;</span> </p> <p style="color:#666666;"> <span style="font-size:14px;">3、有MySQL数据库基础的朋友</span> </p> <p style="color:#666666;"> <span style="font-size:14px;"> </span> </p> <p style="color:#666666;"> <span style="font-size:14px;"><img alt="" src="https://img-bss.csdnimg.cn/202009070752197496.png" /><br /> </span> </p> <p style="color:#666666;"> <span style="font-size:14px;"><br /> </span> </p>
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值