gpt4 book ai didi

Android SocketTimeoutException 原因

转载 作者:搜寻专家 更新时间:2023-11-01 09:48:59 29 4
gpt4 key购买 nike

我想在我的应用程序中使用 REST API。它为我从这个应用程序发出的所有请求抛出 SocketTimeoutException

Logcat 输出:(您也可以在此处看到带有漂亮格式的输出:http://pastebin.com/FbZU6wRd)

04-14 18:58:46.769 22839-22839/kovacsdev.hu.facec W/AsyncHttpClient: Passed contentType will be ignored because HttpEntity sets content type 04-14 18:58:46.769 22839-22839/kovacsdev.hu.facec D/dalvikvm: create interp thread : stack size=32KB 04-14 18:58:46.770 22839-22839/kovacsdev.hu.facec D/dalvikvm: create new thread 04-14 18:58:46.770 22839-22839/kovacsdev.hu.facec D/dalvikvm: new thread created 04-14 18:58:46.770 22839-22839/kovacsdev.hu.facec D/dalvikvm: update thread list 04-14 18:58:46.770 22839-23323/kovacsdev.hu.facec D/dalvikvm: threadid=20: interp stack at 0x53f36000 04-14 18:58:46.770 22839-23323/kovacsdev.hu.facec D/dalvikvm: threadid=20: created from interp 04-14 18:58:46.770 22839-22839/kovacsdev.hu.facec D/dalvikvm: start new thread 04-14 18:58:46.771 22839-23323/kovacsdev.hu.facec D/dalvikvm: threadid=20: notify debugger 04-14 18:58:46.771 22839-23323/kovacsdev.hu.facec D/dalvikvm: threadid=20 (pool-2-thread-1): calling run() 04-14 18:58:46.797 22839-22839/kovacsdev.hu.facec I/SurfaceTextureClient: [STC::queueBuffer] (this:0x50c8b858) fps:0.30, dur:6595.54, max:6086.69, min:508.85 04-14 18:58:46.797 22839-22839/kovacsdev.hu.facec I/SurfaceTextureClient: [STC::queueBuffer] this:0x50c8b858, api:1, last queue time elapsed:6086.69 04-14 18:58:47.154 22839-23323/kovacsdev.hu.facec D/libc-netbsd: getaddrinfo: api.kairos.com get result from proxy >> 04-14 18:58:47.155 22839-23323/kovacsdev.hu.facec I/System.out: propertyValue:true 04-14 18:58:47.156 22839-23323/kovacsdev.hu.facec I/System.out: [socket][0] connection /50.17.167.207:80;LocalPort=55439(10000) 04-14 18:58:47.157 22839-23323/kovacsdev.hu.facec I/System.out: [CDS]connect[/50.17.167.207:80] tm:10 04-14 18:58:47.158 22839-23323/kovacsdev.hu.facec D/Posix: [Posix_connect Debug]Process kovacsdev.hu.facec :80 04-14 18:58:47.158 22839-23323/kovacsdev.hu.facec I/System.out: [socket][/192.168.199.102:55439] connected 04-14 18:58:47.158 22839-23323/kovacsdev.hu.facec I/System.out: [CDS]rx timeout:10000 04-14 18:58:47.159 22839-23323/kovacsdev.hu.facec W/System.err: rto value is too small:0 04-14 18:58:47.164 22839-23323/kovacsdev.hu.facec I/System.out: >doSendRequest 04-14 18:58:47.167 22839-22847/kovacsdev.hu.facec D/jdwp: processIncoming 04-14 18:58:47.167 22839-22847/kovacsdev.hu.facec D/jdwp: handlePacket : cmd=0x1, cmdSet=0xC7, len=0x14, id=0x4000013E, flags=0x0, dataLen=0x9 04-14 18:58:47.167 22839-22847/kovacsdev.hu.facec D/jdwp: sendBufferedRequest : len=0x34 04-14 18:58:47.254 22839-23323/kovacsdev.hu.facec I/System.out:

这里发生了确切的问题。

04-14 18:58:57.248 22839-23323/kovacsdev.hu.facec I/System.out: [CDS]EAGAIN or EWOULDBLOCK in Recvfrom 04-14 18:58:57.249 22839-23323/kovacsdev.hu.facec I/System.out: [CDS]read byte is 0 04-14 18:58:57.250 22839-23323/kovacsdev.hu.facec I/System.out: [CDS]close[55439] 04-14 18:58:57.251 22839-23323/kovacsdev.hu.facec I/System.out: close [socket][/0.0.0.0:55439] 04-14 18:58:57.252 22839-23323/kovacsdev.hu.facec I/System.out: ex:java.net.SocketTimeoutException 04-14 18:58:57.253 22839-23323/kovacsdev.hu.facec W/System.err: java.net.SocketTimeoutException 04-14 18:58:57.268 22839-23323/kovacsdev.hu.facec W/System.err: at java.net.PlainSocketImpl.read(PlainSocketImpl.java:495)

代码 fragment :

    public void onClick(View v) {
Bitmap image = BitmapFactory.decodeFile(file);
String subjectId = user;
String galleryId = "users";
String selector = "FULL";
String multipleFaces = "false";
String minHeadScale = "0.25";
try {
myKairos.enroll(image,
subjectId,
galleryId,
selector,
multipleFaces,
minHeadScale,
listener);
} catch (JSONException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}

Kairos 类中的方法。

/*
* Enroll subject into gallery (Image)
*/
public void enroll(Bitmap image,
String subjectId,
String galleryId,
String selector,
String multipleFaces,
String minHeadScale,
final KairosListener callback) throws JSONException, UnsupportedEncodingException {

AsyncHttpClient client = new AsyncHttpClient();

AsyncHttpResponseHandler responseHandler = new AsyncHttpResponseHandler() {

@Override
public void onStart() {
// called before request is started
}

@Override
public void onSuccess(int statusCode, Header[] headers, byte[] response) {
// called when response HTTP status is "200 OK"
String responseString = new String(response);
callback.onSuccess(responseString);
}

@Override
public void onFailure(int statusCode, Header[] headers, byte[] errorResponse, Throwable e) {
// called when response HTTP status is "4XX" (eg. 401, 403, 404)
String responseString = new String(errorResponse);
callback.onFail(responseString);

}

@Override
public void onRetry(int retryNo) {
// called when request is retried
}

};

JSONObject jsonParams = new JSONObject();
jsonParams.put("image", base64FromBitmap(image));
jsonParams.put("subject_id", subjectId);
jsonParams.put("gallery_name", galleryId);

if(selector != null) {
jsonParams.put("selector", selector);
}

if(minHeadScale != null) {
jsonParams.put("minHeadScale", minHeadScale);
}

if(multipleFaces != null) {
jsonParams.put("multiple_faces", multipleFaces);
}

StringEntity entity = new StringEntity(jsonParams.toString());
client.addHeader("app_id", my_app_id);
client.addHeader("app_key", my_api_key);
client.post(my_context, "http://api.kairos.com/enroll", entity, "application/json", responseHandler);

}

最佳答案

按照此处的建议创建静态 Http 客户端 http://loopj.com/android-async-http/ , 而且还将上下文传递给 get/post 方法。

关于Android SocketTimeoutException 原因,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36629873/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com