java - 使用 HTTPUrlConnection 的 RESTful 请求

标签 java android json rest

我正在编写我的第一个 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,我会很高兴。

谢谢!

最佳答案

您的 localhost 可能有误,服务器未在 Android 设备或模拟器本身上运行。

您应该使用 10.0.2.2 访问运行模拟器的计算机,请参阅 http://developer.android.com/tools/devices/emulator.html

或者网络服务器的IP。 (首先确保其可以被外界访问)

正如 @Jason C 所说,你的错误处理非常糟糕。你不应该捕获所有异常。

一个相当标准的方法是让您的方法抛出 IOException,因此调用 getMapsJson 的代码可以处理这个特定且常见的异常(例如,无连接)。

如果您想处理 HTTP 错误和错误代码,您应该在打开 InputStream 之前检查结果代码。如果发生错误,如果除了已知结果代码之外您还需要实际响应,您还可以获得 ErrorStream 而不是 InputStream

关于java - 使用 HTTPUrlConnection 的 RESTful 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20065975/

相关文章:

java - 错误 :Error converting bytecode to dex: Cause: not found: Ljava/lang/Object;

javascript - 如何使用 jQuery ajax 数据变量

java - 最快的同步技术

java - 无法在 Eclipse 中找到 svn 选项?

java - Android 应用内结算 - 如何多次购买单个应用内购买?

java - Gson在json中存储对象类型

json - 如何将 postgresql json 类型转换为 golang native?

Android HttpResponse 错误

java - ReactNative - SSLException 构建电影示例

java - 可观察内的 RxJava 过滤器列表