服务器没有从java tcp / ip客户端接收数据

时间:2012-02-13 16:17:38

标签: java sockets tcp client

我正在编写一个java客户端来连接远程服务器并将纯文本推送到它。我不知道服务器是什么语言,我被告知只需连接到某个端口上的IP地址然后推送数据。

我连接得很好(显然),在我看来,似乎数据被正常发送。但是,在服务器端,他们只看到我连接/断开连接,没有收到任何数据。

我是Java中的TCP / IP和套接字的新手,我想知道我是不是在做我不想做的事情。

基本上,我的Java客户端查找某个目录中的所有.txt文件,从这些文件中获取文本,然后将该文本推送到输出流中。刷新文件的数据后,它会将文件移动到“已发送”目录,然后继续下一个文件(如果有)。

这是我的Java代码:

import java.net.*;
import java.io.*;

public class Client
{

public class MyFileFilter implements FilenameFilter {
    public boolean accept(File dir, String name) {
        return name.toLowerCase().endsWith(".txt");
    }
}

public Client()
{
    try {

        String dirName = "/var/lib/adt/";
        String sentDir = "/var/lib/adt/sent/";

        File directory = new File(dirName);
        if (!directory.exists()) {
            System.out.println("directory does not exist!  Location: " + dirName);
            return;
        }

        // get files in directory
        File[] listOfFiles = directory.listFiles(new MyFileFilter());

        if (listOfFiles == null || listOfFiles.length == 0) {
            System.out.println("No files to send.");
            return;
        }

        FileInputStream fin;
        DataInputStream dis;

        String sendAddr = "192.168.1.9";
        int sendPort = 9486;

        Socket client = new Socket(sendAddr, sendPort);
        //getting the o/p stream of that connection
        PrintStream out = new PrintStream(client.getOutputStream());
        //reading the response using input stream
        BufferedReader in= new BufferedReader(new InputStreamReader(client.getInputStream()));

        System.out.println("Sending file(s) to '" + sendAddr + ":" + sendPort + "'");

        for (int i = 0; i < listOfFiles.length; i++)  {
            if (listOfFiles[i].isFile())  {
                String fName = listOfFiles[i].getName();
                if (fName.endsWith(".txt") || fName.endsWith(".TXT")) {
                    fin = new FileInputStream (dirName + fName);
                    dis = new DataInputStream(fin);

                    String message = "";
                    String messagePart = "";
                    while ((messagePart = dis.readLine()) != null)
                        message += messagePart + "\n";

                    if (message.equals(""))
                        continue;

                    System.out.println("Sending file '" + fName + "' with message: " + message);

                    out.print(message);
                    System.out.println("Written!");
                    out.flush();
                    System.out.println("Flushed!");

                    // move file to 'sent' directory
                    File dir = new File(sentDir);

                    boolean success = listOfFiles[i].renameTo(new File(dir, fName));
                    if (!success) {
                        // File was not successfully moved
                        System.out.println("File not successfully moved to 'sent' directory.");
                    }

                    dis.close();
                    fin.close();
                }
            }
        }

        in.close();
        out.close();

        client.shutdownOutput();
        if (!client.isClosed())
            client.close();

        System.out.println("Successfully sent all file(s)!");
    } catch (Exception e) {
        System.out.println("ERROR while sending file: " + e.toString());
        e.printStackTrace();
    }

}

public static void main(String a[])
{
    new Client();
}

}

对于我的控制台输出,我得到了这个:

jarrett@jarrett-Latitude-D520:~/Downloads$ java Client 
Sending file(s) to '192.168.1.9:9486'
Sending file 'blah.txt' with message: asdpoifjawpeoifjawpeoifjwapoeifjapwoie

Written!
Flushed!
Successfully sent all file(s)!

据我所知,一切都很好。有谁知道为什么会发生这种情况?在我的结尾有什么我显然做错了吗?

我感谢任何反馈!

干杯

Jarrett的

编辑:另外,我还写了一个'服务器'java文件在本地进行测试,并设法连接到它并成功从我的客户端程序发送数据。

1 个答案:

答案 0 :(得分:1)

Jarrett,你的代码发送*东西;它看起来不错,你正确地刷新流,以避免它备份缓冲区并在关闭时丢失。

如果您想确保发送内容,请安装Wireshark,然后进行连接,然后在发送数据时嗅探它。您应该看到要发送的出站流量。

如果您看到它,那么您可以让客户知道他们的服务没有正确接收数据。我的猜测是,使用他们的端点的要求比他们传达给你的要多(例如标题,编码,格式等),并且在他们的结尾可能有一个解析错误导致处理你的数据,所以他们只是假设你从不发送任何东西,因为他们没有看到存储在数据库中的处理结果或类似的东西。

只是一个猜测。