Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Eñes tilde acentos no salen en Apache PHP MySQL CentOS
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Eñes tilde acentos no salen en Apache PHP MySQL CentOS

Publicar nuevo tema Responder al tema
Foros de discusión » Linux, sistema operativo gratuito, Ubuntu, Debian, Suse, Red Hat, Fedora   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Eñes tilde acentos no salen en Apache PHP MySQL CentOS Responder citando

Hola, tengo un servidor con Linux CentOS 7, lo uso como servidor web, antes tenía la web en un Linux Ubuntu Server, pero me dijeron que CentOS va mejor y lo cambié. En el servidor web uso Apache, PHP y MySQL, tengo una web con el viejo PHPNuke que en el Ubuntu estaba funcionando bien. Al pasarla al Linux CentOS funciona pero las eñes, tildes, acentos y caracteres propios de nuestro idioma salen con caracteres raros o extraños.

No tengo muchos conocimientos de Linux ¿a qué puede ser debido esto?
MensajePublicado:
Lun May 11, 2015 5:47 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Eñes tilde acentos no salen en Apache PHP MySQL CentOS Responder citando



Anuncios



varios escribió:
Hola, tengo un servidor con Linux CentOS 7, lo uso como servidor web, antes tenía la web en un Linux Ubuntu Server, pero me dijeron que CentOS va mejor y lo cambié. En el servidor web uso Apache, PHP y MySQL, tengo una web con el viejo PHPNuke que en el Ubuntu estaba funcionando bien. Al pasarla al Linux CentOS funciona pero las eñes, tildes, acentos y caracteres propios de nuestro idioma salen con caracteres raros o extraños.

No tengo muchos conocimientos de Linux ¿a qué puede ser debido esto?


Los problemas con la codificación de caracteres suelen solucionarse de forma relativamente sencilla. Realiza estas verificaciones:

1. El juego de caracteres de tu base de datos MySQL debe ser, normalmente:

charset = latin1
collation = latin1_spanish_ci


Esto puedes comprobarlo usando, por ejemplo, MySQL Administrator o MySQL Workbench y editando las propiedades de la tabla, desde aquí puedes cambiar el juego de caracteres.

También puedes consultar y modificar el juego de caracteres de la base de datos, de una tabla e incluso de sus columnas usando la línea de comandos. Algunos comandos MySQL para mostrar el juego de caracteres:

** A nivel de toda la base de datos, para que al crear una tabla sin que se especifice el juego de caracteres se aplique este directamente:

Código:

show variables like "character_set_database";


Te devolverá algo así:

character_set_database latin1

y

Código:

show variables like "collation_database";


te devolverá:

collation_database latin1_swedish_ci

** A nivel de una tabla ejecuta la siguiente consulta SQL (cambiando "bdajpdsoft" por el nombre de tu esquema o base de datos y "nuke_stories" por el nombre de la tabla:

Código:

SELECT CCSA.character_set_name FROM information_schema.TABLES T, information_schema.COLLATION_CHARACTER_SET_APPLICABILITY CCSA WHERE CCSA.collation_name = T.table_collation AND T.table_schema = "bdajpdsoft" AND T.table_name = "nuke_stories";


Si quieres mostrar el juego de caracteres de todas las tablas puedes suprimir el filtro del where "T.table_name", de la siguiente forma:

Código:

SELECT CCSA.character_set_name FROM information_schema.TABLES T, information_schema.COLLATION_CHARACTER_SET_APPLICABILITY CCSA WHERE CCSA.collation_name = T.table_collation AND T.table_schema = "bdajpdsoft";


** Para ver todas las variables del motor de MySQL relacionadas con el juego de caracteres:

Código:

show variables like 'collation%';


te devolverá algo así:

collation_connection utf8_general_ci
collation_database latin1_swedish_ci
collation_server latin1_swedish_ci


** También puedes ver el SQL de creación de una tabla, donde te mostrará el juego de caracetes empleado, con:

Código:

show create table nombre_tabla;


Existen algunas más, pero estas son las principales. Para cambiar el juego de caracteres de un esquema/base de datos:

Código:

ALTER TABLE nombre_tabla CONVERT TO CHARACTER SET latin1 COLLATE latin1_spanish_ci;


2. Una vez que te hayas asegurado de que tienes el juego de caracteres correcto en tu base de datos MySQL, lo siguiente es comprobar la configuración de codificación de caracteres de Apache. Para ello edita el fichero de configuración de Apache de tu servidor (httpd.conf), que en el caso de Linux CentOS 7 suele estar en:

/etc/httpd/conf/httpd.conf

puedes editarlo con vi o con nano, dentro del fichero busca la línea [b]AddDefaultCharset[/] y déjala con el siguiente valor:

AddDefaultCharset ISO-8859-1

Guarda los cambios en el fichero y reinicia el servicio de Apache con el comando:

Código:

systemctl restart httpd.service


3. Comprueba que los ficheros de tu sitio web están también guardados con la codificación ISO-8859-1, esto puedes hacerlo abriendo el fichero con el editor Notepad++ (por ejemplo), que te mostrará la codificación actual del fichero y te dejará modificarla por la que quieras.

4. En el encabezado HTML de las páginas de tu sitio web (en la cabecera HEAD) debes tener la metaetiqueta:

Código:

<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=ISO-8859-1">


Si usas PHP, incluso podrías forzar al uso de este juego de caracteres con:

Código:

<?php
header("Content-Type: text/html; charset=ISO-8859-1");
?>


Y rizando el rizo, incluso se podría usar el fichero .htaccess para forzar al uso del juego de caracteres. Pero en principio, si sigues los pasos que te hemos indicado, hasta llegar al 4 sería suficiente: base de datos con latin1 (que es equivalente al ISO-8859-1), ficheros con el ISO-8859-1 y encabezado HTML con este juego también. De esta forma debería mostrarte bien el juego de caracteres.

Si realizas modificaciones de configuración tal vez debas reiniciar el servicio de MySQL y el de Apache, como te hemos indicando arriba.
MensajePublicado:
Lun May 11, 2015 6:30 pm
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: [RESUELTO] Eñes acentos no salen en Apache PHP MySQL CentOS Responder citando



Anuncios



alonsojpd escribió:
Los problemas con la codificación de caracteres suelen solucionarse de forma relativamente sencilla. Realiza estas verificaciones:

1. El juego de caracteres de tu base de datos MySQL debe ser, normalmente, latin1.

2. Una vez que te hayas asegurado de que tienes el juego de caracteres correcto en tu base de datos MySQL, lo siguiente es comprobar la configuración de codificación de caracteres de Apache. Para ello edita el fichero de configuración de Apache de tu servidor (httpd.conf), que en el caso de Linux CentOS 7 suele estar en:

/etc/httpd/conf/httpd.conf

puedes editarlo con vi o con nano, dentro del fichero busca la línea [b]AddDefaultCharset[/] y déjala con el siguiente valor:

AddDefaultCharset ISO-8859-1

Guarda los cambios en el fichero y reinicia el servicio de Apache con el comando:

Código:

systemctl restart httpd.service


3. Comprueba que los ficheros de tu sitio web están también guardados con la codificación ISO-8859-1, esto puedes hacerlo abriendo el fichero con el editor Notepad++ (por ejemplo), que te mostrará la codificación actual del fichero y te dejará modificarla por la que quieras.

4. En el encabezado HTML de las páginas de tu sitio web (en la cabecera HEAD) debes tener la metaetiqueta:


Genial tu explicación, lo resolví con el segundo punto, el fichero de configuración de Apache, lo tenía todo bien, la BD a latin1, los ficheros a ISO-8859-1 y el encabezado HTML también, solo me faltaba la configuración de Apache.

Muchísimas gracias!!!!!!!!!!!!!
MensajePublicado:
Lun May 11, 2015 6:34 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Linux, sistema operativo gratuito, Ubuntu, Debian, Suse, Red Hat, Fedora  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A