Foros del Web » Programando para Internet » PHP »

Pregunta Funciones PHP htmlspecialchars y htmlentities

Estas en el tema de Pregunta Funciones PHP htmlspecialchars y htmlentities en el foro de PHP en Foros del Web. Hola ojalá me puedan ayudar... Quiero mostrar los resultados de noticias almacenadas en una base de datos que es alimentada a través de un CMS ...
  #1 (permalink)  
Antiguo 30/09/2005, 11:59
 
Fecha de Ingreso: abril-2005
Mensajes: 50
Antigüedad: 18 años, 11 meses
Puntos: 0
Pregunta Pregunta Funciones PHP htmlspecialchars y htmlentities

Hola ojalá me puedan ayudar... Quiero mostrar los resultados de noticias almacenadas en una base de datos que es alimentada a través de un CMS por usuarios que no tienen idea de html o php, y utilizan caracteres que pueden causar problemas como comillas, entre otros..

En este sentido, me encontre que además de la función htmlspecialchars() existe una que se llama htmlentities(), pero a pesar de que leí el manual php quería saber su opinión sobre cual consideran mejor para utilizarla en este caso y si sería conveniente utilizarla junto con:

stripslashes()
y/o trim()

de la siguiente manera:

htmlspecialchars(stripslashes($row['titulo']))
ó
htmlspecialchars(stripslashes(trim(($row['titulo'])))
ó
en cuyo caso utilizar htmlentities() en vez de htmlspecialchars()

Saludos y gracias
  #2 (permalink)  
Antiguo 30/09/2005, 12:13
Avatar de davidangel  
Fecha de Ingreso: abril-2005
Mensajes: 124
Antigüedad: 18 años, 10 meses
Puntos: 0
cualquiera de las dos ultimas opciones estaria bien, bueno es lo que uso para
casos como el tuyo

htmlentities()
htmlspecialchars()

suerte nos vemos
  #3 (permalink)  
Antiguo 30/09/2005, 12:21
 
Fecha de Ingreso: abril-2005
Mensajes: 50
Antigüedad: 18 años, 11 meses
Puntos: 0
Exclamación htmlentities() ó htmlspecialchars().

Gracias...

Supongo que la pregunta podría replantearse de la siguiente manera:

¿En casos similares, es mejor utilizar htmlentities() ó htmlspecialchars()?

¿Cuál es la diferencia entre los dos?

Saludos

Última edición por raml; 30/09/2005 a las 14:55
  #4 (permalink)  
Antiguo 30/09/2005, 15:03
Avatar de davidangel  
Fecha de Ingreso: abril-2005
Mensajes: 124
Antigüedad: 18 años, 10 meses
Puntos: 0
lee esto y despeja dudas

http://www.php.net/manual/es/function.htmlentities.php

suerte nos vemos
  #5 (permalink)  
Antiguo 30/09/2005, 15:10
 
Fecha de Ingreso: abril-2005
Mensajes: 50
Antigüedad: 18 años, 11 meses
Puntos: 0
Sonrisa

Según el manual:

Cita:
Esta función es identica en todo a htmlspecialchars(), excepto que con htmlentities(), todos los caracteres que tengan una entidad equivalente en HTML serán cambiados a esas entidades.
¿Eso es mejor en mi caso?

Ya había leído el manual, siempre es mi primera referencia antes del foro... mi problema no es más que falta de experiencia en PHP ya que el manual hace referencia a muchas otras funciones que me confunden un poco (como en el caso de las dos tablas que aparecen), de ahí que esté buscando alguna explicación más simple...

Saludos y gracias

Última edición por raml; 30/09/2005 a las 15:23
  #6 (permalink)  
Antiguo 30/09/2005, 15:34
Avatar de jam1138
/** @package Moderador */
 
Fecha de Ingreso: julio-2004
Ubicación: sèveR led onieR lE
Mensajes: 9.368
Antigüedad: 19 años, 7 meses
Puntos: 102
htmlspecialchars() convierte carácteres que se usan para trabajar con HTML (<, >, ", ' y &), htmlentities() traduce todos aquellos que tengan un equivalente a HTML además de los mencionados antes (vocales acentuadas por ejemplo...).

Usa htmlentities().
__________________
٩(͡๏̯͡๏)۶
» Cómo hacer preguntas de manera inteligente «

"100 años después, la revolución no es con armas, es intelectual y digital"
  #7 (permalink)  
Antiguo 02/10/2005, 10:08
 
Fecha de Ingreso: abril-2005
Mensajes: 50
Antigüedad: 18 años, 11 meses
Puntos: 0
De acuerdo

Gracias por la ayuda en sus explicaciones.

Saludos ;0)

Última edición por raml; 02/10/2005 a las 12:45
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 01:04.