Android 客户端未连接到 REST 服务器

Android client not connecting to REST server

我有一个 Spring Restful 服务器功能正常。它接受来自任何浏览器和我用来测试它的 Java 客户端的请求。

问题是当我尝试用 Android 连接它时,无论是在模拟器上还是在智能手机上。

我的 Java 客户端中有这个简单的代码来测试服务器:

public void requestServer() throws IOException {
    String url = "http://localhost:8080/checkPoints?username=john";

    URL obj = new URL(url);
    HttpURLConnection con = (HttpURLConnection) obj.openConnection();

    // optional default is GET
    con.setRequestMethod("GET");

    int responseCode = con.getResponseCode();
    System.out.println("\nSending 'GET' request to URL : " + url);
    System.out.println("Response Code : " + responseCode);

    BufferedReader in = new BufferedReader(
            new InputStreamReader(con.getInputStream()));
    String inputLine;
    StringBuffer response = new StringBuffer();

    while ((inputLine = in.readLine()) != null) {
        response.append(inputLine);
    }
    in.close();

    //print result
    System.out.println(response.toString());
}

效果很好。如果我调试它,我会看到 con 的 HTTP 响应代码为 200,并且页面的响应正是 john 拥有的点数。

但如果我在 Android 上尝试使用相同的代码在单击按钮时激活:

public void requestServer(View view) throws IOException {
    String url = "http://10.0.2.2:8080/checkPoints?username=joao";

    URL obj = new URL(url);
    HttpURLConnection con = (HttpURLConnection) obj.openConnection();

    // optional default is GET
    con.setRequestMethod("GET");

    int responseCode = con.getResponseCode();
    System.out.println("\nSending 'GET' request to URL : " + url);
    System.out.println("Response Code : " + responseCode);

    BufferedReader in = new BufferedReader(
            new InputStreamReader(con.getInputStream()));
    String inputLine;
    StringBuffer response = new StringBuffer();

    while ((inputLine = in.readLine()) != null) {
        response.append(inputLine);
    }
    in.close();

    //print result
    System.out.println(response.toString());
}

总是在这一行出现:

HttpURLConnection con = (HttpURLConnection) obj.openConnection();

如果我调试它,我看到 HTTP 响应代码是 -1,而不是 200。 我已经尝试了我的内部网络 IP(在我的例子中是 192.168.1.79),但它不起作用。我在 Whosebug 中搜索了很多线程,并尝试了很多用户拥有的代码,在所有这些代码片段中,它总是以相同的代码出现,即 obj.openConnection()。

我在清单中有互联网权限,不会是因为那个。

会是什么?

编辑:这里是 stackTrace

5-02 19:19:38.109 2769-2769/pt.androidrestfulclient E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                        Process: pt.androidrestfulclient, PID: 2769
                                                                                        java.lang.IllegalStateException: Could not execute method for android:onClick
                                                                                            at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:289)
                                                                                            at android.view.View.performClick(View.java:4780)
                                                                                            at android.view.View$PerformClick.run(View.java:19866)
                                                                                            at android.os.Handler.handleCallback(Handler.java:739)
                                                                                            at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                                            at android.os.Looper.loop(Looper.java:135)
                                                                                            at android.app.ActivityThread.main(ActivityThread.java:5254)
                                                                                            at java.lang.reflect.Method.invoke(Native Method)
                                                                                            at java.lang.reflect.Method.invoke(Method.java:372)
                                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
                                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
                                                                                         Caused by: java.lang.reflect.InvocationTargetException
                                                                                            at java.lang.reflect.Method.invoke(Native Method)
                                                                                            at java.lang.reflect.Method.invoke(Method.java:372)
                                                                                            at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:284)
                                                                                            at android.view.View.performClick(View.java:4780) 
                                                                                            at android.view.View$PerformClick.run(View.java:19866) 
                                                                                            at android.os.Handler.handleCallback(Handler.java:739) 
                                                                                            at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                                            at android.os.Looper.loop(Looper.java:135) 
                                                                                            at android.app.ActivityThread.main(ActivityThread.java:5254) 
                                                                                            at java.lang.reflect.Method.invoke(Native Method) 
                                                                                            at java.lang.reflect.Method.invoke(Method.java:372) 
                                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
                                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
                                                                                         Caused by: android.os.NetworkOnMainThreadException
                                                                                            at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147)
                                                                                            at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:110)
                                                                                            at libcore.io.IoBridge.connectErrno(IoBridge.java:137)
                                                                                            at libcore.io.IoBridge.connect(IoBridge.java:122)
                                                                                            at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
                                                                                            at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:456)
                                                                                            at java.net.Socket.connect(Socket.java:882)
                                                                                            at com.android.okhttp.internal.Platform.connectSocket(Platform.java:174)
                                                                                            at com.android.okhttp.Connection.connect(Connection.java:152)
                                                                                            at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:276)
                                                                                            at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:211)
                                                                                            at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:382)
                                                                                            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:332)
                                                                                            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:500)
                                                                                            at pt.ulisboa.tecnico.cmov.androidrestfulclient.MainActivity.requestServer(MainActivity.java:50)
                                                                                            at java.lang.reflect.Method.invoke(Native Method) 
                                                                                            at java.lang.reflect.Method.invoke(Method.java:372) 
                                                                                            at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:284) 
                                                                                            at android.view.View.performClick(View.java:4780) 
                                                                                            at android.view.View$PerformClick.run(View.java:19866) 
                                                                                            at android.os.Handler.handleCallback(Handler.java:739) 
                                                                                            at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                                            at android.os.Looper.loop(Looper.java:135) 
                                                                                            at android.app.ActivityThread.main(ActivityThread.java:5254) 
                                                                                            at java.lang.reflect.Method.invoke(Native Method) 
                                                                                            at java.lang.reflect.Method.invoke(Method.java:372) 
                                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
                                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 

尝试使用 Asynctask 包装 requestServer()。在doInBackground()

中执行这个方法