Android Web服务连接被拒绝

时间:2013-02-11 19:33:07

标签: java php android web-services httpwebrequest

我知道我的代码是正确的,因为它只运行一次。我的PHP没有问题,因为当它运行时,它会返回我想要的内容。这里的问题在于请求中。我正在努力获得正确的地址,但到目前为止,我已经尝试了所有可能的地址并且没有成功。我的代码是:

package com.example.testwiththread;

import java.util.ArrayList;
import java.util.List;

import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends Activity {
    JSONParser jsonParser = new JSONParser();
    String pid;
    String name = "";
    String test = "";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.service_details);
        new Thread(new TestThread()).start();
        Toast.makeText(this, "Hi", Toast.LENGTH_SHORT).show();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

    public void clickSend (View view) {

        EditText txtName = (EditText) findViewById(R.id.txtName);
        EditText txtPrice = (EditText) findViewById(R.id.txtTest);

        // display product data in EditText
        txtName.setText(name);
        txtPrice.setText(test);
        Log.e("Checking", name);
        Log.e("Checking", test);
    }

    public class TestThread extends Thread {
        public void run() {
            int success;
            try {
                // Building Parameters
                List<NameValuePair> params = new ArrayList<NameValuePair>();
                params.add(new BasicNameValuePair("pid", pid));

                // getting product details by making HTTP request
                // Note that product details url will use GET request
                JSONObject json = jsonParser.makeHttpRequest(
                        "http://10.0.2.2:8080/webservice.php", "GET", params);

                // check your log for json response
                Log.d("Single Record Details", json.toString());

                // json success tag
                success = json.getInt("success");
                if (success == 1) {
                    // successfully received product details
                    JSONArray productObj = json.getJSONArray("record"); // JSON Array

                    // get first product object from JSON Array
                    JSONObject product = productObj.getJSONObject(1);

                    name = product.getString("name");
                    test = product.getString("test");
                }
            } catch (JSONException e) {
                Log.e("error", e.toString());
            }
        }
    }
}

我的JSON解析器:

package com.example.secondtestsqlserver;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.util.List;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URLEncodedUtils;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONException;
import org.json.JSONObject;

import android.util.Log;

public class JSONParser {

    static InputStream is = null;
    static JSONObject jObj = null;
    static String json = "";

    // constructor
    public JSONParser() {

    }

    // function get json from url
    // by making HTTP POST or GET method
    public JSONObject makeHttpRequest(String url, String method,
            List<NameValuePair> params) {

        // Making HTTP request
        try {

            // check for request method
            if(method == "POST"){
                // request method is POST
                // defaultHttpClient
                DefaultHttpClient httpClient = new DefaultHttpClient();
                HttpPost httpPost = new HttpPost(url);
                httpPost.setEntity(new UrlEncodedFormEntity(params));

                HttpResponse httpResponse = httpClient.execute(httpPost);
                HttpEntity httpEntity = httpResponse.getEntity();
                is = httpEntity.getContent();

            }else if(method == "GET"){
                // request method is GET
                DefaultHttpClient httpClient = new DefaultHttpClient();
                String paramString = URLEncodedUtils.format(params, "utf-8");
                url += "?" + paramString;
                HttpGet httpGet = new HttpGet(url);

                HttpResponse httpResponse = httpClient.execute(httpGet);
                HttpEntity httpEntity = httpResponse.getEntity();
                is = httpEntity.getContent();
            }           

        } catch (UnsupportedEncodingException e) {
            Log.e("Unsupported Encoding", Log.getStackTraceString(e));
        } catch (ClientProtocolException e) {
            Log.e("Client Protocol", Log.getStackTraceString(e));
        } catch (IOException e) {
            Log.e("IO Exception", Log.getStackTraceString(e));
        }

        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }
            is.close();
            json = sb.toString();
        } catch (Exception e) {
            Log.e("Buffer Error", "Error converting result " + e.toString());
            System.out.println(e.toString());
        }

        // try parse the string to a JSON object
        try {
            jObj = new JSONObject(json);
        } catch (JSONException e) {
            Log.e("JSON Parser", "Error parsing data " + e.toString());
            Log.e("JSON Parser", json);
        }

        // return JSON String
        return jObj;

    }
}

如您所见,我使用10.0.2.2:8080作为本地主机地址。我已经尝试了127.0.0.1,localhost以及localhost的Android页面中包含的许多其他选项。他们中的大多数都会返回此错误

02-11 15:18:31.329: E/IO Exception(27504): org.apache.http.conn.HttpHostConnectException: Connection to http://10.0.2.2:8080 refused
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:183)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
02-11 15:18:31.329: E/IO Exception(27504):  at com.example.testwiththread.JSONParser.makeHttpRequest(JSONParser.java:62)
02-11 15:18:31.329: E/IO Exception(27504):  at com.example.testwiththread.MainActivity$TestThread.run(MainActivity.java:63)
02-11 15:18:31.329: E/IO Exception(27504):  at java.lang.Thread.run(Thread.java:856)
02-11 15:18:31.329: E/IO Exception(27504): Caused by: java.net.ConnectException: failed to connect to /10.0.2.2 (port 8080): connect failed: ETIMEDOUT (Connection timed out)
02-11 15:18:31.329: E/IO Exception(27504):  at libcore.io.IoBridge.connect(IoBridge.java:114)
02-11 15:18:31.329: E/IO Exception(27504):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
02-11 15:18:31.329: E/IO Exception(27504):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
02-11 15:18:31.329: E/IO Exception(27504):  at java.net.Socket.connect(Socket.java:842)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
02-11 15:18:31.329: E/IO Exception(27504):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
02-11 15:18:31.329: E/IO Exception(27504):  ... 9 more
02-11 15:18:31.329: E/IO Exception(27504): Caused by: libcore.io.ErrnoException: connect failed: ETIMEDOUT (Connection timed out)
02-11 15:18:31.329: E/IO Exception(27504):  at libcore.io.Posix.connect(Native Method)
02-11 15:18:31.329: E/IO Exception(27504):  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85)
02-11 15:18:31.329: E/IO Exception(27504):  at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
02-11 15:18:31.329: E/IO Exception(27504):  at libcore.io.IoBridge.connect(IoBridge.java:112)
02-11 15:18:31.329: E/IO Exception(27504):  ... 14 more
02-11 15:18:31.329: E/Buffer Error(27504): Error converting result java.lang.NullPointerException: lock == null
02-11 15:18:31.329: E/JSON Parser(27504): Error parsing data org.json.JSONException: End of input at character 0 of 
02-11 15:18:31.329: W/dalvikvm(27504): threadid=11: thread exiting with uncaught exception (group=0x40e46930)
02-11 15:18:31.329: E/AndroidRuntime(27504): FATAL EXCEPTION: Thread-9043
02-11 15:18:31.329: E/AndroidRuntime(27504): java.lang.NullPointerException
02-11 15:18:31.329: E/AndroidRuntime(27504):    at com.example.testwiththread.MainActivity$TestThread.run(MainActivity.java:67)
02-11 15:18:31.329: E/AndroidRuntime(27504):    at java.lang.Thread.run(Thread.java:856)

然而,唯一一个不会返回此错误的是我使用路由器的IP地址时。问题是,即使连接没有被拒绝,也表示禁止访问。任何帮助将不胜感激。

编辑:为了以防万一,我在Manifest中提供了互联网访问。

4 个答案:

答案 0 :(得分:1)

如果您的WAMP服务器不在http://10.0.2.2:8080/webservice.php,则无法使用10.0.2.2。此地址是在与您的网络服务器在同一主机上运行的模拟器中的use ,这意味着如果您在平板电脑上进行测试而不是Android模拟器程序,它将无法为您工作。要解决此问题,请将您的地址更新为:

(A)路由器的公共IP,通过适当的端口转发将端口8080路由到WAMP主机。
(B)您的wifi网络本地IP地址。在典型设置下,这是192.168.1.x但我们无法保证。请注意,当您使用家庭无线网络时,这将允许您的连接仅
工作。

您可以通过Google搜索“我的IP是什么”找到您的公共IP。您可以打开Start->Run->cmd并输入ipconfig来找到您的本地IP。 “IPv4地址”旁边列出的地址应为您提供详细信息。

答案 1 :(得分:1)

我设法解决了在Apache httpd.conf中更改设置的问题。

#   onlineoffline tag - don't remove
    Order Deny,Allow
    Deny from all
    Allow from 127.0.0.1

我把它改成了

#   onlineoffline tag - don't remove
    Order Deny,Allow
    Allow from all
    Allow from 127.0.0.1

现在我的平板电脑可以访问网络服务了。我不知道是否有更好的方法来做到这一点。当然,我应该提到我没有使用10.0.2.2 IP而是使用路由器的IP地址。我还将httpd.conf中的Listen更改为8080.到目前为止,它正在运行。

答案 2 :(得分:1)

我正在使用PHP进行webservice和Android 4.x.用于连接到Web服务的设备。 我有类似的问题,使用10.0.2.2与模拟器很好地工作但无法从设备连接。 对我有用的解决方案是: 找到您的计算机的IP ...说192.168.0.103 找到你的apache的端口...说8080 现在打开httpd.conf并找到以下行 听127.0.0.1:8080 在此行之后添加以下内容 听192.168.0.103:8080 而已。 现在,如果您的Android代码中有192.168.0.103:8080,它将连接!!

答案 3 :(得分:0)

听起来它不是代码,而是配置或缺少正确的地址。 127.x.x.x始终指您所在的计算机。 10.0.2.2是一个不可路由的地址,因此它必须位于您正在使用的网络上。

您提到您的计算机是您正在处理并连接到路由器的计算机。平板电脑通过wifi连接。平板电脑是否连接到同一路由器?从您正在使用的计算机上,您可以转到http://10.0.2.2:8080/...并访问该页面吗?

在另一个回复中(我无法对回复发表评论)你说你已经尝试过使用路由器的地址了。我认为这是出于端口转发的原因。许多路由器不允许从内部端口转发它们是WAN到LAN端口转发,而不是局域网到LAN,所以如果你是内部的并且托管页面的计算机也是内部的,那就太不足为奇了。

话虽如此,您是否可以从您所在的计算机访问该页面。您可以检查您所在计算机的IP(开始 - &gt; cmd-&gt; ipconfig并查找10.0.x.x192.168.x.x)。希望使用该地址对您有用。