我正在编写我的第一个Android应用程序,并尝试从应用程序内部进行REST调用。在几页和其他SO帖子之后,我有了这个:
URL serverUrl = new URL("http://localhost:13980/api/maps/"); //the value is hardcoded for testing purposes
public String getMapsJson()
{
Log.d("Minimap", ">> getting maps json from " + serverUrl.toString());
String output = "";
HttpURLConnection connection = null;
try
{
connection = (HttpURLConnection) serverUrl.openConnection();
connection.setRequestMethod("GET");
Log.d("Minimap", "connection opened!");
InputStream in = new BufferedInputStream(connection.getInputStream());
Log.d("Minimap", "input stream captured");
output = readStream(in);
Log.d("Minimap", "stream read");
}
catch (Exception e)
{
Log.d("Minimap", e.getMessage()); //************* This is line 53 <<<<<<
}
finally
{
connection.disconnect();
}
Log.d("Minimap", "JSON: " + output);
return output;
}
private String readStream(InputStream in)
{
try
{
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String line = reader.readLine();
String output = line;
while((line = reader.readLine()) != null)
output += line;
return output;
}
catch (IOException e)
{
e.printStackTrace();
return "";
}
}
我从logcat获得的输出只是
11-19 07:38:31.599 3813-3813/com.northstar.minimap D/Minimap﹕ >> getting maps json from http://localhost:13980/api/maps/
11-19 07:38:31.599 3813-3813/com.northstar.minimap D/Minimap﹕ connection opened!
然后应用程序崩溃并显示以下堆栈跟踪:
11-19 08:02:50.903 744-744/com.northstar.minimap E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.northstar.minimap/com.northstar.minimap.MapActivity}: java.lang.NullPointerException: println needs a message
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException: println needs a message
at android.util.Log.println_native(Native Method)
at android.util.Log.d(Log.java:138)
at com.northstar.minimap.Communicator.getMapsJson(Communicator.java:53)
at com.northstar.minimap.MapActivity.onCreate(MapActivity.java:36)
at android.app.Activity.performCreate(Activity.java:5104)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
11-19 08:02:50.933 308-445/system_process W/ActivityManager﹕ Force finishing activity com.northstar.minimap/.MapActivity
11-19 08:02:50.943 308-445/system_process W/ActivityManager﹕ Force finishing activity com.northstar.minimap/.MainActivity
它查询的页面(http://localhost:13980/api/maps/
)是一个简单的GET端点,它会回吐一些JSON。在这一点上,如果它拉出的JSON打印到LogCat,我会很高兴。
谢谢!
答案 0 :(得分:2)
你可能错误localhost
,服务器没有在Android设备或模拟器上运行。
您应该使用10.0.2.2访问运行模拟器的计算机,请参阅http://developer.android.com/tools/devices/emulator.html
或网络服务器的IP。 (确保它首先可以访问外部世界)
<@>如@Jason C所述,你的错误处理非常糟糕。你永远不应该抓住所有例外。一种非常标准的方法是让你的方法抛出IOException,因此调用getMapsJson
的代码可以处理这个特殊的常见异常(例如,没有连接)。
如果要处理HTTP错误和错误代码,则应在打开InputStream
之前检查结果代码。如果出现错误,如果您需要除已知结果代码之外的实际响应,还可以获得ErrorStream
而不是InputStream
。
答案 1 :(得分:0)
你的应用程序(可能)抛出异常的原因在Gal Ben-haim的回答中给出。但是,您的应用崩溃的原因是因为您没有正确处理异常本身。
关于异常的一个棘手问题是getMessage()
方法可以返回null
。 Log.d()
不喜欢null
参数,因此会从您的异常处理程序中抛出另一个异常,该异常处理程序未被捕获,并且您的应用程序崩溃并烧毁。此外,您的原始异常不再是堆栈跟踪的一部分(因为它不是崩溃的直接原因),并且吞下了有关它的信息。
您应该检查e.getMessage()
是否为null
,如果是,请将非空的内容传递给Log.d
(例如,可能是空字符串)。
请参阅NullPointerException : println needs a message in android