2

我正在JSON使用这个发送消息PHP

$result = mysql_query("select a.id, ad.nombre, a.imagen, a.lat, a.long, ad.desc, a.url, a.email, a.tel, a.direccion, a.cp, a.poblacion, a.provincia from `bck_alrededor` a, `bck_alrededor_description` ad, `bck_alrededor_partner` ap
where a.id = ad.id_alrededor
and a.id = ap.id_alrededor
and a.id_cat = '$cat'
and ad.language = '$idioma'
and ap.id_partner = '$idp'",$link);

    while( $row = mysql_fetch_array($result) )
    {   
        $id = $row['id'];
        $nombre = $row['nombre'];
        $imagen=$row['imagen'];
        $lat=$row['lat'];
        $long=$row['long'];
        $desc=$row['desc'];
        $url=$row['url'];
        $email=$row['email'];
        $tel=$row['tel'];
        $direccion=$row['direccion'];
        $cp=$row['cp'];
        $poblacion=$row['poblacion'];
        $provincia=$row['provincia'];

        if ($imagen <>'')
        {
            $imagen = $dir.'/'.$imagen;
        }

        $posts[] = array('nid'=> $id , 'title'=> $nombre, 'image'=> $imagen ,  'latitude'=> $lat, 'longitude'=> $long, 'html'=> $desc, 'web'=> $url, 'email'=> $email, 'phone'=> $tel, 'address'=> $direccion, 'cp'=> $cp, 'poblacion'=> $poblacion, 'provincia'=> $provincia );

    }
    $response['nodes'] = $posts;

    $current_charset = 'ISO-8859-15';
    array_walk_recursive($response,function(&$value) use ($current_charset){
         $value = iconv('UTF-8//TRANSLIT',$current_charset,$value);

    });

    echo json_encode($response);

    if(!headers_sent()) header('Content-Type: application/json; charset=utf-8', true,200);
    header('Content-type: application/json');

但是我收到了带有 UTF8 转义字符的 JSON 消息:

{"nodes":[{"nid":"87","title":"Tienda Oficial","image":"\/tiendaoficialgbc.png","latitude":"43.3021","longitude":"-1.9721","html":"Entra y adquiere todos los productos oficiales del GBC. En 48h los tienes en casa","web":"http:\/\/www.gipuzkoabasket.com\/tienda\/tienda_es.php","email":"gipuzkoabasket@gipuzkoabasket.com.","phone":"943 44 44 28","address":"Paseo de Anoeta 22, 1a Planta","cp":"20014","poblacion":"Donostia - San Sebasti\u00e1n","provincia":"Gipuzkoa"},{"nid":"88","title":"Tienda Oficial Salaberria","image":"\/tiendaoficialgbc.png","latitude":"43.30384","longitude":"-1.9797","html":"Entra y adquiere todos los productos oficiales del GBC. En 48h los tienes en casa","web":"http:\/\/www.gipuzkoabasket.com\/tienda\/tienda_es.php","email":"gipuzkoabasket@gipuzkoabasket.com.","phone":"943 44 44 28","address":"Jos\u00e9 Maria Salaberria 88","cp":"20014","poblacion":"Donostia - San Sebasti\u00e1n","provincia":""}]}

我尝试使用 echo json_encode(utf8_encode($response)); 但后来我在客户端应用程序中收到了一条空 JSON 消息。

如何获得没有字符的常规JSON消息?UTF8

谢谢

4

1 回答 1

2

\u00e1是在 JSON 中转义 Unicode 字符的一种完全有效的方法。它是 JSON 规范的一部分。要将其解码为 UTF-8,只需json_decode它。utf8_decode与它无关。

我不明白的是这段代码:

iconv('UTF-8//TRANSLIT',$current_charset,$value);

这表示您正在尝试从UTF-8//TRANSLITISO-8859-15 转换,这没有多大意义。//TRANSLIT应该在之后,ISO-8859-15否则您根本不应该进行此转换。

于 2012-05-01T02:05:10.230 回答