Integrar Facebook Open Graph en WordPress
Si tienes un blog con WordPressy has compartido una entrada en Facebook habrás notado que no muestra siempre la imagen correcta, la que debería ser; con frecuencia la imagen destacada de la entrada. Además, es posible que esto no sólo te pase con la imagen, sino que también lo haga con el título, la descripción o que, cuando alguien pulse el botón de «me gusta», no muestre el thumbnail correcto.
Si te ha pasado esto, en esta entrada aprenderás lo justo para hacer que Facebook reconozca bien los datos de las entradas de tu WordPress. Esto es algo que no todos los temas hacen bien.
¿Qué es Open Graph?
Open Graph es un protocolo que creó Facebook para ayudar a compartir contenido con amigos y admiradores de los sitios web. Esto, sea quien sea quien de a «me gusta», hará que tu contenido sea mostrado en su tablón (o muro). Así que, para evitar el fallo que mencionaba antes de los thumbnails, títulos, descripciones… tienes que hacer unas mejoras a tu sitio para que Facebook sepa qué cosa corresponde con qué.
Tranquilo, es más sencillo de lo que parece. Basta con asegurarnos de que nuestro sitio es 100% compatible con las especificaciones de Open Graph.
Instalación mediante plugin
Si tus conocimientos de desarrollo son bajos, puedes instalar un plugin que realice estos cambios por tí. Yo algunas veces he recomendado WP Facebook Open Graph aunque, como todo, es cuestión de gustos.
Instalación manual
Si, por otro lado, quieres hacerlo de forma manual (más óptimo, sin plugins mejor), tendremos que agregar el siguiente contenido al fichero functions.php de nuestro tema:
//Agregamos Open Graph en los Language Attributes function add_opengraph_doctype( $output ) { return $output . ' xmlns:og="http://opengraphprotocol.org/schema/" xmlns:fb="http://www.facebook.com/2008/fbml"'; } add_filter('language_attributes', 'add_opengraph_doctype'); //Añadimos la información Open Graph function insert_fb_in_head() { global $post; if ( !is_singular()) //Si no es un post o página return; echo '<meta property="fb:admins" content="EL ID DE TU USUARIO"/>'; echo '<meta property="og:title" content="' . get_the_title() . '"/>'; echo '<meta property="og:type" content="article"/>'; echo '<meta property="og:url" content="' . get_permalink() . '"/>'; echo '<meta property="og:site_name" content="AQUI VA EL NOMBRE DE TU SITIO WEB"/>'; if(!has_post_thumbnail( $post->ID )) { //La entrada no tiene imagen destacada, utiliza una imagen predeterminada $default_image="http://ejemplo.com/image.jpg"; //Aquí tienes que poner la ruta de la imagen prefeterminada que se mostrará. echo '<meta property="og:image" content="' . $default_image . '"/>'; } else{ $thumbnail_src = wp_get_attachment_image_src( get_post_thumbnail_id( $post->ID ), 'medium' ); echo '<meta property="og:image" content="' . esc_attr( $thumbnail_src[0] ) . '"/>'; } echo " "; } add_action( 'wp_head', 'insert_fb_in_head', 5 ); |
Por supuesto, no olvides modificar el ID de tu usuario, el nombre de tu sitio web o la URL de la imagen predeterminada.
Espero que sea de ayuda, ¡si es así no dudes en compartirlo!
y para que muestre la descripción del post correspondiente?
Hola Jordi, con un meta og:description lo consigues.
Hola, no me funciona, comparta lo que comparta siempre me hace lo mismo, mi sitio web con la dirección el nombre y la imagen del blog, pero yo quiero que identifique la de cada post y la meta de cada uno y nada… saludos
Alejandro, repasa todos los pasos; el contenido del artículo sigue funcionando correctamente.
hola un saludo acabo de hacer tal cual el código y tengo un problema ya que no puedo obtener la imagen si obtengo la descripción y a su vez en nombre del sitio pero me toma 3 imágenes la agrego manual es decir yo pongo la url e igual sigue mostrando 3 imágenes me puedes orientar o bien hay algo que deba de configurar en wordpress ?
Hola Rubén, pues ahora mismo no se me ocurre qué puede ser. Si te da a escoger 3 quizá es porque funciona realmente así. Esta entrada es para parámetros por defecto (sin imagen ni descripción ni nada coge esos elementos por defecto).
me sucede exactamente lo mismo, me da a elegir varias imagenes pero no la que esta como featured
Carlos, el script del ejemplo muestra la imagen que coloques en la url.
Gracias por la info, fue de mucha utilidad! Saludos
Gracias, me funcionó.
Saludos.
Gracias hermano !!, me funcionó a la perfección !
Muchas gracias. Funcionó como la seda!
Agradecido amigo me has salvado…
funciona para página estática fija, es lo mismo? Gracias
Hola Sebastian, debería funcionar sin problema. En este caso lo aplico a WordPress pero los meta datos son iguales.