簡體   English   中英

Android應用程序連接到REST服務-拒絕連接

[英]Android App connecting to REST Service - Connection Refused

我正在開發一個涉及調用RESTful API的Android應用。 我有使用Python編寫的REST服務,該筆記本計算機在端口8080上的筆記本電腦( 192.168.156.1 )上運行。我通過Connectify Wifi連接將手機綁定到筆記本電腦。 電話位於192.168.156.112 現在,我可以通過手機的瀏覽器使用諸如http://192.168.156.1:8080/lighting/12345的URL來訪問該服務。 但是,當我嘗試從應用程序訪問它時,在LogCat中收到“連接被拒絕”錯誤。 以下是我用來建立連接的代碼。

    String sampleURL = "`http://192.168.156.1:8080/lighting/weert`";
        HttpClient Client = new DefaultHttpClient();
         try
         {
             HttpGet httpget = new HttpGet(sampleURL);
             String serverString = "";
             HttpResponse response= Client.execute(httpget);
             StatusLine statusLine = response.getStatusLine();
             if (statusLine.getStatusCode() == HttpStatus.SC_OK) {
                 ByteArrayOutputStream out = new ByteArrayOutputStream();
                 response.getEntity().writeTo(out);
                 out.close();
                 serverString = out.toString();
             } 
             threadMsg(SetServerString);
          }
        catch(Exception ex){
            Log.e("RESTCALL",ex.getMessage());  
            threadMsg("Fail!");
         }

threadMsg()是將響應字符串傳遞回UI線程的方法。

解決這個問題的任何幫助都將非常有用! 提前致謝!

更新:添加堆棧跟蹤

    I/ActivityManager(  246): START {act=android.intent.action.MAIN cat=   [android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.example.testreceiver/.MainActivity u=0} from pid 464
    I/ActivityManager(  246): Displayed com.example.testreceiver/.MainActivity: +315ms
    W/System.err(15799): org.apache.http.conn.HttpHostConnectException: Connection to http://192.168.156.1:8080 refused
    D/AudioHardware(   89): AudioHardware pcm playback is going to standby.
    D/AudioHardware(   89): closePcmOut_l() mPcmOpenCnt: 1
    W/System.err(15799):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:183)
    W/System.err(15799):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
    W/System.err(15799):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
    W/System.err(15799):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
    W/System.err(15799):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
    W/System.err(15799):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
    W/System.err(15799):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
    W/System.err(15799):    at com.example.testreceiver.MainActivity$1.run(MainActivity.java:47)
    W/System.err(15799):    at java.lang.Thread.run(Thread.java:856) 
    W/System.err(15799): Caused by: java.net.ConnectException: failed to connect to /192.168.156.1 (port 8080): connect failed: EHOSTUNREACH (No route to host)
    W/System.err(15799):    at libcore.io.IoBridge.connect(IoBridge.java:114)
    W/System.err(15799):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
    W/System.err(15799):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
    W/System.err(15799):    at java.net.Socket.connect(Socket.java:842)
    W/System.err(15799):    at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
    W/System.err(15799):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
    W/System.err(15799):    ... 8 more
    W/System.err(15799): Caused by: libcore.io.ErrnoException: connect failed: EHOSTUNREACH (No route to host)
    W/System.err(15799):    at libcore.io.Posix.connect(Native Method)
    W/System.err(15799):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85)
    W/System.err(15799):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
    W/System.err(15799):    at libcore.io.IoBridge.connect(IoBridge.java:112)
    W/System.err(15799):    ... 13 more
    E/RESTCALL(15799): Connection to `http://192.168.156.1:8080` refused

另外,這是服務器上運行的代碼。

    import socket
    from bottle import route, run@route('/lighting/<name>', method='GET')

    def hello(name="ABC"):
    return name

    run(host='192.168.156.1', port=8080, debug=True)

問題解決了! 我停止使用connectify熱點,並切換到路由器,現在我的手機和筆記本電腦已連接到該路由器。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM