В данный момент я пишу клиент сокета.
Запись в сокет работает отлично.
Но когда я пытаюсь прочитать данные с BufferedReader, он зависает.
Иногда это работает, но в основном сокет уничтожается (устройством?).
(Я вижу это только на стороне сервера: + WIND: 62: Ушел клиент сокетов: 172.20.237.2, что означает клиентушел / закрыл сокет)
Я пытался:
- first i used readNewLine, it worked but slowly so i tought this was
blocking.
- then i tried Char by Char but this is also blocking at: br.read i think.
- i tried to set Socket Timeot to 100000 e.g.
- i changed port (80,3067, now 6660)
Я не знаю, почему он так медленно, его единственное подключение от Wifi-модуля (с Socketlistener) к Android-телефону.
В этом примере я использую символ "!"сообщить моему клиенту, когда строка в конце.
Может быть, это еще одна проблема ... Я надеюсь, что кто-нибудь может мне помочь.
Вот мой код записи / чтения:
@Override
protected String doInBackground(String... params) //was strings
{
ip = params[0];
message = params[1];
port = params[2];
try
{
s = new Socket(ip,Integer.parseInt(port));
s.setSoTimeout(100000);
if (s.isConnected())
{
dos = new DataOutputStream(s.getOutputStream());
dos.writeBytes(message);
dos.flush();
is = s.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr);
//StringBuffer buffer = new StringBuffer();
// or of course StringBuffer if you need to be treadsafe
StringBuilder messageBuffer = new StringBuilder();
// reads to the end of the stream or till end of message
while((value = br.read()) != -1) {
char c = (char)value;
// end? jump out
if (c == endMarker) {
break;
}
// else, add to buffer
messageBuffer.append(c);
}
// message is complete!
response = messageBuffer.toString();
/*
BufferedReader br = new BufferedReader(new
InputStreamReader(s.getInputStream()));
response = br.readLine();
*/
}
//dos.writeUTF(message);
//br.close();
dos.close();
s.close();
}
catch (IOException e)
{
e.printStackTrace();
}
return response;
}
И LogCat после того, как я увидел, что Клиент ушел:
Я не знаю, вызвало ли это проблему или произошло после нее:
java.lang.NumberFormatException: s ==null
2018-11-20 15:34:44.921 3787-3920/? D/SemContextService:
Service.updateContext() : service = Step Level Monitor
2018-11-20 15:34:44.924 22956-23045/? I/Sensor[0x06]: [0x01] 33
2018-11-20 15:34:44.925 22956-23045/? I/Sensor[0x04]: [0x01]
1542724446610[0x02] 0[0x03] 2[0x04] 10012
2018-11-20 15:34:45.686 27406-27406/? D/gpsd: CALL_SENTRY(main()):
GlEngine::OnResourceRelease took 251 ms (from 143759612 to 143759863)
(logOverhead=0,0,0,0,0,0,0), start: 15:34:45.435
2018-11-20 15:34:45.937 27406-27406/? D/gpsd: CALL_SENTRY(main()):
GlEngine::OnResourceRequest took 251 ms (from 143759863 to 143760114)
(logOverhead=0,0,0,0,0,0,0), start: 15:34:45.686
2018-11-20 15:34:45.940 27406-27406/? D/gpsd: CALL_SENTRY(main()):
GlEngine::ChipData took 506 ms (from 143759611 to 143760117)
(logOverhead=0,0,0,0,0,0,0), start: 15:34:45.434
2018-11-20 15:34:45.941 27406-27406/? D/gpsd: CALL_SENTRY(main()):
ProcessEvent took 507 ms (from 143759611 to 143760118)
(logOverhead=0,0,0,0,0,0,0), start: 15:34:45.434
2018-11-20 15:34:46.161 3787-8916/? D/ConnectivityService:
filterNetworkStateForUid() uid: 1000 networkInfo: [type: WIFI[] - WIFI,
state: CONNECTED/CONNECTED, reason: (unspecified), extra: "SocketAppTest",
failover: false, available: true, roaming: false, metered: false]
2018-11-20 15:34:46.192 3408-6813/? V/APM_AudioPolicyManager:
getAudioPolicyConfig: audioParam;activeStream
2018-11-20 15:34:46.193 3408-6813/? V/APM_AudioPolicyManager: ### active
stream : 0
2018-11-20 15:34:46.194 3787-8916/? D/AudioService: active stream is 0x0
2018-11-20 15:34:46.196 3408-6813/? V/APM_AudioPolicyManager:
getAudioPolicyConfig: audioParam;outDevice
2018-11-20 15:34:46.196 3408-6813/? V/APM_AudioPolicyManager:
getNewOutputDevice() selected device 0
2018-11-20 15:34:46.197 3408-6813/? V/APM_AudioPolicyManager: ### curdevice
: 2
2018-11-20 15:34:46.202 3787-8916/? W/System.err:
java.lang.NumberFormatException: s == null
2018-11-20 15:34:46.202 3787-8916/? W/System.err: at
java.lang.Integer.parseInt(Integer.java:570)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at b.b.aF(:79)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at b.c.aN(:149)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at b.n.run(:72)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at
android.os.Handler.handleCallback(Handler.java:789)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at
android.os.Handler.dispatchMessage(Handler.java:98)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at
android.os.Looper.loop(Looper.java:164)
2018-11-20 15:34:46.203 3787-8916/? W/System.err: at
android.os.HandlerThread.run(HandlerThread.java:65)
2018-11-20 15:34:46.678 12232-12699/? D/ClClient: Not sending keepalive.
Current connection state=STOPPED
2018-11-20 15:34:46.699 3418-3639/? D/DnsProxyListener: DNSDBG::dns addrinfo
af 2
2018-11-20 15:34:47.611 3787-8916/? D/SSRM:w: SIOP:: AP = 340, PST = 340
(W:15), BAT = 313, USB = 318, CHG = 346, CP = 333
2018-11-20 15:34:48.087 4959-4959/? D/io_stats: !@ 8,0 r 5038254 276077112
w 1290028 18962328 d 122047 41066928 f 289127 307003 iot 2157260 1768288 th
307200 0 0 pt 0 inp 0 0 63174.392
2018-11-20 15:34:49.339 3787-3909/? D/SamsungAlarmManager: Expired : 4
2018-11-20 15:34:49.340 3787-3909/? I/SamsungAlarmManager: setLocked to
kernel - T:2 / 20181120T153509, SetElapsed=143783728, nowELAPSED=143763517
2018-11-20 15:34:49.341 3787-3909/? I/SamsungAlarmManager: setLocked to
kernel - T:3 / 20181120T153500, SetElapsed=143774177, nowELAPSED=143763518
2018-11-20 15:34:49.342 3787-3909/? V/SamsungAlarmManager: Sending to uid :
1000 listener=android.app.AlarmManager$ListenerWrapper@fa0b687
alarm=Alarm{5a2ea2f type 2 when 143763516 android}
2018-11-20 15:34:49.356 3787-4006/? D/SamsungAlarmManager: setExact Listener
(T:2/F:9/AC:false) 20181120T153525 - CU:1000/CP:3787
2018-11-20 15:34:49.501 13308-13308/? E/hw-IPCThreadState: binder thread
pool (1 threads) starved for 155 ms
2018-11-20 15:34:49.632 13308-13308/? E/hw-IPCThreadState: binder thread
pool (1 threads) starved for 129 ms
2018-11-20 15:34:49.649 3787-4015/? D/WifiP2pService: InactiveState143375
2018-11-20 15:34:49.650 3787-4015/? D/WifiP2pService: P2pEnabledState143375
2018-11-20 15:34:49.701 3787-6300/? D/SamsungAlarmManager: setExact Listener
(T:2/F:9/AC:false) 20181120T153450 - CU:1000/CP:3787
2018-11-20 15:34:49.702 3787-6300/? I/SamsungAlarmManager: setLocked to
kernel - T:2 / 20181120T153450, SetElapsed=143764875, nowELAPSED=143763879
2018-11-20 15:34:50.698 3787-3909/? D/SamsungAlarmManager: Expired : 4
2018-11-20 15:34:50.699 3787-3909/? I/SamsungAlarmManager: setLocked to
kernel - T:2 / 20181120T153509, SetElapsed=143783728, nowELAPSED=143764876
2018-11-20 15:34:50.700 3787-3909/? V/SamsungAlarmManager: Sending to uid :
1000 listener=android.app.AlarmManager$ListenerWrapper@44c69c5
alarm=Alarm{213f1a type 2 when 143764844 android}
2018-11-20 15:34:50.747 3787-6300/? D/SamsungAlarmManager: setExact Listener
(T:2/F:9/AC:false) 20181120T153452 - CU:1000/CP:3787
2018-11-20 15:34:50.747 3787-6300/? I/SamsungAlarmManager: setLocked to
kernel - T:2 / 20181120T153452, SetElapsed=143767063, nowELAPSED=143764924
2018-11-20 15:34:50.753 3787-6300/? D/DhcpClient: Renewed lease: IP address
172.20.237.2/24 Gateway 172.20.237.1 DNS servers: [ 172.20.237.1 ] Domains
DHCP server /172.20.237.1 Vendor info null lease 240 seconds
2018-11-20 15:34:50.754 3787-6300/? D/SamsungAlarmManager: Cancel Alarm
calling from uid:1000 pid :3787 /
listener:android.app.AlarmManager$ListenerWrapper@77dfa4b
2018-11-20 15:34:50.754 3787-4006/? D/SamsungAlarmManager: Cancel Alarm
calling from uid:1000 pid :3787 /
listener:android.app.AlarmManager$ListenerWrapper@912383c
2018-11-20 15:34:50.758 3787-6300/? I/SamsungAlarmManager: setLocked to
kernel - T:2 / 20181120T153500, SetElapsed=143774177, nowELAPSED=143764935
2018-11-20 15:34:50.769 3787-4015/? D/WifiP2pService: InactiveState143375
2018-11-20 15:34:50.769 3787-6300/? D/SamsungAlarmManager: setExact Listener
(T:2/F:9/AC:false) 20181120T153645 - CU:1000/CP:3787
2018-11-20 15:34:50.770 3787-4015/? D/WifiP2pService: P2pEnabledState143375
Также я только что нашел это в LogCat: (Может быть, проблема?)
2018-11-20 16:01:01.546 3384-3384/? E/audit: type=1400
audit(1542726061.545:3227): avc: denied { read } for pid=16998
comm="Analytics-Norma" name="boot_id" dev="proc" ino=3571102
scontext=u:r:untrusted_app:s0:c512,c768 tcontext=u:object_r:proc:s0
tclass=file permissive=0 SEPF_SM-G955F_8.0.0_0017 audit_filtered
2018-11-20 16:01:01.549 16998-17153/? E/msgr.BootIdReader: Error reading
boot_id from procfs
java.io.FileNotFoundException: /proc/sys/kernel/random/boot_id (Permission
denied)
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:200)
at java.io.FileInputStream.<init>(FileInputStream.java:150)
at java.io.FileInputStream.<init>(FileInputStream.java:103)
at java.io.FileReader.<init>(FileReader.java:58)
at X.2MN.a(:372675)
at X.46q.a(:579709)
at X.0Hi.A(Unknown Source:26)
at X.0IH.a(:60614)
at X.0IH.b(:60638)
at X.41k.a(:569612)
at X.1y8.a(:339223)
at X.1rz.a(:330137)
at X.0dC.a(:118033)
at X.0d9.a(:117958)
at X.0fP.d(:123017)
at X.0fP.c(:122985)
at X.0fP.handleMessage(:123035)
at android.os.Handler.dispatchMessage(Handler.java:105)
at android.os.Looper.loop(Looper.java:164)
at android.os.HandlerThread.run(HandlerThread.java:65)
2018-11-20 16:01:02.739 16656-16708/? E/Fabric: Settings request failed.
+...
2018-11-20 16:04:25.446 16779-16855/? E/BtGatt.GattService: [GSIM LOG]:
gsimLogHandler, msg: MESSAGE_SCAN_STOP, appName: com.enbw.ev, scannerId: 7,
reportDelayMillis=0
2018-11-20 16:04:25.472 4777-5949/? E/ExecutionCriteria: Package unavailable
for task: com.tumblr/com.firebase.jobdispatcher.GooglePlayReceiver{u=0
tag="retryServiceTag"
trigger=window{start=3429s,end=3610s,earliest=-3609249s,latest=-3609069s}
requirements=[NET_ANY] attributes=[PERSISTED,RECURRING] scheduled=-3612679s
last_run=N/A jid=N/A status=PENDING retries=0
client_lib=FIREBASE_JOB_DISPATCHER-1}
2018-11-20 16:04:36.402 3787-4392/? E/Watchdog: !@Sync 2164 [2018-11-20
16:04:36.402]
2018-11-20 16:04:39.119 5626-5793/? E/ContactsProvider_EventLog: Flush
buffer to file cnt : 1 size : 1Kb duration : 2ms lastUpdatedAfter : 60132 ms
mFlush_time_threasold : 2000 mCurrentSize : 800
2018-11-20 16:04:55.481 4777-5949/? E/ExecutionCriteria: Package unavailable
for task: com.tumblr/com.firebase.jobdispatcher.GooglePlayReceiver{u=0
tag="retryServiceTag"
trigger=window{start=3429s,end=3610s,earliest=-3609279s,latest=-3609099s}
requirements=[NET_ANY] attributes=[PERSISTED,RECURRING] scheduled=-3612709s
last_run=N/A jid=N/A status=PENDING retries=0
client_lib=FIREBASE_JOB_DISPATCHER-1}
2018-11-20 16:04:55.551 16779-16855/? E/BtGatt.GattService: [GSIM LOG]:
gsimLogHandler, msg: MESSAGE_SCAN_START, appName: com.enbw.ev, scannerId: 7,
reportDelayMillis=0
2018-11-20 16:05:00.596 16779-16855/? E/BtGatt.GattService: [GSIM LOG]:
gsimLogHandler, msg: MESSAGE_SCAN_STOP, appName: com.enbw.ev, scannerId: 7,
reportDelayMillis=0