未找到Java IO文件异常

时间:2013-05-14 19:38:19

标签: java android urlconnection

我开发了一个servlet,我试图通过Android应用程序访问它。这是我的异步类的重要部分。 'params [0]'是作为参数传入的URL

URL url;
BufferedReader reader = null;
String s = "";
try {
    url = new URL(params[0]);
    URLConnection con = url.openConnection();
      reader = new BufferedReader(new InputStreamReader(
      con.getInputStream()));
    String line = "";
    while ((line = reader.readLine()) != null) {
        s = s + line;
    }
} catch (MalformedURLException e) {
    e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (Exception e) {
                e.printStackTrace();
            } 

大部分时间都适用。但有时,我得到一个java.io.FileNotFoundException 当我使用相同的网址并在浏览器中尝试它时,它可以工作,但是从我的应用程序来看,无论我尝试多少次,它都无法工作。这是我的logcat:

05-14 19:35:51.852: W/System.err(767): java.io.FileNotFoundException: http://192.168.10.105:8080/CarpoolServer/EditProfileServlet?name=anna&yob=1977&gender=Female&major=Architecture&uni=N/A&occupation=Software Development&hobby1=Basketball&hobby2=Reading&hobby3=Football&email=jad_naoum%40hotmail.com&phone=70202018&from11=Beirut&from12=Beirut&from13=Mousseitbeh&to11=Beirut&to12=Beirut&to13=Mazraa&days1=SAT&time_from1=3:21AM&time_to1=4:21PM&car=true
05-14 19:35:51.852: W/System.err(767):  at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:186)
05-14 19:35:51.852: W/System.err(767):  at com.jad.carpooling.EditProfile$Async.doInBackground(EditProfile.java:416)
05-14 19:35:51.862: W/System.err(767):  at com.jad.carpooling.EditProfile$Async.doInBackground(EditProfile.java:1)
05-14 19:35:51.862: W/System.err(767):  at android.os.AsyncTask$2.call(AsyncTask.java:287)
05-14 19:35:51.862: W/System.err(767):  at java.util.concurrent.FutureTask.run(FutureTask.java:234)
05-14 19:35:51.862: W/System.err(767):  at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
05-14 19:35:51.862: W/System.err(767):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
05-14 19:35:51.872: W/System.err(767):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
05-14 19:35:51.872: W/System.err(767):  at java.lang.Thread.run(Thread.java:856)

有什么想法吗?



我明白了。似乎我没有正确编码URL。 URL中有一个空格。当我编码它时,它工作。 谢谢你的帮助

1 个答案:

答案 0 :(得分:1)

您必须用%20替换所有空格 所以这里是替换空间的代码。

strUrl = strUrl.replace(" ", "%20");