2011-03-15 44 views
3

我的应用程序的一部分在mysql数据库上执行查询(通过php)。我在数据库UTF-8中使用,因为我需要出现像éàê这样的字母。 我读过这个问题,因为这看起来差不多。Android Java UTF-8 JSON

Android Java UTF-8 HttpClient Problem

然而,当我在执行的代码,他替换的E为空每个返回值。

这是我的代码

HttpParams params = new BasicHttpParams(); 
     HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1); 
     HttpProtocolParams.setContentCharset(params, "UTF-8"); 
     params.setBooleanParameter("http.protocol.expect-continue", false); 
     HttpClient httpclient = new DefaultHttpClient(params); 

      HttpPost httppost = new HttpPost("http://www.example.com/example.php"); 
      httppost.setEntity(new UrlEncodedFormEntity(query)); 
      HttpResponse response = httpclient.execute(httppost); 


      HttpEntity entity = response.getEntity(); 
      String jsonText = EntityUtils.toString(entity, HTTP.UTF_8); 
      Toast.makeText(StoresInfo.this, jsonText, Toast.LENGTH_LONG).show(); 
      is = entity.getContent(); 

所以在jsonText字符串替换他用它的“E”由空返回值。

最后一行是= entity.getConent();我添加了这个,因为我通常使用输入流来读取它,但这不起作用。

有人有想法吗?

这是我的PHP代码

<?php 
    mysql_select_db("database"); 

     $q=mysql_query($_REQUEST['query']); 

      while($e=mysql_fetch_assoc($q)) 

       $output[]=$e; 
      print(json_encode($output)); 
    mysql_close(); 


    ?> 
+0

你确定你的web界面是UTF-8? – Hrk 2011-03-15 21:53:19

+0

你是什么意思?这是我的PHP代码... – user661434 2011-03-15 21:57:20

+0

你是否在你的PHP界面你要求提供你的UTF-8内容,而不是另一种编码? – Hrk 2011-03-15 22:01:08

回答

4

尝试其他页面上的代码后,我想从你的服务器的Web界面来你的问题。

例如,你可以尝试含有“é”字符的谷歌网页上的GET请求:

HttpParams params = new BasicHttpParams(); 
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1); 
HttpProtocolParams.setContentCharset(params, "UTF-8"); 
params.setBooleanParameter("http.protocol.expect-continue", false); 
HttpClient httpclient = new DefaultHttpClient(params); 

HttpGet httpget = new HttpGet("http://www.google.ch/search?sourceid=chrome&ie=UTF-8&q=www.google.frb%C3%A9b%C3%A9&qscrl=1#sclient=psy&hl=fr&qscrl=1&source=hp&q=b%C3%A9b%C3%A9&aq=&aqi=&aql=f&oq=&pbx=1&fp=b4d89b2783e136eb&pf=p&pdl=300"); 

    try 
    { 
     HttpResponse response = httpclient.execute(httpget); 

     HttpEntity entity = response.getEntity(); 
     String jsonText = EntityUtils.toString(entity, HTTP.UTF_8); 
     Log.d("TEST", jsonText); 
     Toast.makeText(this, jsonText, Toast.LENGTH_LONG).show(); 
    } 
    catch (Exception e) 
    { 
    } 
+0

嗨伙计!这实际上是诀窍!我用记事本中的逗号分隔文件写了所有内容并上传了它!现在我看到了口音! 非常感谢你! – user661434 2011-03-16 17:12:20