[英]App working fine on emulator but not working on android device
我正在开发一个简单的客户端服务器登录应用程序。 该应用程序在模拟器上运行良好,但是当我从手机运行该应用程序时,它无法正常工作。 我还添加了权限<uses-permission android:name="android.permission.INTERNET"/>
我正在通过wifi连接我的android手机,还通过对服务器执行ping操作来测试与终端仿真器应用的连接。
URL = "http://192.168.1.2:8084/AndroidServlet/AndroidServlet?name="+name+"&pass="+pass;
我用来连接服务器和192.168.1.2的URL是我机器的IP地址。
public class SimServletActivity extends Activity implements OnClickListener{
Button button;
String name,pass;
EditText us_id,us_password;
public String URL = "http://192.168.1.1:8084/AndroidServlet/AndroidServlet?name="+name+"&pass="+pass;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
findViewsById();
button.setOnClickListener(this);
}
private void findViewsById() {
button = (Button) findViewById(R.id.btnLogin);
us_id=(EditText) findViewById(R.id.loginid);
us_password=(EditText) findViewById(R.id.password);
}
public void getDetails(){
name=us_id.getText().toString();
pass=us_password.getText().toString();
URL = "http://192.168.1.1:8084/AndroidServlet/AndroidServlet?name="+name+"&pass="+pass;
}
public void onClick(View view) {
getDetails();
GetXMLTask task = new GetXMLTask();
task.execute(new String[] { URL });
}
private class GetXMLTask extends AsyncTask<String, Void, String> {
@Override
protected String doInBackground(String... urls) {
String output = null;
for (String url : urls) {
output = getOutputFromUrl(url);
}
return output;
}
private String getOutputFromUrl(String url) {
String output = null;
try {
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(url);
HttpResponse httpResponse = httpClient.execute(httpGet);
HttpEntity httpEntity = httpResponse.getEntity();
output = EntityUtils.toString(httpEntity);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return output;
}
@Override
protected void onPostExecute(String output) {
if(output.equals("true"))
{
Intent i=new Intent(SimServletActivity.this, NextActivity.class);
startActivity(i);
}
else{
Toast.makeText(SimServletActivity.this, "Enter correct Details",Toast.LENGTH_LONG).show();
}
}
}
}
任何帮助表示赞赏。 提前致谢。
LogCat详细信息是E/AndroidRuntime(26414): FATAL EXCEPTION: main E/AndroidRuntime(26414): java.lang.NullPointerException E/AndroidRuntime(26414): at com.eg.simpleservlet.SimServletActivity$GetXMLTask.onPostExecute(SimServletActivity.java:88) E/AndroidRuntime(26414): at com.eg.simpleservlet.SimServletActivity$GetXMLTask.onPostExecute(SimServletActivity.java:1) E/AndroidRuntime(26414): at android.os.AsyncTask.finish(AsyncTask.java:417) E/AndroidRuntime(26414): at android.os.AsyncTask.access$300(AsyncTask.java:127) E/AndroidRuntime(26414): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429) E/AndroidRuntime(26414): at android.os.Handler.dispatchMessage(Handler.java:99) E/AndroidRuntime(26414): at android.os.Looper.loop(Looper.java:130) E/AndroidRuntime(26414): at android.app.ActivityThread.main(ActivityThread.java:3687) E/AndroidRuntime(26414): at java.lang.reflect.Method.invokeNative(Native Method) E/AndroidRuntime(26414): at java.lang.reflect.Method.invoke(Method.java:507) E/AndroidRuntime(26414): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) E/AndroidRuntime(26414): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625) E/AndroidRuntime(26414): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(26414): FATAL EXCEPTION: main E/AndroidRuntime(26414): java.lang.NullPointerException E/AndroidRuntime(26414): at com.eg.simpleservlet.SimServletActivity$GetXMLTask.onPostExecute(SimServletActivity.java:88) E/AndroidRuntime(26414): at com.eg.simpleservlet.SimServletActivity$GetXMLTask.onPostExecute(SimServletActivity.java:1) E/AndroidRuntime(26414): at android.os.AsyncTask.finish(AsyncTask.java:417) E/AndroidRuntime(26414): at android.os.AsyncTask.access$300(AsyncTask.java:127) E/AndroidRuntime(26414): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429) E/AndroidRuntime(26414): at android.os.Handler.dispatchMessage(Handler.java:99) E/AndroidRuntime(26414): at android.os.Looper.loop(Looper.java:130) E/AndroidRuntime(26414): at android.app.ActivityThread.main(ActivityThread.java:3687) E/AndroidRuntime(26414): at java.lang.reflect.Method.invokeNative(Native Method) E/AndroidRuntime(26414): at java.lang.reflect.Method.invoke(Method.java:507) E/AndroidRuntime(26414): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) E/AndroidRuntime(26414): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625) E/AndroidRuntime(26414): at dalvik.system.NativeStart.main(Native Method)
如果您的网站返回的是空字符串,
if(output.equals("true"))
会像您描述的那样失败。 你可以用
if ((output!=null) && output.equals("true"))
代替。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.