WordPress Plugin: Open Graph Image Tag


Die aktuellen Änderungen von Facebook machen es notwendig.
Facebook generiert seit ein paar Tagen echte Einträge auf meiner Facebook-Wall, wenn ich auf irgendeiner Website den Like-Bottom drücke. Dabei werden auch diese kleinen Bilder mit generiert, die üblicherweise schon immer dann erschienen sind, wenn ich einen Link geteilt habe. Leider sucht sich der Algorithmus von Facebook immer das falsche Bild aus, es sei denn, es gibt im Header des HTML-Bereiches eine Angabe zum Open Graph Tag – „og:image“.

Ich hatte hier bereits vor einer ganzen Weile mal eine Lösung gepostet, hier mal der Code, wie daraus ein Plugin werden kann.
Es würde mich freuen, wenn sich dem mal jemand annehmen würde und ein vollwertiges Plugin draus macht.

Es setzt auf das Plugin get_the_image von Justin Tadlock, welches ebenfalls installiert werden muss. Beides zusammen gibt dann die Referenz über den Open-Graph-Image-Tag z.B. auf das erste Bild im Post oder das Artikelbild. Wer daraus ein leicht zu handhabendes Plugin macht, bekommt von mir ein persönliches Lob ausgesprochen, diese falschen Bild in meinem Stream nerven mich doch zu sehr! 🙂


<?php
/*
Plugin Name: Open Graph Image Tag
Plugin URI: http://koffeinbetriebenes.net/
Description: Fügt einen META-Tags og:image in den Header ein. Für die Ausgabe des richtigen Bildes im automatisierten Facebook-Sharing. Benötigt das Plugin "get_the_image" von Justin Tadlock
Version: 0.1
Author: Steffen Peschel, Du
Author URI: http://steffenpeschel.de/
Min WP Version: 3.0
Max WP Version: 3.0
*/

// Hier URL zum Standardbild eingeben
$URL_to_logo = "";

// Filter im Plugin 'get_the_image'
if ( function_exists( 'get_the_image' ) ) add_filter( 'get_the_image', 'sp_overwrite_image' );
function sp_overwrite_image ($image) {
	$pattern = '/src="([^"]*)"/';
	preg_match($pattern, $image, $matches);
	$src = $matches[1];
	unset($matches);
return $src;
}

// Display og:img <meta> tag
if(!is_admin()) add_action ('wp_head', 'sp_og_img');
function sp_og_img() {
	global $URL_to_logo;
	if (is_single()) {
		global $posts;
		if ( function_exists( 'get_the_image' ) ) {
			$img_url = get_the_image( array( 'echo' => false, 'size' => 'medium', 'default_image' => $URL_to_logo ) );
		} else { 
		$img_url = $URL_to_logo; 
		}
	} else { 
		$img_url = $URL_to_logo; 
	} 
echo "\n<meta property=\"og:image\" content=\"" . $img_url . "\" />\n";
}
?>

p.s. Wenn es das Plugin für diese Funktion schon gibt, auch gut. Ich verlinke das dann gern.

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert.