我想从 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
怎么了?有人帮帮我好吗?