Как заставить Toast отображать текст LogCat?
У меня есть HttpPost, который отправляет данные на сервер для хранения в базе данных. Когда эти данные успешно сохранены, я получаю ответ в LogCat, который говорит, что "сообщение было успешно сохранено" (этот ответ был определен в моем коде PHP). Я доволен этим, но я пытаюсь получить тот же самый ответ, который будет отображаться в тосте. Вот мой код:
String myBreadfromr, myBreadtor;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
Bundle myBasket = getIntent().getExtras();
myBreadfromr = myBasket.getString("keyfromcellr");
myBreadtor = myBasket.getString("keytocellr");
new SendData().execute("");
}
public class SendData extends AsyncTask<String, Integer, Void> {
protected void onPreExecute(String f) {
// called before doInBackground has started
f = "f";
}
protected Void doInBackground(String... params) {
// TODO Auto-generated method stub
// Create a new HTTP client
HttpClient client = new DefaultHttpClient();
// Create a new HTTP Post
HttpPost post = new HttpPost("http://192.xxx.xxx.xxx/androidp2p/process.php");
try {
// Add the data
List<NameValuePair> pairs = new ArrayList<NameValuePair>(3);
pairs.add(new BasicNameValuePair("from", myBreadfromr));
pairs.add(new BasicNameValuePair("to", myBreadtor));
pairs.add(new BasicNameValuePair("message", "What is your location?"));
// Encode Post data into valid URL format
post.setEntity(new UrlEncodedFormEntity(pairs));
// Go back to the first page
Intent back2start = new Intent(RequestLocation.this, StartApp.class);
startActivity(back2start);
// Make the HTTP Post Request
HttpResponse response = client.execute(post);
// Convert the response into a String
final HttpEntity resEntity = response.getEntity();
// Write the response to a log file
if (resEntity != null) {
Log.i("RESPONSE", EntityUtils.toString(resEntity));
}
runOnUiThread(new Runnable(){
public void run() {
Toast.makeText(RequestLocation.this, resEntity.toString(), Toast.LENGTH_LONG).show();
}
});
} catch (UnsupportedEncodingException uee) {
uee.printStackTrace();
} catch (ClientProtocolException cpe) {
cpe.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
}
return null;
}
protected void onProgressUpdate(Integer... progress) {
// called when the background task has made any progress
}
protected void onPostExecute() {
// called after doInBackground has finished
}
}
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
}
Вместо этого я вижу в тосте: "org.apache.http.conn.BasicManagedEntity@41284b48".
Заранее благодарю за любую помощь в решении этого вопроса.
1 ответ
Использование EntityUtils.toString(resEntity)
в тосте, чтобы получить тот же текст.
Также не нужно звонить runOnUiThread
, doInBackground
должен что-то вернуть, а не null
и что то будет доступно onPostExecute
который уже сделан для запуска в потоке пользовательского интерфейса.