我需要从mysql数据库中获取一些数据,我正在运行一个php脚本来查询数据库,json编码并打印它。通过服务器中php上的httppost从我的应用程序获取结果。除了包含特殊/非类型字符的条目外,我从服务器获取所有数据。例如:“,”
对于这些条目,我将得到空值。所以除了用诸如“服务器端”之类的键入字符替换这些字符之外,是否有任何方法可以用这些字符获取这些数据以显示在应用程序中。
谢谢。
try{
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost(KEY_121);
//httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
HttpResponse response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
is = entity.getContent();
}catch(Exception e){
Log.e("cxxn", "Error in http connection "+e.toString());
}
//convert response to string
try{
BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
result=sb.toString();
}catch(Exception e){
Log.e("convt", "Error converting result "+e.toString());
}
结果对于那些带有特殊字符的数据有空值。我是否应该更改正在使用的编码。。?
编辑:
MySQL字符集是:UTF-8unicode(utf8)
<?php
mysql_connect("","","");
mysql_select_db("fdict");
$q=mysql_query("SELECT (Id), (WD), (des), (udte) FROM `dict`");
while($e=mysql_fetch_assoc($q))
$output[]=$e;
print(json_encode($output));
mysql_close();
?>
这是我的服务器端php代码。已删除服务器地址,pass。带有特殊字符的数据似乎只有在json_encode()之后才变为空。sql查询结果的回音显示正确的数据,没有任何空值。请帮助我们。我能做些什么。。?我有什么选择。。?
谢谢。
最佳答案
使用this解决了这个问题。
需要将mysql_query('SET CHARACTER SET utf8')
放在SELECT查询之前,以便以utf8格式检索它。