UnsupportedCharsetException:utf-lixo

时间:2015-01-07 15:03:08

标签: php android utf-8

当我尝试在我的APP中运行一个Activity时,我在Logcat上收到此错误。

1134-1134/br.com.agenciaeisberg.qm E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: br.com.agenciaeisberg.qm, PID: 1134
    java.nio.charset.UnsupportedCharsetException: utf-lixo

我调试了代码,一切正常,直到我调用webservice

JSONObject json = jsonParser.makeHttpRequest(url_info_hospital,"GET",params);

PHP页面正常运行,所需的所有信息都可以。

我检查了PHP和APP代码,但没有找到 UTF-lixo

在App布局上都使用

<?xml version="1.0" encoding="UTF-8"?>

PHP并没有声明任何内容。

以下是活动的完整代码

package br.com.agenciaeisberg.qm;


import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.util.ArrayList;
import java.util.List;

public class HospitalActivity extends Activity {

TextView Nome;
String pid;
Button btnIndicarLotacao;


// Progress Dialog
private ProgressDialog pDialog;

// JSON parser class
JSONParser jsonParser = new JSONParser();

// URL de busca de informações hospital
    private static final String url_info_hospital = "http://www.quickmed.com.br/android_hospital.php";

// JSON Nodes names

    private static final String TAG_HOSPITAL = "hospital";
    private static final String TAG_PID = "pid";
    private static final String TAG_NOME = "nome";
    private static final String TAG_SUCESSO = "sucesso";
    private static final String TAG_LOTACAO = "lotacao";

@Override
    public void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.hospital);

    //Botão de Indicar Lotação
    btnIndicarLotacao = (Button)findViewById(R.id.btnIndicarLotacao);

    //Buscando detalhes do hospital através do Intent
    Intent i = getIntent();

    // Buscando o pid do intent
    pid = i.getStringExtra(TAG_PID);

    // Buscando info do hospital no background
    new InfoHospital().execute();

    // Botão Indicar Lotação
    btnIndicarLotacao .setOnClickListener(new View.OnClickListener(){
        @Override
        public void onClick(View view){
            //Launch atividade Lista de Hospitais
            Intent i=new Intent(getApplicationContext(),ListagemHospitaisActivity.class);
            startActivity(i);
        }
    });

}
    /**
     * Background Async Task para buscar todos as informações do hospital
     */

    class InfoHospital extends AsyncTask<String, String, String>{

        /**
         * Mostra Progress Dialog
         */

        @Override
        protected void onPreExecute(){
            super.onPreExecute();
            pDialog = new ProgressDialog(HospitalActivity.this);
            pDialog.setMessage("Carregando informações dos hospitais. Favor aguadar ...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();
        }
        /**
         * Buscando as informações num Background thread
         */

        protected String doInBackground(String... params){

            //atualizando UI pelo Background thread

            runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    // Check for sucesso tag
                    int sucesso;
                    try {
                        //Construindo Parametros
                        List<NameValuePair> params = new ArrayList<NameValuePair>();
                        params.add(new BasicNameValuePair("pid",pid));

                        //buscando as informações do produto atrav~es de Request HTTP
                        // Observer que o url de buscar produtos vai utilizar GET
                        JSONObject json = jsonParser.makeHttpRequest(
                                url_info_hospital,"GET",params);

                        // Verifica o log para a json response
                        Log.d("Info Hospital", json.toString());

                        // json tag sucesso
                        //sucesso = json.getInt(TAG_SUCESSO);

                        sucesso = 1;

                        if (sucesso == 1){
                            // Recebeu informações do Hospital
                            JSONArray hospitalObj = json
                                    .getJSONArray(TAG_HOSPITAL);

                            JSONObject hospital = hospitalObj.getJSONObject(0);

                            //produto encontrado
                            // TextView
                            Nome = (TextView) findViewById(R.id.displayNome);
                            Nome.setText(hospital.getString(TAG_NOME));


                        }else{
                            // hospital não encontrado
                        }

                    }catch (JSONException e) {
                        e.printStackTrace();
                    }

                }
            });

          return null;
        }
        /**
         * After completing background task Dismiss the progress dialog
         * **/
        protected void onPostExecute(String file_url) {
            // dismiss the dialog once got all details
            pDialog.dismiss();
        }

    }

}

1 个答案:

答案 0 :(得分:0)

这是一个愚蠢的错误。但我会把它留在这里,所以它可能会帮助其他同样的愚蠢错误。在JSONParser类中,它定义了URLEncodedUtils。错误就在那里。

而不是UTF-8,它位于下面第4行的utf-lixo

}else if(method == "GET"){
                // request method is GET
                DefaultHttpClient httpClient = new DefaultHttpClient();
                String paramString = URLEncodedUtils.format(params, "UTF-8");
                url += "?" + paramString;
                HttpGet httpGet = new HttpGet(url);

                HttpResponse httpResponse = httpClient.execute(httpGet);
                HttpEntity httpEntity = httpResponse.getEntity();
                is = httpEntity.getContent();
            }