GVKun编程网logo

如何用RequestConfig替换不推荐使用的httpClient.getParams()?

213

本文将为您提供关于如何用RequestConfig替换不推荐使用的httpClient.getParams的详细介绍,我们还将为您解释?的相关知识,同时,我们还将为您提供关于.NET中如何选择WebC

本文将为您提供关于如何用RequestConfig替换不推荐使用的httpClient.getParams的详细介绍,我们还将为您解释的相关知识,同时,我们还将为您提供关于.NET 中如何选择 WebClient,HttpClient,HttpWebRequest、android-在使用不推荐使用的版本时,对不推荐使用和不推荐使用的变体两次调用了shouldInterceptRequest、ASP.net HttpRequest上的静态HttpClient线程安全、AsyncHttpClient, RequestParams ,AsyncHttpResponseHandler三个类使用方法的实用信息。

本文目录一览:

如何用RequestConfig替换不推荐使用的httpClient.getParams()?

如何用RequestConfig替换不推荐使用的httpClient.getParams()?

我已经继承了代码

import org.apache.http.client.HttpClient;
...
HttpClient httpclient = createHttpClientOrProxy();
...



private HttpClient createHttpClientOrProxy() {
    HttpClient httpclient = new DefaultHttpClient();

    /*
     * Set an HTTP proxy if it is specified in system properties.
     * 
     * http://docs.oracle.com/javase/6/docs/technotes/guides/net/proxies.html
     * http://hc.apache.org/httpcomponents-client-ga/httpclient/examples/org/apache/http/examples/client/ClientExecuteProxy.java
     */
    if( isSet(System.getProperty("http.proxyHost")) ) {
        int port = 80;
        if( isSet(System.getProperty("http.proxyPort")) ) {
            port = Integer.parseInt(System.getProperty("http.proxyPort"));
        }
        HttpHost proxy = new HttpHost(System.getProperty("http.proxyHost"),port,"http");
// @Deprecated methods here... getParams() and ConnRoutePNames
        httpclient.getParams().setParameter(ConnRoutePNames.DEFAULT_PROXY,proxy);
    }
    return httpclient;
}

httpClient.getParams() @已弃用,并显示为“

HttpParams  getParams()
Deprecated. 
(4.3) use RequestConfig.

没有RequestConfig的类文档,我不知道应该使用哪种方法来替换getParams()and
ConnRoutePNames.DEFAULT_PROXY

.NET 中如何选择 WebClient,HttpClient,HttpWebRequest

.NET 中如何选择 WebClient,HttpClient,HttpWebRequest

当我们在用 .NET 调用 RestAPI 时通常有三种选择,分别为:WebClient,HttpWebRequest,HttpClient,这篇文章我们将会讨论如何使用这三种方式去调用 RestAPI,我还会提供相应的代码案例来帮助你更好的理解这三者的概念和使用方式,简单来说:

  • HttpWebRequest 是一种相对底层的处理 Http request/response 的方式。

  • WebClient 提供了对 HttpWebRequest 的高层封装,来简化使用者的调用。

  • HttpClient 是一种新的处理 Http request/response 工具包,具有更高的性能。

接下来我们讨论一下抽象类 WebRequest

WebRequest

WebRequest 是一种基于特定的 http 实现,它是一个抽象类,所以在处理 Reqeust 请求时底层会根据传进来的 url 生成相应的子类,如:HttpWebRequest 或 FileWebRequest ,下面的代码展示了如何使用 WebRequest。


WebRequest webRequest = WebRequest.Create(uri);
webRequest.Credentials = CredentialCache.DefaultCredentials;
webRequest.Method ="GET";
HttpWebResponse webResponse = (HttpWebResponse)webRequest.GetResponse();

WebRequest 是 .NET Framework 中第一个用来处理 Http 请求的类,在处理 Http请求和响应 方面给调用者提供了诸多的灵活性,你还可以使用这个类来存取 headers,cookies,protocols 和 timeouts 等等,下面的代码展示了其实现子类 HttpWebRequest 是如何使用的。


HttpWebRequest http = HttpWebRequest)WebRequest.Create(“http://localhost:8900/api/default”);
WebResponse response = http.GetResponse();
MemoryStream memoryStream = response.GetResponseStream();
StreamReader streamReader = new StreamReader(memoryStream);
string data = streamReader.ReadToEnd();

WebClient

WebClient 是 HttpWebRequest 的高层封装,它给调用者提供了更便捷的使用方式,理所当然做出的牺牲就是 WebClient 的性能略逊于 HttpWebRequest,如果你的业务场景只是简单访问第三方的 Http Service,那么我建议你使用 WebClient ,同理如果你有更多的精细化配置则使用 HttpWebRequest,下面的代码展示了如何使用 WebClient 。


string data = null;

using (var webClient = new WebClient())
{
    data = webClient.DownloadString(url);
}

HttpClient

HttpClient 是在 .NET Framework 4.5 中被引入的,如果你的项目是基于 .NET 4.5 以上版本,除一些特定的原因之外,建议你优先使用 HttpClient,本质上来说,HttpClient 作为后来之物,它吸取了 HttpWebRequest 的灵活性及 WebClient 的便捷性,所以说

android-在使用不推荐使用的版本时,对不推荐使用和不推荐使用的变体两次调用了shouldInterceptRequest

android-在使用不推荐使用的版本时,对不推荐使用和不推荐使用的变体两次调用了shouldInterceptRequest

我有webView覆盖shouldInterceptRequest方法:

@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
    WebResourceResponse response = proxy.getWebResourceResponse(request.getUrl(), request.getmethod(), request.getRequestHeaders());
    if (response == null) {
        return super.shouldInterceptRequest(view, request);
    } else {
        return response;
    }
}

@SuppressWarnings("deprecation")
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
    WebResourceResponse response = proxy.getWebResourceResponse(Uri.parse(url), "GET", null);
    if (response == null) {
        return super.shouldInterceptRequest(view, url);
    } else {
        return response;
    }
}

问题是在棒棒糖上这两种方法都被调用了.因此,我认为我应该指定不赞成使用的版本仅应用于旧的Android版本.与RequiresApi完全相反
如果可以通过制作复制粘贴类并使用if-else根据Android版本选择类来解决问题,但这确实很丑.

更新.更新以更好地反映问题.

解决方法:

默认实现WebViewClient in Android source codes从较新的版本调用不赞成使用的shouldInterceptRequest版本,将请求中的当前URL作为字符串传递:

@Deprecated
public WebResourceResponse shouldInterceptRequest(WebView view, String url)
{
    return null;
}

public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request)
{
    return shouldInterceptRequest(view, request.getUrl().toString());
}

由于您从自定义WebViewClient实现中调用了默认的Lollipop特定处理程序(当request为null时,使用super.shouldInterceptRequest(view,request)),因此它将依次调用已弃用的处理程序的重写实现.

您不应从新的实现中调用super方法,以免执行不受欢迎的方法.

ASP.net HttpRequest上的静态HttpClient线程安全

ASP.net HttpRequest上的静态HttpClient线程安全

我们正在为HttpClient创建一个包装器.因为我们将遵循 https://github.com/mspnp/performance-optimization的性能优化指南.我们希望避免反模式 – 该文档中提到的不正确的实例化.我将此指南提交给我的团队使用静态HttpClient.我得到的反馈是线程安全性.每个请求都有一个包含用户声明的标头.由于我有一个静态的HttpClient,它是否是线程安全的?如果我们同时有多个请求命中代码(例如GET),那么设置标题是否会出现竞争条件?我们的实施如下.
public class HttpClientHelper{
private static readonly HttpClient _HttpClient;
static HttpClientHelper() {
        HttpClient = new HttpClient();
        HttpClient.Timeout = TimeSpan.FromMinutes(SOME_CONfig_VALUE);
}

public async Task<HttpResponseMessage> CallHttpClientPostAsync(string requestUri,HttpContent requestBody)
{
    AddHttpRequestHeader(httpClient);
    var response = await httpClient.PostAsync(requestUri,requestBody); //Potential thread synchronization issue???
    return response;
}

public HttpResponseMessage CallHttpClientGet(string requestUri)
{
    AddHttpRequestHeader(httpClient);
    var response = httpClient.GetAsync(requestUri).Result; //Potential thread synchronization issue???
    return response;
}

private void AddHttpRequestHeader(HttpClient client)
{
    string HeaderName = "CorrelationId";
    client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(Properties.Settings.Default.HttpClientAuthHeaderScheme,GetTokenFromClaims()); //Race condition???
    if (client.DefaultRequestHeaders.Contains(HeaderName))
        client.DefaultRequestHeaders.Remove(HeaderName);
    client.DefaultRequestHeaders.Add(HeaderName,Trace.CorrelationManager.ActivityId.ToString());
}

}

解决方法

你的团队是正确的,这远非线程安全.考虑这种情况:

>线程A将CorrelationId标头设置为“foo”.
>线程B将CorrelationId标头设置为“bar”.
>线程A发送请求,其中包含线程B的CorrelationId.

更好的方法是使用CallXXX方法创建新的HttpRequestMessage对象,并在其上设置标题,并使用HttpClient.SendAsync进行调用.

请记住,重新使用HttpClient实例仅在您对同一主机进行多次调用时才有用.

AsyncHttpClient, RequestParams ,AsyncHttpResponseHandler三个类使用方法

AsyncHttpClient, RequestParams ,AsyncHttpResponseHandler三个类使用方法

1. AsyncHttpClient, RequestParams ,AsyncHttpResponseHandler三个类使用方法

(1)AsyncHttpClient
public class AsyncHttpClient extends java.lang.Object
 该类通常用在android应用程序中创建异步GET, POST, PUT和DELETE HTTP请求,请求参数通过RequestParams实例创建,响应通过重写匿名内部类 ResponseHandlerInterface的方法处理。
例子:

AsyncHttpClient client = new AsyncHttpClient();
 client.get("http://www.baidu.com", new ResponseHandlerInterface() {
     @Override
     public void onSuccess(String response) {
         System.out.println(response);
     }
 });


(2)RequestParams
public class RequestParams extends java.lang.Object 
用于创建AsyncHttpClient实例中的请求参数(包括字符串或者文件)的集合
例子:

RequestParams params = new RequestParams();
 params.put("username", "tom");
 params.put("password", "111111");
 params.put("email", "my@email.com");
 params.put("file", new File("test.txt")); // Upload a File
 
 Map<String, String> map = new HashMap<String, String>();
 map.put("first_name", "James");
 map.put("last_name", "Smith");
 params.put("user", map); // url params: "user[first_name]=James&user[last_name]=Smith"
 
 Set<String> set = new HashSet<String>(); // unordered collection
 set.add("music");
 set.add("art");
 params.put("like", set); // url params: "like=music&like=art"
 
 List<String> list = new ArrayList<String>(); // Ordered collection
 list.add("Java");
 list.add("C");
 params.put("languages", list); // url params: "languages[]=Java&languages[]=C"
 
 String[] colors = { "blue", "yellow" }; // Ordered collection
 params.put("colors", colors); // url params: "colors[]=blue&colors[]=yellow"
 
 List<Map<String, String>> listOfMaps = new ArrayList<Map<String, String>>();
 Map<String, String> user1 = new HashMap<String, String>();
 user1.put("age", "30");
 user1.put("gender", "male");
 Map<String, String> user2 = new HashMap<String, String>();
 user2.put("age", "25");
 user2.put("gender", "female");
 listOfMaps.add(user1);
 listOfMaps.add(user2);
 params.put("users", listOfMaps); // url params: "users[][age]=30&users[][gender]=male&users[][age]=25&users[][gender]=female"
 
 AsyncHttpClient client = new AsyncHttpClient();
 client.post("http://myendpoint.com", params, responseHandler);


(3)public class AsyncHttpResponseHandler extends java.lang.Object implements ResponseHandlerInterface
用于拦截和处理由AsyncHttpClient创建的请求。在匿名类AsyncHttpResponseHandler中的重写 onSuccess(int, org.apache.http.Header[], byte[])方法用于处理响应成功的请求。此外,你也可以重写 onFailure(int, org.apache.http.Header[], byte[], Throwable), onStart(), onFinish(), onRetry() 和onProgress(int, int)方法
例子:

AsyncHttpClient client = new AsyncHttpClient();
 client.get("http://www.google.com", new AsyncHttpResponseHandler() {
     @Override
     public void onStart() {
         // Initiated the request
     }
 
     @Override
     public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
         // Successfully got a response
     }
 
     @Override
     public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error)
 {
         // Response failed :(
     }
 
     @Override
     public void onRetry() {
         // Request was retried
     }
 
     @Override
     public void onProgress(int bytesWritten, int totalSize) {
         // Progress notification
     }
 
     @Override
     public void onFinish() {
         // Completed the request (either success or failure)
     }
 });


2.利用RequestParams上传文件
类RequestParams支持multipart file 文件上传


(1)添加文件对象用于上传

File myFile = new File("/path/to/file.png");
RequestParams params = new RequestParams();
try {
    params.put("profile_picture", myFile);
} catch(FileNotFoundException e) {}


(2)添加字节数组用于上传(字节转化见上一片)
byte[] myByteArray = bytes;
RequestParams params = new RequestParams();
params.put("file", new ByteArrayInputStream(myByteArray), "text.txt");

转载自:http://my.oschina.net/u/1471093/blog/341811

关于如何用RequestConfig替换不推荐使用的httpClient.getParams的介绍现已完结,谢谢您的耐心阅读,如果想了解更多关于.NET 中如何选择 WebClient,HttpClient,HttpWebRequest、android-在使用不推荐使用的版本时,对不推荐使用和不推荐使用的变体两次调用了shouldInterceptRequest、ASP.net HttpRequest上的静态HttpClient线程安全、AsyncHttpClient, RequestParams ,AsyncHttpResponseHandler三个类使用方法的相关知识,请在本站寻找。

本文标签: