-1

Androidアプリを使用してサーバーにデータを送信するために使用されると思われる次のコードがありますが、「残念ながらアプリ名が停止されました」というエラー状態が発生し続けます

私の活動コードは:

public class SendDataToServerActivity extends Activity {
    /** Called when the activity is first created. */
    Button sendButton;
    EditText msgTextField;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        // make message text field object
        msgTextField = (EditText) findViewById(R.id.msgTextField);
        // make send button object
        sendButton = (Button) findViewById(R.id.sendButton);
        sendButton.setOnClickListener(new Button.OnClickListener(){
            //perform your action here            
            public void onClick(View v){
                String msg = msgTextField.getText().toString();  

                // make sure the fields are not empty
                if (msg.length()>0)
                {
                    HttpClient httpclient = new DefaultHttpClient();
                    HttpPost httppost = new HttpPost("http://98.131.137.4/husam.php");
                 try {
                   List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(1);
                   nameValuePairs.add(new BasicNameValuePair("id", "12345"));
                   nameValuePairs.add(new BasicNameValuePair("message", msg));
                   httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
                   httpclient.execute(httppost);
                   msgTextField.setText("");
                 } catch (ClientProtocolException e) {
                     // TODO Auto-generated catch block
                 } catch (IOException e) {
                     // TODO Auto-generated catch block
                 }
                }
                else
                {
                    // display message if text fields are empty
                    Toast.makeText(getBaseContext(),"All field are   required",Toast.LENGTH_SHORT).show();
                }
            }
        });
    }
}

私のログは次のとおりです。

04-19 01:17:02.168: E/AndroidRuntime(583): FATAL EXCEPTION: main
04-19 01:17:02.168: E/AndroidRuntime(583): android.os.NetworkOnMainThreadException
04-19 01:17:02.168: E/AndroidRuntime(583):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
04-19 01:17:02.168: E/AndroidRuntime(583):  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
04-19 01:17:02.168: E/AndroidRuntime(583):  at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
04-19 01:17:02.168: E/AndroidRuntime(583):  at libcore.io.IoBridge.connect(IoBridge.java:112)
04-19 01:17:02.168: E/AndroidRuntime(583):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
04-19 01:17:02.168: E/AndroidRuntime(583):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
04-19 01:17:02.168: E/AndroidRuntime(583):  at java.net.Socket.connect(Socket.java:842)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
04-19 01:17:02.168: E/AndroidRuntime(583):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
04-19 01:17:02.168: E/AndroidRuntime(583):  at com.husamalahmadi.send.SendDataToServerActivity$1.onClick(SendDataToServerActivity.java:55)
04-19 01:17:02.168: E/AndroidRuntime(583):  at android.view.View.performClick(View.java:3511)
04-19 01:17:02.168: E/AndroidRuntime(583):  at android.view.View$PerformClick.run(View.java:14105)
04-19 01:17:02.168: E/AndroidRuntime(583):  at android.os.Handler.handleCallback(Handler.java:605)

アプリをデバッグするとエラーや警告がないという事実を知っているので、ここで何が間違っているのかを教えてくれる人はいますか

よろしく

4

1 に答える 1

0

上に投稿した私の質問によると、私は問題を見つけてその根本から解決しましたが、それは私の質問にコメントしたブランデルからの助けなしには起こりえませんでした。ここに問題と答えがあります。

以前のコードの問題は、メインの UI スレッドで 5 ~ 10 秒間続くコードを実行していましたが、Android の初期の realse では問題ありませんでしたが、Android の最新の realse ではそうではありません。そのため、次のコードをメイン アクティビティに追加しました。

StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()  
                    .detectDiskReads()  
                    .detectDiskWrites()  
                    .detectNetwork()   
                                    .problems  
                    .penaltyLog()  
                    .build());  
        StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()  
                    .detectLeakedSqlLiteObjects()  
                    .detectLeakedClosableObjects()  
                    .penaltyLog()  
                    .penaltyDeath()  
                    .build());  

このコードは開発フェーズでのみ実装することをお勧めしますが、実稼働コードについては、ワーカー スレッドである別のスレッドを使用して、ファイル処理やネットワーク処理、またはその他の負荷の高い処理コードを実行し、メイン UI スレッドに更新を提供することをお勧めします。Android スレッド、ハンドラー、AsyncTask - チュートリアルを確認できる、優れた開始チュートリアルです。

于 2012-04-19T08:41:11.520 に答える