1

我想从 mysql 数据库中打印 Json 数据,但数据未在浏览器中正确显示。我正在输入带有重音符号的名称,例如:José 或 L'Alcudia(它们是西班牙名称) 我有两个 php 文件,一个用于将数据插入数据库,另一个用于返回 JSON 数据。另一方面,我有一个允许我输入数据的 html 文件(一个表单)。

//HTML FILE
<!DOCTYPE html>
<html lang="es">

<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
</head>
<header></header>
<body>
<form id="formulario" name="formulario" method="post" action="insertar_persona.php" enctype="multipart/form-data">  
    <p>Nombre:</p>
    <input type="text" name="nombre" value="nombre" />      
    <br/><br/>
    <input type="submit" id="insertar" name="insertar" value="Insertar"/>

</form>
</body>
</html>



//INSERT PHP FILE

<?php header ('Content-type: text/html; charset=utf-8');
//Credenciales de la BBDD
$db = "prueba";
$host = 'localhost';
$username = "dpbataller";
$password = '1234';

//Conectamos al servidor de la Base de datos
$link = mysql_connect($host,$username,$password) or die("No se puede conectar");
//Seleccionamos la BBDD
@mysql_select_db($db) or die ("No se ha podido seleccionar a la base de datos");
//Lanzamos la consulta
$consulta = mysql_query("INSERT INTO personas (id,nombre) VALUES ('','$_POST[nombre]')");
?>



//GET JSON DATA
<?php header ('Content-type: text/html; charset=utf-8');
//Credenciales de la BBDD
$db = "prueba";
$host = 'localhost';
$username = "dpbataller";
$password = '1234';
//Conectamos al servidor de la Base de datos
$link = mysql_connect($host,$username,$password) or die("No se puede conectar");
//Seleccionamos la BBDD
mysql_select_db($db) or die ("No se ha podido seleccionar a la base de datos");
//Lanzamos la consulta 
$consulta = mysql_query("SELECT id,nombre from personas");
//Creamos un array para almacenar los resultados
$filas = array();
//Agregamos las filas  devueltas al array
while ($r = mysql_fetch_assoc($consulta)) { 
$filas[] = $r;  

}
//Devolvemos el resultado
echo json_encode($filas);
?>

当我尝试通过浏览器显示数据时显示:

[{"Id": "1", "name": "Jos \ u00e9"}]

数据库和表的编码是utf-8_spanish_ci

怎么了?有人帮帮我好吗?

4

2 回答 2

0

Try to change content-type as: application/json

<?php header ('Content-type: application/json; charset=utf-8');
于 2012-05-02T11:04:51.733 回答
0

您可以使用以下功能:

function encodeIt($array) { 
  return json_encode(array_map('base64_encode', $array));
}

function decodeIt($string) {
  return array_map('base64_decode', json_decode($string));
}
于 2012-05-02T11:06:53.600 回答