神秘的FileNotFoundException

时间:2013-08-12 13:58:29

标签: java android tomcat servlets

我正在编写一个与运行servlet的Tomcat服务器通信的Android应用程序。我正在对Tomcat服务器进行POST,指定我希望服务器将哪个文件发送回客户端(Android应用程序)。当我尝试通过将POST发送的文件名添加到目录名称来打开此文件时,我得到一个FileNotFoundException。但硬编码完全相同的文件名工作正常。

将从Tomcat服务器控制台抛出FileNotFoundException时获取的文件路径复制粘贴到Windows资源管理器中会打开正确的文件。我还将硬编码文件路径和我将文件名附加到目录路径的文件路径写入日志文件。在此日志文件中,两个文本看起来完全相同,并将两个文本粘贴到Windows资源管理器中打开正确的文件。有没有人知道为什么会产生FileNotFoundException?

从客户端执行帖子

String potentialIP = "http://"+url+":8080/se.myPage/myServlet";
URL url = new URL(potentialIP);
conn = (HttpURLConnection) url.openConnection();
conn.setReadTimeout(10000 /* milliseconds */);
conn.setConnectTimeout(15000 /* milliseconds */);
conn.setRequestMethod("POST");
conn.setDoOutput(true);
conn.setChunkedStreamingMode(0);

// Starts the query
conn.connect();

OutputStream out = new BufferedOutputStream(conn.getOutputStream());
byte[] byteArray = korning.getBytes();
out.write(byteArray);
out.flush();

服务器端的doPost方法看起来像这样

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    InputStream in = request.getInputStream();
    java.util.Scanner s = new java.util.Scanner(in).useDelimiter("\\A");

    String fileName = s.hasNext() ? s.next() : "";
    String filePath = "C:/myCatalog/"+fileName;

    PrintWriter out = response.getWriter();

    PrintWriter writer = new PrintWriter("C:/myCatalog/Servletlog.txt", "UTF-8");
    writer.write("'"+"C:/myCatalog/hardCodedFileName.txt"+"'");
    writer.write("'"+filePath+"'");
    writer.flush();
    writer.close();

    BufferedReader reader = new BufferedReader(new FileReader(filePath));

    String svar = reader.readLine();
    reader.close();     
    out.close();
}

有人知道如何解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

对我来说,事实证明服务器阻止了默认用户代理(可能没什么),并且正在返回403。这会在我的尝试中抛出FileNotFoundException。然后我从另一台服务器更改为示例json:http://date.jsontest.com/ 这将返回一个如下所示的json:

{
   "time": "05:58:38 AM",
   "milliseconds_since_epoch": 1400047118645,
   "date": "05-14-2014"
}

通过切换到另一台服务器,一切都运行良好 - 后来我发现(如上所述)用户代理存在问题 - 将其设置为类似Chrome用户代理的东西,它也应该正常工作。

希望它会对你有所帮助。