1

Web サービスを使用してデータベースからデータを取得するために、次のコードを実行しようとしています。

  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    getData();
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}


public void getData(){
    TextView resultView = (TextView) findViewById(R.id.textView1);
    String result = "";
    InputStream isr = null;
    try{
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("http://HOSTNAME/FILENAME.php");
        HttpResponse response = httpclient.execute(httppost);
        HttpEntity entity = response.getEntity();
        isr = entity.getContent();
    }
    catch(Exception e){
        Log.e("log_tag","Error in http connection"+e.toString());
        resultView.setText("Couldnt connect to database");
    }
    //converting to string
    try{
        BufferedReader reader = new BufferedReader(new InputStreamReader(isr,"iso-8859-1"),8);
        StringBuilder sb = new StringBuilder();
        String line = null;
        while ((line = reader.readLine()) != null){
            sb.append(line + "\n");
        }
        isr.close();
        result = sb.toString();
    }
    catch(Exception e){
        Log.e("log_tag", "Error converting result"+ e.toString());
    }

    //parse data
    try{
        String s = "";
        JSONArray jArray = new JSONArray(result);
        for(int i = 0;i<jArray.length();i++){
            JSONObject json = jArray.getJSONObject(i);
            s = s + "St.ID" + json.getString("StId") + "\n " +json.getString("StName") + "\n" + json.getString("StMail");

        }
        resultView.setText(s);
    }
    catch(Exception e){
        Log.e("Log_tage", "Error Parsing Data"+e.toString());
    }
}

しかし、エラーが返されます: データベースに接続できませんでした。

出力 LogCat は次のとおりです。

11-14 20:10:35.057: E/log_tag(5323): http 接続のエラーandroid.os.NetworkOnMainThreadException

11-14 20:10:35.057: E/log_tag(5323): resultjava.lang.NullPointerException の変換中にエラーが発生しました: ロック == null

11-14 20:10:35.057: E/Log_tage(5323): Dataorg.json.JSONException 解析エラー: 文字 0 で入力の終わり

一部のWebサービスにphpファイルを追加しましたが、うまく機能していますが、HttpPost URLに関するものだと思います.HttpPost URLに特定の形式がありますか、それともWebサービスで指定されたのと同じURLですか?

PHP ファイル:

   <?php 
$con = mysql_connect("HOST","USERNAME","PASSWORD");
if (!$con)
    {
    die('Could not Connect:'. mysql_error());
    }
mysql_select_db("database_name",$con);

$result = mysql_query("SELECT * FROM table_name");

while($row = mysql_fetch_assoc($result))
    {
       $output[]=$row;
    }

print(json_encode($output));
mysql_close($con);
?>

それを手伝ってください。

4

2 に答える 2

1

HttpPost URL に特定の形式はありません。Web サービスで指定されたものと同じ URL です。

「データベースに接続できませんでした」エラーを解決するには、AsyncTaskを使用する必要があります。

AsynTask を使用したコードは次のとおりです。また、次のようTextViewonPostExecuteメソッドのテキストを設定する必要があります。

RetrievingDataFromDatabase retrievingTask;
TextView resultView;
String s;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    retrievingTask = new RetrievingDataFromDatabase();
    retrievingTask.execute((Void) null);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

public void getData(){
    resultView = (TextView) findViewById(R.id.textView1);
    String result = "";
    InputStream isr = null;
    try { 
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("http://HOSTNAME/FILENAME.php");
        HttpResponse response = httpclient.execute(httppost);
        HttpEntity entity = response.getEntity();
        isr = entity.getContent();
    } catch(Exception e) {
        Log.e("log_tag", "Error in http connection " + e.toString());
        resultView.setText("Couldnt connect to database");
    }
    //converting to string
    try {
        BufferedReader reader = new BufferedReader(new InputStreamReader(isr, "iso-8859-1"), 8);
        StringBuilder sb = new StringBuilder();
        String line = null;
        while ((line = reader.readLine()) != null) {
            sb.append(line + "\n");
        }
        isr.close();
        result = sb.toString();
    } catch(Exception e) {
        Log.e("log_tag", "Error converting result " + e.toString());
    }

    //parse data
    try {
        s = "";
        JSONArray jArray = new JSONArray(result);
        for(int i = 0; i < jArray.length(); i++){
            JSONObject json = jArray.getJSONObject(i);
            s = s + "St. ID" + json.getString("StId") + "\n " + json.getString("StName") + "\n" + json.getString("StMail");
        }
    }
    catch(Exception e) {
        Log.e("Log_tage", "Error Parsing Data" + e.toString());
    }
}

class RetrievingDataFromDatabase extends AsyncTask<Void, Void, Boolean> {

    @Override
    protected Boolean doInBackground(Void... params) {
        getData();
        return null;
    }

    @Override
    protected void onPostExecute(Boolean result) {
        super.onPostExecute(result);
        resultView.setText(s);
    }
}
于 2013-11-15T22:21:46.110 に答える
0

@Carlo のコードを使用して次のコード行を編集することにより、問題が解決され、データが取得されました。

HttpPost httppost = new HttpPost("http://HOSTNAME/FILENAME.php");

に:

HttpGet httppost = new HttpGet("http://HOSTNAME/FILENAME.php");

私のコードで述べたように、データを投稿していない URL からデータを取得したかったのです。

HttpPost > 指定されたリソースにデータを送信するために使用されます。HttpGet > 指定されたリソースからデータを取得するために使用されます。

ご協力ありがとうございます。

于 2013-11-16T16:35:49.327 に答える