java socket从服务器端断开连接

时间:2012-05-07 09:36:52

标签: java sockets

我正面临服务器端套接字问题。我的代码是客户端。每当我发送第二条消息(无论是心跳还是其他任何消息)时,它都会在服务器上失败,服务器端会记录“消息格式错误”,但第一次会收到相同的消息。 这个你能帮我吗。 我的客户代码:

    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) 

2 个答案:

答案 0 :(得分:4)

您的代码体现了许多不良做法和谬误。

  1. 您正在记录异常,否则忽略它们,并做一些奇怪的事情,例如让程序继续,返回“异常”等。这是糟糕的编程。有例外可以帮助你,而不是让绑带用来隐藏血液。该代码不会在绑定下自我修复。例如,您应该声明connection()抛出IOException并让调用者处理它。

  2. 由于(1)您有许多ss != null次测试。您甚至不应该处于需要执行I / O的状态,而ss可能是null。再次正确的异常处理和传播将避免这种情况。

  3. 作为(1)的进一步结果,您进行了大量!ss.isConnected()测试,显然错误地认为此API将告诉您连接是否已被删除。它不会。它只会告诉您是否已连接Socket。在您的代码中,当您调用ss = new Socket(...)时,您已将其连接起来,否则您尚未执行该代码。调用isConnected()不会增加任何价值。

  4. 您正在关闭输出流之前的套接字输入流。这是不正确的。您应该关闭输出流,并在finally块中关闭套接字本身。这样输出流就会被刷新。关闭输入流会关闭套接字和输出流,而不会将其刷新。不要那样做。

答案 1 :(得分:0)

实际上,正确答案是\n响应中没有MML。所以这永远不会奏效:

recv = in.readLine();   

您必须阅读响应的邮件标题部分中给出的邮件长度,并读取该长度。

<强>更新

  1. MML命令中存在语法错误。您似乎正在使用协议版本1.00,因此这是一个有效的示例(寻找差异):

    `SC`00741.00CRBT    PPS     00000001DLGCON    00000004TXBEG     PPS CUT FEE:mdn=93784050910,fee=300,id=20140812165011003    F3E0ADDF
    
  2. 您必须使用0以数字填充多余的空格,在其他地方您必须用空格填充它们。