Json 编码 php 文件


Json encode php file

我想从mysql数据库打印Json数据,但数据在浏览器中显示不正确。我输入的名字带有重音,例如:何塞或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

会发生什么?有人帮我,好吗?

尝试将内容类型更改为:application/json

<?php header ('Content-type: application/json; charset=utf-8');

您可以使用以下函数:

function encodeIt($array) { 
  return json_encode(array_map('base64_encode', $array));
}
function decodeIt($string) {
  return array_map('base64_decode', json_decode($string));
}