我想用AsyncTask类向后端服务器php文件发送HTML请求,但是,发送操作无法完成,某些错误消息出现在logcat中,可能我请问一些建议来解决问题?AsyncTask发送HTML请求失败
下面是我的AsyncTask类:
private class GrabURL extends AsyncTask{
ArrayList nameValuePairs;
//private ProgressDialog Dialog;
public GrabURL() {
nameValuePairs = new ArrayList();
//Dialog = new ProgressDialog(Reader.this);
}
protected void onPreExecute(String key, String value) {
mTest.append("PreExecute");
//Dialog.setMessage("Sending value..");
//Dialog.show();
nameValuePairs.add(new BasicNameValuePair(key,value));
}
@Override
protected Void doInBackground(String... urls) {
// TODO Auto-generated method stub
try{
mTest.append("doinback");
HttpClient client = new DefaultHttpClient();
HttpPost post = new HttpPost(urls[0]);
UrlEncodedFormEntity ent = new UrlEncodedFormEntity(nameValuePairs,HTTP.UTF_8);
post.setEntity(ent);
client.execute(post);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
protected void onPostExecute(Void unused) {
mTest.append("PostExecute");
//Dialog.dismiss();
Toast.makeText(getApplicationContext(), "Value updated", Toast.LENGTH_SHORT).show();
}
}
我通过在外部类调用此启动发送动作
grab.execute(new String[]{"http://192.168.1.150/myapp/check.php"});
如果我隐瞒那些与对话的事情没有错误消息显示,但是,它仍然无法与服务器通信。
这里是错误信息,如果我不把他们藏
07-19 15:11:29.360: E/WindowManager(26555): Activity android.reader.Reader has leaked window [email protected] that was originally added here
07-19 15:11:29.360: E/WindowManager(26555): android.view.WindowLeaked: Activity android.reader.Reader has leaked window [email protected] that was originally added here
07-19 15:11:29.360: E/WindowManager(26555): at android.view.ViewRootImpl.(ViewRootImpl.java:344)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:267)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:215)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:140)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.Window$LocalWindowManager.addView(Window.java:537)
07-19 15:11:29.360: E/WindowManager(26555): at android.app.Dialog.show(Dialog.java:278)
07-19 15:11:29.360: E/WindowManager(26555): at android.reader.Reader$GrabURL.onPreExecute(Reader.java:228)
07-19 15:11:29.360: E/WindowManager(26555): at android.reader.Reader$1.onClick(Reader.java:102)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.View.performClick(View.java:3511)
07-19 15:11:29.360: E/WindowManager(26555): at android.view.View$PerformClick.run(View.java:14105)
07-19 15:11:29.360: E/WindowManager(26555): at android.os.Handler.handleCallback(Handler.java:605)
07-19 15:11:29.360: E/WindowManager(26555): at android.os.Handler.dispatchMessage(Handler.java:92)
07-19 15:11:29.360: E/WindowManager(26555): at android.os.Looper.loop(Looper.java:137)
07-19 15:11:29.360: E/WindowManager(26555): at android.app.ActivityThread.main(ActivityThread.java:4424)
07-19 15:11:29.360: E/WindowManager(26555): at java.lang.reflect.Method.invokeNative(Native Method)
07-19 15:11:29.360: E/WindowManager(26555): at java.lang.reflect.Method.invoke(Method.java:511)
07-19 15:11:29.360: E/WindowManager(26555): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
07-19 15:11:29.360: E/WindowManager(26555): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
07-19 15:11:29.360: E/WindowManager(26555): at dalvik.system.NativeStart.main(Native Method)
下面是我的服务器端程序的代码,只是一个简单的PHP文件。
$file = "C:/wamp/www/myapp/file.txt";
$data = "AID:".$_POST['A']." BID:".$_POST['B'];
file_put_contents($file, $data);
?>
2012-07-19
Conrad
+0
“窗口导致的错误”的原因。你的对话不会被“解雇”。你在'onPostExecute'中执行。但是你的代码永远不会进入'onPostExecute'。在你的'doInBackground'中有一个错误。我认为你需要添加断点。出现问题的地方。 –
2012-07-19 04:35:54
+0
对不起,我刚吃过午饭,请问我该如何添加一个断点? –
2012-07-19 06:05:04
+0
基于你说的,我试图隐藏所有的对话相关的东西,那些颜色红色的错误消息消失,然而,我的后端服务器仍然没有回应它,也有一些橙色的错误消息。 –
2012-07-19 06:36:15