java basic验证_java如何请求BASIC认证的https协议

/**

* BASIC认证的https

* @param urlStr https请求的地址

* @return

*/

public static String get(String urlStr) {

log.info("url-->" + urlStr);

String rs = "";

StringBuffer buffer = new StringBuffer();

DefaultHttpClient client =null;

HttpGet get = new HttpGet(urlStr);

InputStream instream = null;

BufferedReader in = null;

HttpResponse response;

try {

//处理HTTPS请求

client= new SSLClient();

//BASIC认证

client.getCredentialsProvider().setCredentials(AuthScope.ANY,new

UsernamePasswordCredentials("用户名","密码"));

//获取响应

response = client.execute(get);

instream = response.getEntity().getContent();

in = new BufferedReader(new InputStreamReader(instream, "utf-8"));

String line = "";

while ((line = in.readLine()) != null) {

buffer.append(line);

}

rs = buffer.toString();

System.out.println(rs);

} catch (Exception e) {

e.printStackTrace();

}finally{

//释放资源,自己处理一下,不在赘述

}

return rs;

}

public class SSLClient extends DefaultHttpClient{

//证书处理

private static Logger log = Logger.getLogger(getClass().class);

public SSLClient() throws Exception{

super();

SSLContext ctx = SSLContext.getInstance("TLS");

X509TrustManager tm = new X509TrustManager() {

@Override

public void checkClientTrusted(X509Certificate[] chain,

String authType) throws CertificateException {

}

@Override

public void checkServerTrusted(X509Certificate[] chain,

String authType) throws CertificateException {

}

@Override

public X509Certificate[] getAcceptedIssuers() {

return null;

}

};

log.info("---");

ctx.init(null, new TrustManager[]{tm}, null);

SSLSocketFactory ssf = new

SSLSocketFactory(ctx,SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);

ClientConnectionManager ccm = this.getConnectionManager();

SchemeRegistry sr = ccm.getSchemeRegistry();

sr.register(new Scheme("https", 443, ssf));

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值