use of org.apache.hc.client5.http.impl.DefaultConnectionKeepAliveStrategy in project ajapaik-android-app by Ajapaik.
the class WebOperation method performRequest.
public boolean performRequest(String baseURL, Map<String, String> extraParameters, BasicCookieStore cookieStore) {
Log.d(TAG, "performRequest()");
ConnectivityManager cm = (ConnectivityManager) m_context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo info = cm.getActiveNetworkInfo();
boolean isPost = isPost();
String url = m_url;
URI uri;
if (baseURL != null && !url.contains("://")) {
if (url.startsWith("/") && baseURL.endsWith("/")) {
url = baseURL + url.substring(1);
} else {
url = baseURL + url;
}
}
if (m_client == null) {
if (BuildConfig.DEBUG) {
Log.d(TAG, "new m_client");
}
try {
m_client = HttpClients.custom().setKeepAliveStrategy(new DefaultConnectionKeepAliveStrategy()).setDefaultCookieStore(cookieStore).build();
} catch (Exception e) {
Log.w(TAG, e.toString());
}
}
if (BuildConfig.DEBUG) {
Log.d(TAG, "m_client ready");
}
m_started = true;
if (info == null || info.getState() == NetworkInfo.State.DISCONNECTED) {
onFailure();
if (BuildConfig.DEBUG) {
Log.d(TAG, "No network connection");
}
return false;
}
try {
uri = URI.create(url);
} catch (Exception e) {
Log.w(TAG, "Unable to parse URL (" + url + ")");
onFailure();
return false;
}
for (int i = 0; i < RETRY_COUNT && !m_cancelled; i++) {
CloseableHttpResponse response = null;
HttpUriRequestBase request;
if (isPost) {
HttpPost postRequest = new HttpPost(uri);
request = postRequest;
if (m_file != null || (extraParameters != null && extraParameters.size() > 0) || (m_parameters != null && m_parameters.size() > 0)) {
List<NameValuePair> postData = new ArrayList<NameValuePair>(((extraParameters != null) ? extraParameters.size() : 0) + ((m_parameters != null) ? m_parameters.size() : 0));
if (m_parameters != null) {
for (Map.Entry<String, String> entry : m_parameters.entrySet()) {
postData.add(new BasicNameValuePair(entry.getKey(), entry.getValue()));
}
}
if (extraParameters != null) {
for (Map.Entry<String, String> entry : extraParameters.entrySet()) {
postData.add(new BasicNameValuePair(entry.getKey(), entry.getValue()));
}
}
try {
StringBuilder strData = new StringBuilder();
String separator = "";
MultipartEntityBuilder builder = MultipartEntityBuilder.create();
builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
if (m_file != null) {
Log.d(TAG, "Adding file to post");
for (NameValuePair pair : postData) {
StringBody stringBody1 = new StringBody(pair.getValue(), ContentType.MULTIPART_FORM_DATA);
builder.addPart(pair.getName(), stringBody1);
strData.append(separator);
strData.append(pair.toString());
separator = "&";
}
FileBody fileBody = new FileBody(m_file, ContentType.DEFAULT_BINARY);
builder.addPart("original", fileBody);
HttpEntity entity = builder.build();
postRequest.setEntity(entity);
} else {
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(postData);
postRequest.setEntity(entity);
for (NameValuePair pair : postData) {
strData.append(separator);
strData.append(pair.toString());
separator = "&";
}
}
if (BuildConfig.DEBUG) {
Log.d(TAG, strData.toString());
}
} catch (Exception e) {
Log.d(TAG, "UTF8 is not supported");
}
}
} else if ((extraParameters != null && extraParameters.size() > 0) || (m_parameters != null && m_parameters.size() > 0)) {
Uri.Builder uriBuilder = Uri.parse(m_url).buildUpon();
if (m_parameters != null) {
for (Map.Entry<String, String> entry : m_parameters.entrySet()) {
uriBuilder.appendQueryParameter(entry.getKey(), entry.getValue());
}
}
if (extraParameters != null) {
for (Map.Entry<String, String> entry : extraParameters.entrySet()) {
uriBuilder.appendQueryParameter(entry.getKey(), entry.getValue());
}
}
request = new HttpGet(URI.create(uriBuilder.build().toString()));
} else {
request = new HttpGet(uri);
}
request.setHeader("Accept-Encoding", CONTENT_ENCODING_GZIP);
try {
String encoding = null;
HttpEntity entity;
if (BuildConfig.DEBUG) {
Log.e(TAG, "Retry count:" + i);
Log.e(TAG, ((isPost) ? "POST: " : "GET: ") + request.toString());
Log.e(TAG, "Cookies before: " + cookieStore.getCookies().toString());
}
response = m_client.execute(request);
if ((entity = response.getEntity()) != null) {
encoding = entity.getContentEncoding();
}
try {
onResponse(response.getCode(), (encoding != null && CONTENT_ENCODING_GZIP.equals(encoding)) ? new GZIPInputStream(entity.getContent()) : entity.getContent());
Log.e(TAG, "responseCode: " + response.getCode());
Log.e(TAG, "Cookies after: " + cookieStore.getCookies().toString());
List<Cookie> cookies = cookieStore.getCookies();
String session_id = null;
for (int n = 0; n < cookies.size(); n++) {
if (cookies.get(n).getName().equals("sessionid")) {
Log.d(TAG, "Cookie :" + cookies.get(n).getName() + "; value " + cookies.get(n).getValue());
session_id = cookies.get(n).getValue();
}
}
// If no session_id in response then kill login
if (session_id == null) {
Log.e(TAG, "No session_id in response cookie");
m_settings.setSession(null);
}
} catch (ApiException e) {
Crashlytics.log(e.toString());
Crashlytics.setString("URL", url);
if (m_parameters != null && !m_parameters.isEmpty()) {
Crashlytics.setString("params", new JSONObject(m_parameters).toString());
}
Crashlytics.logException(e);
}
response.close();
return true;
} catch (IOException e) {
if (BuildConfig.DEBUG) {
Log.w(TAG, "Network error", e);
}
Crashlytics.log(e.toString());
Crashlytics.setString("URL", url);
Crashlytics.logException(e);
try {
HttpEntity entity = response.getEntity();
entity.getContent().close();
} catch (Exception e1) {
}
request.abort();
try {
Thread.sleep(RETRY_INTERVAL);
} catch (InterruptedException e1) {
}
}
}
return true;
}
use of org.apache.hc.client5.http.impl.DefaultConnectionKeepAliveStrategy in project californium by eclipse.
the class HttpClientFactory method createClient.
/**
* Create the pooled asynchronous http client.
*
* @param config configuration for the http client
* @return asynchronous http client
* @since 3.0 (changed parameter to Configuration)
*/
public static CloseableHttpAsyncClient createClient(Configuration config) {
int connectionIdleSecs = config.getTimeAsInt(Proxy2Config.HTTP_CONNECTION_IDLE_TIMEOUT, TimeUnit.SECONDS);
final CloseableHttpAsyncClient client = HttpAsyncClientBuilder.create().disableCookieManagement().setDefaultRequestConfig(createCustomRequestConfig(config)).setConnectionManager(createPoolingConnManager(config)).setVersionPolicy(HttpVersionPolicy.NEGOTIATE).setIOReactorConfig(IOReactorConfig.custom().setSoTimeout(Timeout.ofSeconds(connectionIdleSecs)).build()).addRequestInterceptorFirst(new RequestConnControl()).addRequestInterceptorFirst(new RequestDate()).addRequestInterceptorFirst(new RequestExpectContinue()).addRequestInterceptorFirst(new RequestTargetHost()).addRequestInterceptorFirst(new RequestUserAgent()).setKeepAliveStrategy(new DefaultConnectionKeepAliveStrategy() {
@Override
public TimeValue getKeepAliveDuration(HttpResponse response, HttpContext context) {
TimeValue keepAlive = super.getKeepAliveDuration(response, context);
if (keepAlive == null || keepAlive.getDuration() < 0) {
// Keep connections alive if a keep-alive value
// has not be explicitly set by the server
keepAlive = KEEP_ALIVE;
}
return keepAlive;
}
}).build();
client.start();
return client;
}
Aggregations