En este post voy a mostrar cómo solucioné un error que me estaba fastidiando demasiado y que tenía tiempo que no me sucedía.

Resulta que al estar trayendo datos de una base de datos con MySQL y PHP se mostraban caracteres raros con signos de interrogación cuyo char code es 65535:

Como se puede apreciar en la imagen, no muestra letras con acento y al usar json_encode tampoco devuelve nada.

Cabe mencionar que en el head de mi HTML todo estaba correcto con el meta:

<meta charset="UTF-8">

Y el charset de mi base de datos con mi tabla ya lo había cambiado desde utf8_spanish_ci a otros. Ya estaba enloqueciendo hasta que dije:

¿Cómo es que en otros proyectos esto no me pasa?

Así que revisé mi plantilla en GitHub y afortunadamente ahí estaba la respuesta:

SET NAMES 'utf8';

No sé cómo funciona ni de qué se trata, pero antes de eso tenía mi PDO así:

Después lo hice así:

¡Magia pura! ahora sí funcionaba:

Si ves el botón un poco raro es porque estoy depurando el objeto con json_encode. El punto es que ahora sí funciona.

Por cierto, si quieres, puedes ver un tutorial de PHP con PDO y varios motores de búsqueda.

Si el post fue de tu agrado muestra tu apoyo compartiéndolo, suscribiéndote al blog, siguiéndome o realizando una donación.

Suscribir por correo

Ingresa tu correo y recibirás mis últimas entradas sobre programación, open source, bases de datos y todo lo relacionado con informática

Únete a otros 379 suscriptores

Relacionado:  Extraer extensión de archivo en PHP

parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

0 Comments

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

A %d blogueros les gusta esto: