繁体   English   中英

Java套接字与服务器端断开连接

[英]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) 

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

  1. 您正在记录异常,否则将其忽略,并进行一些奇怪的事情,例如让程序继续运行,返回“ Exception”等。这是糟糕的编程。 有例外可以帮助您,不要让创可贴将它们掩盖起来。 该代码在创可贴下不会自愈。 例如,您只需要声明connection()即可引发IOException并让调用者对其进行处理。

  2. 作为(1)的结果,您有许多ss != null测试。 您甚至不应该处于需要执行I / O并且ss可以为null 同样,正确的异常处理和传播将避免这种情况。

  3. 作为(1)的进一步结果,您有许多!ss.isConnected()测试,显然是错误地认为此API会告诉您是否断开了连接。 不会的 它只会告诉您是否已连接Socket 在您的代码中,当您调用ss = new Socket(...) ,您已经连接了它,否则您尚未执行该代码。 调用isConnected()不会增加任何值。

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

实际上,正确的答案是MML响应中没有\\n 因此,这永远行不通:

recv = in.readLine();   

您必须读取响应的消息头部分中给出的消息长度,并读取到该长度。

更新:

  1. 您的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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM