Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/387.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/211.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 为什么我要在httpPost()之后重新启动Wifi_Java_Android_Httpclient - Fatal编程技术网

Java 为什么我要在httpPost()之后重新启动Wifi

Java 为什么我要在httpPost()之后重新启动Wifi,java,android,httpclient,Java,Android,Httpclient,难道你不知道为什么只能调用onClickListener一次,在第二次尝试时,我应该打开和关闭设备上的Wifi连接。第一次点击后,我无法浏览网页和阅读电子邮件-所以互联网连接被阻止 Code: package je.net.ua; import java.io.BufferedReader; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.List; import org.apach

难道你不知道为什么只能调用onClickListener一次,在第二次尝试时,我应该打开和关闭设备上的Wifi连接。第一次点击后,我无法浏览网页和阅读电子邮件-所以互联网连接被阻止

Code:
package je.net.ua;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class App extends Activity {

    Button button;
    TextView tv;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        button = (Button) findViewById(R.id.Button01);
        tv = (TextView) findViewById(R.id.TextView01);
        Log.d("Dev", "Application started");
        button.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                try {
                    BufferedReader in;
                    HttpClient client = new DefaultHttpClient();
                    HttpPost request = new HttpPost("http://www.snee.com/xml/crud/posttest.cgi");

                    List<NameValuePair> postParameters = new ArrayList<NameValuePair>();

                    postParameters.add(new BasicNameValuePair("fname", "First name"));
                    postParameters.add(new BasicNameValuePair("lname", "Last name"));

                    UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(
                            postParameters);

                    request.setEntity(formEntity);

                    HttpResponse response = client.execute(request);

                    in = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));

                    StringBuffer sb = new StringBuffer("");
                    String line = "";
                    String NL = System.getProperty("line.separator");
                    while ((line = in.readLine()) != null) {
                        Log.d("Dev", "Line = " + line);
                        sb.append(line + NL);
                    }
                    in.close();
                    tv.setText(line);
                } catch (Exception ex) {
                }

            }
        });


    }
}
代码:
包je.net.ua;
导入java.io.BufferedReader;
导入java.io.InputStreamReader;
导入java.util.ArrayList;
导入java.util.List;
导入org.apache.http.HttpResponse;
导入org.apache.http.NameValuePair;
导入org.apache.http.client.HttpClient;
导入org.apache.http.client.entity.UrlEncodedFormEntity;
导入org.apache.http.client.methods.HttpPost;
导入org.apache.http.impl.client.DefaultHttpClient;
导入org.apache.http.message.BasicNameValuePair;
导入android.app.Activity;
导入android.os.Bundle;
导入android.util.Log;
导入android.view.view;
导入android.widget.Button;
导入android.widget.TextView;
公共类应用程序扩展活动{
按钮;
文本视图电视;
/**在首次创建活动时调用*/
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
按钮=(按钮)findViewById(R.id.Button01);
tv=(TextView)findViewById(R.id.TextView01);
Log.d(“开发”、“应用程序已启动”);
setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
试一试{
缓冲读取器;
HttpClient=new DefaultHttpClient();
HttpPost请求=新建HttpPost(“http://www.snee.com/xml/crud/posttest.cgi");
List postParameters=new ArrayList();
添加(新的BasicNameValuePair(“fname”、“名字”);
添加(新的BasicNameValuePair(“lname”、“姓氏”);
UrlEncodedFormEntity formEntity=新的UrlEncodedFormEntity(
后参数);
请求。setEntity(formEntity);
HttpResponse response=client.execute(请求);
in=新的BufferedReader(新的InputStreamReader(response.getEntity().getContent());
StringBuffer sb=新的StringBuffer(“”);
字符串行=”;
字符串NL=System.getProperty(“line.separator”);
而((line=in.readLine())!=null){
Log.d(“Dev”,“Line=“+Line”);
sb.追加(行+NL);
}
in.close();
tv.setText(行);
}捕获(例外情况除外){
}
}
});
}
}
调试:

12-27 21:39:16.936: DEBUG/Dev(6568): Line = <html><head><title>posted data</title></head><body><h1>posted data</h1><p>First name: "First+name"</p><p>Last name: "Last+name"</p><p>REQUEST_URI: "/xml/crud/posttest.cgi"</p><p>QUERY_STRING: ""</p><p>CONTENT_LENGTH: "32"</p><p>content passed via STDIN: "fname=First+name&lname=Last+name"</p></body></html>
12-27 21:39:25.566: DEBUG/dalvikvm(85): GC_FOR_MALLOC freed 28784 objects / 1536696 bytes in 109ms
12-27 21:39:34.106: DEBUG/dalvikvm(6072): GC_EXPLICIT freed 1097 objects / 213648 bytes in 67ms
12-27 21:39:42.476: DEBUG/dalvikvm(5056): GC_EXPLICIT freed 1749 objects / 72040 bytes in 53ms
12-27 21:39:47.516: DEBUG/dalvikvm(29993): GC_EXPLICIT freed 1378 objects / 67232 bytes in 91ms
12-27 21:39:50.136: WARN/GTalkService(21165): [GTalkConnection.11] doConnect: caught XMPPError connecting to mtalk.google.com:5228.: (502)
12-27 21:39:50.136: WARN/GTalkService(21165):   -- caused by: java.net.SocketException: The operation timed out
12-27 21:39:16.936:DEBUG/Dev(6568):Line=posteddataposteddata名字:“First+name”

姓氏:“Last+name”

请求URI:“/xml/crud/postest.cgi”

查询字符串:”

内容长度:“32”

通过STDIN传递的内容:“fname=First+name&lname=Last+name”

12-27 21:39:25.566:DEBUG/dalvikvm(85):GC_FOR_MALLOC在109ms内释放了28784个对象/1536696字节 12-27 21:39:34.106:DEBUG/dalvikvm(6072):GC_显式释放1097个对象/213648字节(67毫秒) 12-27 21:39:42.476:DEBUG/dalvikvm(5056):GC_在53ms内显式释放1749个对象/72040字节 12-27 21:39:47.516:DEBUG/dalvikvm(29993):GC_在91毫秒内显式释放了1378个对象/67232字节 12-27 21:39:50.136:WARN/GTalkService(21165):[GTalkConnection.11]doConnect:catch-XMPPError连接到mtalk.google.com:5228:(502) 12-27 21:39:50.136:WARN/GTalkService(21165):--原因:java.net.SocketException:操作超时
您的OnClickListener在等待
http://www.snee.com/xml/crud/posttest.cgi
。关闭WiFi会中断套接字连接,因此此时OnClickListener不再被阻止

如果您将此处理程序的主要部分作为一个组件运行,我认为您会发现您可以多次单击该按钮(并在这样做时向服务器大量发送帖子;-)


更新 回应您的更新,特别是web和电子邮件被阻止:通过
DefaultHttpClient
发送帖子似乎还有其他问题。如果您的目标是Froyo和更高版本,我建议您考虑使用,并确保在连接完成后调用它的方法。或者,如果因为需要支持早期版本而需要坚持使用
DefaultHttpClient
,请在连接完成后尝试调用
client.getConnectionManager().shutdown()
。我不能保证这些步骤会有所帮助,但不管怎样,它们似乎都是值得采取的好步骤


(以下是我的评论:如果在启动程序之前关闭WiFi会发生什么?它是否仍然会阻止您浏览和发送电子邮件?此外,您是否在调用
tv.setText(line)
后看到返回的HTML?最后,我建议将
Log.d
调用放在异常处理程序内部和
readLine()之后)
循环,并查看是否已到达其中任何一个。)

当OnClickListener等待来自
http://www.snee.com/xml/crud/posttest.cgi
。关闭WiFi会中断套接字连接,因此此时OnClickListener不再被阻止

如果您将此处理程序的主要部分作为一个组件运行,我认为您会发现您可以多次单击该按钮(并在这样做时向服务器大量发送帖子;-)


更新 回应您的更新,特别是web和电子邮件被阻止:通过
DefaultHttpClient
发送帖子似乎还有其他问题。我建议您考虑使用,如果您的目标是Froyo和更高版本,请确保