在 PHP 中以区域语言返回 JSON 数据

懒惰的蜘蛛

我正在使用 MYSQL 数据库,其中我将数据存储在排序规则中:utf16le_general_ci。我这样做是为了在数据库中支持我的区域语言,并且我能够成功地以我的区域语言(GUJARATI)存储数据。

但是当我使用 PHP(版本 7+)读取数据并以 JSON 格式回显时,我得到了这种结果:

[
    {
        "content_id":"1",
        "cat_id_FK":"1",
        "content_data":"??????????? ? ????? ??????? ??."
    },
    {
        "content_id":"2",
        "cat_id_FK":"1",
        "content_data":"???? ?? ??? ?? 80% ????? ???? ??? ? ??? ??, ???? ??? ?????? ?? ??????,?????????? ??? ?????\r\n??????? ?? ??? ??????? ???? ??? ??? ??."
    },
    {
        "content_id":"3",
        "cat_id_FK":"1",
        "content_data":"?????????? ??????? ????????? ???? ???? ???? ? ???????????."
    },
    {
        "content_id":"4",
        "cat_id_FK":"1",
        "content_data":"???????????  ??? ???? ?????? ?????? ???? ???? ????? ?? ???????? ?? ??? ??."
    },
    {
        "content_id":"5",
        "cat_id_FK":"1",
        "content_data":"??? ????? ????? ???????? ?? ????? ????? ??? ??????? ? ??????????? ?? ????? ???? ????."
    },
    {
        "content_id":"6",
        "cat_id_FK":"1",
        "content_data":"??????????? ???? ?? ??? ??? ??? ? ????? ???."
    }
]

我的代码:-

header('Content-Type:application/json;charset=utf-8');
//header('Content-Type:application/json;charset=utf16le_general_ci');
include 'init.php';
global $connect;
$query = "SELECT * FROM gsrahasyacontent WHERE cat_id_FK=1";
$queryResult = mysqli_query($connect, $query);

while ($row = mysqli_fetch_assoc($queryResult)) {
   $array[] = $row;
}

echo json_encode($array, JSON_UNESCAPED_UNICODE);
//print json_encode($array, JSON_UNESCAPED_UNICODE);

-> 我尝试将字符集从 utf-8 更改为 utf16le_general_ci 但这没有用。

-> 我也使用 print 而不是 json 但仍然得到相同的结果。

这就是我的桌子的样子。

索拉布·夏尔马

试试这个 mysqli_set_charset($con,"utf8");

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章