[英]JSON array giving NULL values in word with Accents
I have this code to generate json array to send to Android App, but when i get values with Accents i get NULL values. 我有这段代码来生成要发送到Android App的json数组,但是当我使用Accents获取值时,我会得到NULL值。
this is my code: 这是我的代码:
<?php
header("Content-Type: text/html; charset=ISO-8859-1",true);
include "db_connect.php";
$userid = $_REQUEST['userid'];
$strSQL = "SELECT * FROM `mensages` WHERE `iduser` = '$userid' AND `read` = '0' ORDER BY `id` DESC";
$objQuery = mysql_query($strSQL);
$intNumField = mysql_num_fields($objQuery);
$resultArray = array();
while($obResult = mysql_fetch_array($objQuery))
{
$arrCol = array();
for($i=0;$i<$intNumField;$i++)
{
$arrCol[mysql_field_name($objQuery,$i)] = $obResult[$i];
}
array_push($resultArray,$arrCol);
}
mysql_close($objConnect);
echo json_encode($resultArray);
?>
You can add this PHP function to your code: 您可以将此PHP函数添加到您的代码中:
public static function normalizeChars($s) {
$replace = array(
'À'=>'A', 'Á'=>'A', 'Â'=>'A', 'Ã'=>'A', 'Ä'=>'Ae', 'Å'=>'A', 'Æ'=>'A', 'Ă'=>'A',
'à'=>'a', 'á'=>'a', 'â'=>'a', 'ã'=>'a', 'ä'=>'ae', 'å'=>'a', 'ă'=>'a', 'æ'=>'ae',
'þ'=>'b', 'Þ'=>'B',
'Ç'=>'C', 'ç'=>'c',
'È'=>'E', 'É'=>'E', 'Ê'=>'E', 'Ë'=>'E',
'è'=>'e', 'é'=>'e', 'ê'=>'e', 'ë'=>'e',
'Ğ'=>'G', 'ğ'=>'g',
'Ì'=>'I', 'Í'=>'I', 'Î'=>'I', 'Ï'=>'I', 'İ'=>'I', 'ı'=>'i', 'ì'=>'i', 'í'=>'i', 'î'=>'i', 'ï'=>'i',
'Ñ'=>'N',
'Ò'=>'O', 'Ó'=>'O', 'Ô'=>'O', 'Õ'=>'O', 'Ö'=>'Oe', 'Ø'=>'O', 'ö'=>'oe', 'ø'=>'o',
'ð'=>'o', 'ñ'=>'n', 'ò'=>'o', 'ó'=>'o', 'ô'=>'o', 'õ'=>'o',
'Š'=>'S', 'š'=>'s', 'Ş'=>'S', 'ș'=>'s', 'Ș'=>'S', 'ş'=>'s', 'ß'=>'ss',
'ț'=>'t', 'Ț'=>'T',
'Ù'=>'U', 'Ú'=>'U', 'Û'=>'U', 'Ü'=>'Ue',
'ù'=>'u', 'ú'=>'u', 'û'=>'u', 'ü'=>'ue',
'Ý'=>'Y',
'ý'=>'y', 'ý'=>'y', 'ÿ'=>'y',
'Ž'=>'Z', 'ž'=>'z'
);
return strtr($s, $replace);
}
Then you can change this particular variable $obResult[$i];
然后,您可以更改此特定变量$obResult[$i];
with normalizeChars($obResult[$i];)
与normalizeChars($obResult[$i];)
This will change your letters with accents to nomal letters, the phone can handle. 这会将您的带有重音符号的字母更改为电话可以处理的正常字母。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.