我知道我的代码是正确的,因为它只运行一次。我的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中提供了互联网访问。
答案 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.x
或192.168.x.x
)。希望使用该地址对您有用。