我正面临服务器端套接字问题。我的代码是客户端。每当我发送第二条消息(无论是心跳还是其他任何消息)时,它都会在服务器上失败,服务器端会记录“消息格式错误”,但第一次会收到相同的消息。 这个你能帮我吗。 我的客户代码:
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);
}
它每隔一秒收到一次空信息
来自服务器端的日志
[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)
答案 0 :(得分:4)
您的代码体现了许多不良做法和谬误。
您正在记录异常,否则忽略它们,并做一些奇怪的事情,例如让程序继续,返回“异常”等。这是糟糕的编程。有例外可以帮助你,而不是让绑带用来隐藏血液。该代码不会在绑定下自我修复。例如,您应该声明connection()
抛出IOException
并让调用者处理它。
由于(1)您有许多ss != null
次测试。您甚至不应该处于需要执行I / O的状态,而ss
可能是null
。再次正确的异常处理和传播将避免这种情况。
作为(1)的进一步结果,您进行了大量!ss.isConnected()
测试,显然错误地认为此API将告诉您连接是否已被删除。它不会。它只会告诉您是否已连接Socket
。在您的代码中,当您调用ss = new Socket(...)
时,您已将其连接起来,否则您尚未执行该代码。调用isConnected()
不会增加任何价值。
您正在关闭输出流之前的套接字输入流。这是不正确的。您应该关闭仅输出流,并在finally块中关闭套接字本身。这样输出流就会被刷新。关闭输入流会关闭套接字和输出流,而不会将其刷新。不要那样做。
答案 1 :(得分:0)
实际上,正确答案是\n
响应中没有MML
。所以这永远不会奏效:
recv = in.readLine();
您必须阅读响应的邮件标题部分中给出的邮件长度,并读取该长度。
<强>更新强>
MML
命令中存在语法错误。您似乎正在使用协议版本1.00,因此这是一个有效的示例(寻找差异):
`SC`00741.00CRBT PPS 00000001DLGCON 00000004TXBEG PPS CUT FEE:mdn=93784050910,fee=300,id=20140812165011003 F3E0ADDF
您必须使用0
以数字填充多余的空格,在其他地方您必须用空格填充它们。