![](/img/trans.png)
[英]Android - java connected via socket programming. dataoutputstream write does not fail on the java side after the device is disconnected from network
[英]java socket disconnected from server side
我在服务器端遇到有关套接字的问题。 我的代码是客户端。 每当我发送第二条消息(无论是心跳或其他任何消息)时,它将在服务器上失败,并且服务器端记录“消息格式错误”,但同一条消息将首次成功。 这个你能帮我吗。 我的客户代码:
public class Main {
String Host = "";
int port = 1111;
Socket ss;
BufferedReader in;
BufferedWriter out;
String recv;
public void connection() {
try {
ss = new Socket(Host, port);
ss.setSoTimeout(30000);
in = new BufferedReader(new InputStreamReader(ss.getInputStream()));
out = new BufferedWriter(new OutputStreamWriter(ss.getOutputStream()));
} catch (UnknownHostException ex) {
Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
} catch (IOException ex) {
Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
}
}
public void sender(String regTag) {
if (ss == null || !ss.isConnected()) {
connection();
}
try {
if (out != null && regTag != null) {
out.write(regTag + "\n");
System.out.println("message::" + regTag);
out.flush();
}
} catch (Exception e) {
e.printStackTrace();
}
}
public String Reciver() {
try {
recv = in.readLine();
if (ss != null && recv != null) {
return recv;
} else {
disconnect();
String Str = "nothing...Sorry";
return Str;
}
} catch (Exception e) {
e.printStackTrace();
return "Exception";
}
}
public void disconnect() {
try {
System.out.println("socket discoonected.");
ss.close();
in.close();
out.close();
connection();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
Main me = new Main();
me.connection();
String hbhb = "`SC`0004HBHBB7BDB7BD";
String login = "`SC`00581.000000CRBTSRVM 00000001DLGLGN 00000002 TXBEG LOGIN:USER=cvbs,PSWD=password DEB2CCA8";
String cut = "`SC`00631.000000CRBT00PPSPHS00000002DLGCON 00000003 TXBEG CUT PPS FEE:MDN=9610023,CUTFEE=1000,REASON=1 BDB7DA88";
me.sender(hbhb.trim());
String str = me.Reciver();
System.out.println("Response :::" + str);
me.sender(login.trim());
String str1 = me.Reciver();
System.out.println("Response hb:::" + str1);
}
它总是在每隔第二条消息上收到null
来自服务器端的日志
[121_SERVER] 2012-05-03 14:26:37:213 [ERROR] [ServerAccptor.java:254] ->
errorCode = [UIP-80015] errorDesc = [Uip server has a exception when receiving data from the client,will remove the client,Server [adapter id=121],.]
at com.ztesoft.zsmart.bss.uip.adapter.socket.server.ServerAccptor.listenMsg(ServerAccptor.java:252)
at com.ztesoft.zsmart.bss.uip.adapter.socket.server.ServerAccptor.run(ServerAccptor.java:117)
Caused by: errorCode = [UIP-9102] errorDesc = [] Describing= [read client message error,will remove client.]
at com.ztesoft.zsmart.bss.uip.adapters.socket.server.mml.MMLServerAdapter.readByteField(MMLServerAdapter.java:784)
at com.ztesoft.zsmart.bss.uip.adapters.socket.server.mml.MMLServerAdapter.reciveWholeMsg(MMLServerAdapter.java:671)
您的代码体现了许多不良做法和谬论。
您正在记录异常,否则将其忽略,并进行一些奇怪的事情,例如让程序继续运行,返回“ Exception”等。这是糟糕的编程。 有例外可以帮助您,不要让创可贴将它们掩盖起来。 该代码在创可贴下不会自愈。 例如,您只需要声明connection()
即可引发IOException
并让调用者对其进行处理。
作为(1)的结果,您有许多ss != null
测试。 您甚至不应该处于需要执行I / O并且ss
可以为null
。 同样,正确的异常处理和传播将避免这种情况。
作为(1)的进一步结果,您有许多!ss.isConnected()
测试,显然是错误地认为此API会告诉您是否断开了连接。 不会的 它只会告诉您是否已连接Socket
。 在您的代码中,当您调用ss = new Socket(...)
,您已经连接了它,否则您尚未执行该代码。 调用isConnected()
不会增加任何值。
您要在输出流之前关闭套接字输入流。 这是不正确的。 您应该只关闭输出流,并在finally块中关闭套接字本身。 这样,输出流将被刷新。 关闭输入流会关闭套接字,而不会刷新输出流。 不要那样做
实际上,正确的答案是MML
响应中没有\\n
。 因此,这永远行不通:
recv = in.readLine();
您必须读取响应的消息头部分中给出的消息长度,并读取到该长度。
更新:
您的MML
命令中存在语法错误。 似乎您正在使用协议的1.00版,因此这是一个有效的示例(查找差异):
`SC`00741.00CRBT PPS 00000001DLGCON 00000004TXBEG PPS CUT FEE:mdn=93784050910,fee=300,id=20140812165011003 F3E0ADDF
您必须仅用数字0
填充多余的空格,否则必须用空格填充。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.