Okhttp 提供了对用户认证的支持。当 http 响应的状态代码是 401 时,Okhttp 会从设置的 Authenticator 对象中获取到新的 Request 对象并再次尝试发出请求。Authenticator 接口中的 authenticate 方法用来提供进行认证的 Request 对象,authenticateProxy 方法用来提供对代理服务器进行认证的 Request 对象。
用户认证的示例:
OkhttpClIEnt clIEnt = new OkhttpClIEnt();clIEnt.setAuthenticator(new Authenticator() {public Request authenticate(Proxy proxy,Response response) throws IOException { String credential = Credentials.basic("user","password"); return response.request().newBuilder() .header("Authorization",credential) .build();}public Request authenticateProxy(Proxy proxy,Response response) throws IOException { return null;}});
进阶
当需要实现一个 Basic challenge, 使用 Credentials.basic(username,password) 来编码请求头。
private final OkhttpClIEnt clIEnt = new OkhttpClIEnt();public voID run() throws Exception { clIEnt.setAuthenticator(new Authenticator() { @OverrIDe public Request authenticate(Proxy proxy,Response response) { System.out.println("Authenticating for response: " + response); System.out.println("Challenges: " + response.challenges()); String credential = Credentials.basic("jesse","password1"); return response.request().newBuilder() .header("Authorization",credential) .build(); } @OverrIDe public Request authenticateProxy(Proxy proxy,Response response) { return null; // Null indicates no attempt to authenticate. } }); Request request = new Request.Builder() .url("http://publicobject.com/secrets/hellosecret.txt") .build(); Response response = clIEnt.newCall(request).execute(); if (!response.isSuccessful()) throw new IOException("Unexpected code " + response); System.out.println(response.body().string());}总结
以上是内存溢出为你收集整理的Android的OkHttp包处理用户认证的代码实例分享全部内容,希望文章能够帮你解决Android的OkHttp包处理用户认证的代码实例分享所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)