<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Soziotechnische Integration &#187; PHP</title>
	<atom:link href="https://test.soziotech.org/category/technologien/php/feed/" rel="self" type="application/rss+xml" />
	<link>https://test.soziotech.org</link>
	<description>Ein Projekt mit der Forschungsgruppe Kooperationssysteme an der Universität der Bundeswehr München</description>
	<lastBuildDate>Mon, 15 Jun 2015 15:24:48 +0000</lastBuildDate>
	<language>de-DE</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>https://wordpress.org/?v=4.2.38</generator>
	<item>
		<title>Quellenangaben und Fußnoten für NextGEN Gallery</title>
		<link>https://test.soziotech.org/quellenangaben-und-fussnoten-fur-nextgen-gallery/</link>
		<comments>https://test.soziotech.org/quellenangaben-und-fussnoten-fur-nextgen-gallery/#comments</comments>
		<pubDate>Sun, 20 Feb 2011 18:02:31 +0000</pubDate>
		<dc:creator><![CDATA[Florian Ott]]></dc:creator>
				<category><![CDATA[Dienstintegration]]></category>
		<category><![CDATA[Internet & Web 2.0]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Wordpress / Buddypress]]></category>
		<category><![CDATA[Footnotes]]></category>
		<category><![CDATA[Fußnoten]]></category>
		<category><![CDATA[Gallery]]></category>
		<category><![CDATA[NextGEN]]></category>
		<category><![CDATA[NextGEN Gallery]]></category>
		<category><![CDATA[Plugin]]></category>
		<category><![CDATA[Quellen]]></category>
		<category><![CDATA[Referenzierung]]></category>
		<category><![CDATA[Simple Footnotes]]></category>
		<category><![CDATA[Wordpress]]></category>
		<category><![CDATA[Zitation]]></category>

		<guid isPermaLink="false">http://sevastyanova.cscwlab.de/?p=407</guid>
		<description><![CDATA[<p><img src="https://test.soziotech.org/wp-content/uploads/cache/192_crop_940x198_istock_000000079169medium.jpg" width="618" height="130" alt="Quellenangaben und Fußnoten für NextGEN Gallery" /></p>NextGen Gallery ist meiner Meinung nach eine der sinnvollsten und am besten durchdachten Erweiterungen für WordPress. Das Plugin ermöglicht eine galerie- und albumbasierte Verwaltung von Bilder aller Art und darüber hinaus die Zuordnung von Schlagwörtern / Tags zur zusätzlichen (flachen) &#8230; <a href="https://test.soziotech.org/quellenangaben-und-fussnoten-fur-nextgen-gallery/">Weiterlesen <span class="meta-nav">&#8594;</span></a><img src="https://analytics.flottmedia.com/piwik/piwik.php?idsite=2&amp;rec=1&amp;url=https%3A%2F%2Ftest.soziotech.org%2Fquellenangaben-und-fussnoten-fur-nextgen-gallery%2F&amp;action_name=Quellenangaben+und+Fu%C3%9Fnoten+f%C3%BCr+NextGEN+Gallery&amp;urlref=http%3A%2F%2Ffeeds.feedburner.com%2Fsoziotech" style="border:0;width:0;height:0" width="0" height="0" alt="" /><div class='yarpp-related-rss'>
<h3>Verwandte Artikel:</h3><ol>
<li><a href="https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/" rel="bookmark" title="Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP">Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP </a></li>
<li><a href="https://test.soziotech.org/wordpress-xml-sitemap-fur-multisite-installationen/" rel="bookmark" title="WordPress XML Sitemap für Multisite-Installationen">WordPress XML Sitemap für Multisite-Installationen </a></li>
<li><a href="https://test.soziotech.org/datenschutzrichtlinien-google-analytics-fur-wordpress/" rel="bookmark" title="Datenschutz &amp; Google Analytics für WordPress">Datenschutz &amp; Google Analytics für WordPress </a></li>
</ol>
</div>
]]></description>
				<content:encoded><![CDATA[<p><img src="https://test.soziotech.org/wp-content/uploads/cache/192_crop_940x198_istock_000000079169medium.jpg" width="618" height="130" alt="Quellenangaben und Fußnoten für NextGEN Gallery" /></p>
<p><a href="http://alexrabe.de/wordpress-plugins/nextgen-gallery/" title="Zur Website von NextGEN Gallery" target="_blank" class="link-external">NextGen Gallery</a> <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-1" href="#note-407-1" onmouseover="tooltip.show('Downloaddes Plugins im WordPress-Repository unter http://wordpress.org/extend/plugins/nextgen-gallery/');" onmouseout="tooltip.hide();"><sup>1</sup></a> ist meiner Meinung nach eine der sinnvollsten und am besten durchdachten Erweiterungen für WordPress. Das Plugin ermöglicht eine galerie- und albumbasierte Verwaltung von Bilder aller Art und darüber hinaus die Zuordnung von Schlagwörtern / Tags zur zusätzlichen (flachen) Strukturierung. Hierdurch wird es möglich, Bilder in Artikeln mithilfe des nggtags-Shortcodes <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-2" href="#note-407-2" onmouseover="tooltip.show('Dokumentation unter http://nextgen-gallery.com/gallery-tags/.');" onmouseout="tooltip.hide();"><sup>2</sup></a> dynamisch einzubinden, d.h. statt einer festen Referenz auf eine Auswahl von Bildern wird nur noch festgelegt, welche Schlagwortkombinationen für eine bestimmte Artikelstelle relevant sind. Beispielsweise würden mit folgendem Shortcode alle Bilder als Thumbnails angezeigt, die mit &#8222;Auto&#8220; (Groß- und Kleinschreibung egal) verschlagwortet wurden <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-3" href="#note-407-3" onmouseover="tooltip.show('Achtung: Die Leerzeichen innerhalb der eckigen Klammern müssen nach einem Copy &amp; Paste entfernt werden, damit der Shortcode von WordPress ausgeführt wird.');" onmouseout="tooltip.hide();"><sup>3</sup></a></p>
<pre>[ nggtags gallery=Auto ]</pre>
<p>Das Ganze hat meiner Meinung nach drei entscheidende Vorteile:</p>
<ol>
<li>Kommen weitere Bilder mit den entsprechenden Tags in irgendeiner Galerie hinzu, werden sie automatisch im Artikel mit angezeigt.</li>
<li>In der Galerie angegebene Metadaten, wie Titel und Beschreibung werden automatisch übernommen und müssen so im Vergleich zur Nutzung der WordPress Mediathek nicht redundant gepflegt werden &#8211; v.a. dann nicht, wenn sie sich nachträglich ändern.</li>
<li>Der Tagging-Mechanismus funktioniert galerieübergreifend, d.h. neben der in NextGEN vorhandenen intuitiven Strukturierung in verschiedene Galerien (z.B. zu einem bestimmten Ereignis wie &#8222;Doktorandenseminare&#8220; oder einer bestimmten Bilderkategorie wie &#8222;WordPress Screenshots&#8220;), lassen sich sehr einfach übergreifende Selektionen vornehmen <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-4" href="#note-407-4" onmouseover="tooltip.show('Beispielsweise würden mithilfe des Shortcodes [ nggtags gallery=Referenzverwaltung ] alle Bilder angezeigt werden, die mit &#8222;Referenzverwaltung&#8220; verschalgwortet wurden, sowohl aus der Galerie &#8222;Doktorandenseminare&#8220; als auch aus der Galerie &#8222;WordPress Screenshots&#8220; (sowie allen ggf. vorhandenen weiteren Galerien).');" onmouseout="tooltip.hide();"><sup>4</sup></a>.</li>
</ol>
<h2>Problem bei externen Bildquellen</h2>
<p>Ein &#8222;Problem&#8220; mit dem Plugin ergibt sich dann, wenn man Bilder z.B. im wissenschaftlichen Kontext von anderen Quellen referenzieren und dennoch auf den Komfort des Plugins nicht verzichten möchte. Aktuell bietet NextGEN Gallery keine Möglichkeit, Bildquellen oder Ähnliches direkt anzugeben. Natürlich könnte man dafür das Beschreibungsfeld nutzen bzw. zweckentfremden und die entsprechende Quelle einfach als Text dort mit aufnehmen. Für den Fall, dass man die Anzeige der Quelle allerdings gezielter steuern möchte, ist diese Möglichkeit nicht geeignet. Auch widerspräche das Vorgehen klar dem Atomaritätsprinzip bzw. der semantischen Bedeutung des Beschreibungsfeldes. Prinzipiell bietet NextGEN auch hierfür einen eingebauten <a href="http://nextgen-gallery.com/custom-fields/" title="Zur Dokumentation der Custom Fields von NextGEN Gallery" target="_blank" class="link-external">Mechanismus zur Angabe weiterer Metadaten</a>, allerdings ist dieser in neueren Versionen des Plugins nur sehr umständlich erreichbar und wird v.a. nicht in den Übersichten angezeigt.</p>
<h2>Lösungsschritte</h2>
<p>Nachdem bis zu einer sinnvoll nutzbaren Lösung zur Quellangabe einige Schritte erforderlich waren, halte ich das hier kurz fest.</p>
<h3>1. Zusätzliches Feld zur Quellenangabe bei jedem Bild</h3>
<p>Zur Bereitstellung des benötigten Metadatenfeldes im Backend von NextGEN hilft das <a href="http://wordpress.org/extend/plugins/nextgen-gallery-custom-fields/" title="Zur Downloadseite des Plugins NextGEN Custom Fields " target="_blank" class="link-external">Plugin NextGEN Custom Fields</a>, mit dem nach erfolgter Installation über den neuen Menüpunkt &#8222;NGG Custom Fields&#8220; sehr einfach ein neues  Image Custom Field mit  Bezeichnung &#8222;Source&#8220; für Quellenangaben angelegt werden kann. Die Eingabe erfolgt anschließend wie gewohnt über den Punkt &#8222;Galerie verwalten&#8220;, wie im folgenden Screenshot auf der rechten Seite zu sehen.</p>
<div class="ngg-singlepic wp-caption">
<a rel="lightbox" href="https://test.soziotech.org/wp-content/uploads/wordpress-screenshots/nextgen-source.png" title="
			Zusätzliches Feld für Quellenangaben bei Bildern in NextGEN Gallery			" 

 >
	<img src="https://test.soziotech.org/wp-content/uploads/cache/245__614xfloat=_nextgen-source.png" alt="NextGEN Gallery Source Feld" title="NextGEN Gallery Source Feld" />
</a>
			<p class="wp-caption-text">NextGEN Gallery Source Feld</p>
</div>

<h3>2. Anpassen des Galerie-Templates</h3>
<p>Damit das neu erstellte Feld auch in Thumbnail-Übersichten oder bei Einzelbildern im Frontend angezeigt wird, muss es entsprechend eingebunden werden. Mein erster Ansatz war, ein eigenes NextGEN Gallery Template für die Ausgabe zu nutzen, allerdings funktioniert der folgende Shortcode leider nicht, da NextGEN seltsamerweise bei tagbasierten Galerien bisher keine Tamplates unterstützt.</p>
<pre>[ nggtags gallery=Auto template=source]
</pre>
<p>Dieser Missstand ließe sich zwar entsprechend <a href="http://wordpress.org/support/topic/plugin-nextgen-gallery-nggtags-caption" title="Zum Forenbeitrag zu nggtags mit captions" target="_blank" class="link-external">http://wordpress.org/support/topic/plugin-nextgen-gallery-nggtags-caption</a> beseitigen, allerdings müssten hierzu die Funktion nggShowGalleryTags in der nggfunctions.php und die Funktion show_tags in der shortcode.php von NextGEN entsprechend angepasst werden, was logischerweise nicht update-sicher und damit wenig sinnvoll ist. Hier heißt es also abwarten, ob diese durchaus sinnvollen Erweiterungen für nggtags irgendwann durch den Autor Alex Rabe ihren Weg in das Plugin finden, wovon ich fest ausgehe.</p>
<p>Somit blieb nichts anderes, als direkt das gallery.php Template entsprechend anzupassen. Nachdem wir hier im Blog allerdings sowieso ein einheitliches Galerieformat verwenden, ist dem auch nichts entgegenzusetzen &#8211; insbesondere da es so (ohne den zusätzlichen template-Parameter im Shortcode) noch einfacher ist, später Galerien in Blogartikeln einzufügen.</p>
<p>Um sicherzustellen, das die Templates nicht bei einem Plugin-Update direkt wieder überschrieben werden, sollten die folgenden Anpassungen ausschließlich (!) in einem zu erstellenden Unterordner &#8222;nggallery&#8220; des verwendeten Themes durchgeführt werden:</p>
<ol>
<li>Kopieren der gallery.php und der singlepic.php aus /wp-content/plugins/nextgen-gallery/view/ nach wp-content/themes/AKTUELLES-THEME/nggallery/.</li>
<li>Einfügen von $image-&gt;ngg_custom_fields[&#8222;Source&#8220;] an der gewünschten Stelle, z.B. hinter echo $image-&gt;caption.</li>
</ol>
<p>Problem hierbei ist, dass die Quellangaben (zumindest in unserem Fall) meist <a href="https://test.soziotech.org/glossar/url/" class="glossaryLink" title="Klicken Sie, um zum detaillierten Glossareintrag für URL zu springen." onmouseover="tooltip.show('Unter URLs (Uniform Resource Locator) versteht man eindeutige menschenlesbare Adressen, die Inhalte wie beispielsweise Webseiten im Internet identifizieren und dadurch zugreifbar machen. URLs werden meist als Internetadressen bezeichnet. ');" onmouseout="tooltip.hide();">URLs</a> sind, die i.d.R. eine Länge haben, durch welche die schön gefloateten Thumbnail-Übersichten unruhig würden oder falscch umbrechen, sicher aber schlecht lesbar wären (s. Screenshot):</p>
<div class="ngg-singlepic wp-caption">
<a rel="lightbox" href="https://test.soziotech.org/wp-content/uploads/wordpress-screenshots/nextgen-thumbnail-problem-mit-quellen.png" title="
			Zerschossene Thumbnails bei langen Quellenangaben			" 

 >
	<img src="https://test.soziotech.org/wp-content/uploads/cache/246__614xfloat=_nextgen-thumbnail-problem-mit-quellen.png" alt="Fehlerhafte Darstellung bei Thumbnails mit Quellen" title="Fehlerhafte Darstellung bei Thumbnails mit Quellen" />
</a>
			<p class="wp-caption-text">Fehlerhafte Darstellung bei Thumbnails mit Quellen</p>
</div>

<h3>3. Fußnoten für Quellenangaben</h3>
<p>Da wir hier im Blog ein Plugin zur Erzeugung von Fußnoten für zusätzliche Anmerkungen oder wissenschaftliche Quellenangaben verwenden, war es naheliegend, dieses Plugin auch für die Galeriebilder zu nutzen. In unserem Fall handelt es sich um das Plugin <a href="http://wordpress.org/extend/plugins/simple-footnotes/" title="Zur Downloadseite des Plugins Simple Footnotes" target="_blank" class="link-external">Simple Footnotes</a>, das sich durch eine sehr einfache Handhabung sowie Multisite- und WP 3.1-Kompatibilität auszeichnet. Im Prinzip sollten die folgenden Schritte aber auch auf andere Plugins übertragbar sein.</p>
<p>Statt der Einbindung der Quellangabe direkt in der Caption, muss hierzu das Source-Field von oben lediglich mit der entsprechenden Shortcode-Funktion das Simple Footnotes Plugins &#8222;gewrappt&#8220; werden. Da das Gallery-Template das Plugin allerdings nicht kennt, ist es erforderlich, zunächst eine entsprechende lokale Instanz zu erzeugen:</p>
<pre class="brush:php">n
$footnotes-&gt;shortcode('', "Bildquelle: " . imagesourcelink($image-&gt;ngg_custom_fields["Source"]) . "."));</pre>
<p>Damit die Fußnoten nur dann erzeugt werden, wenn auch tatsächlich  eine Quellenangabe vorhanden ist, sollte zusätzlich noch folgende  Abfrage integriert werden:</p>
<pre class="brush:php">if ($image-&gt;ngg_custom_fields["Source"]){
	echo ($footnotes-&gt;shortcode('', "Bildquelle: " . imagesourcelink($image-&gt;ngg_custom_fields["Source"]) . "."));
}</pre>
<p>Mit diesem Code wurden die Fußnoten auch erzeugt, allerdings leider für jedes Bild wieder bei 1 beginnend, da bei jedem Aufruf innerhalb der Bilderschleife des Gallery-Templates eine neue Instanz des Footnote-Plugins erstellt wurde. Abhilfe schafft hier das Auslagern der Instanzerzeugung außerhalb der Schleife und verwenden von $footnotes als globale Variable. Wichtig: Ähnlich wie bei einem Singleton <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-5" href="#note-407-5" onmouseover="tooltip.show('Informatiker mögen mir die unsaubere Verwendung an dieser Stelle verzeihen.');" onmouseout="tooltip.hide();"><sup>5</sup></a> sollte die globale Plugin-Referenz nur initialisiert werden, sofern sie noch null ist:</p>
<pre class="brush:php">global $footnotes;
if (!$footnotes){
	$footnotes = new nacin_footnotes();
}
</pre>
<p>Resultat sind wie gewünscht in Fußnoten ausgelagerte Quellenangaben der Bildergalerie. Allerdings tritt das Problem doppelter Fußnoten weiterhin auf, sofern auf einer Seite, wie in diesem Beitrag, normale (textbasierte) Fußnoten und Bildergalerien gleichzeitig verwendet werden. Das liegt daran, dass das Plugin Simple Footnotes seinen Content Filter so angelegt hat, dass es sich selbst bzw. besser gesagt eine Instanz von sich selbst dem Filter übergibt:</p>
<pre class="brush:php">add_filter( 'the_content', array( &amp;$this, 'the_content' ), 12 );</pre>
<p>Durch den WordPress-Filter-Registrierumgsmechanismus <a class="simple-footnote" title="Klicken Sie, um zur Fußnote zu springen oder Links in der Fußnote zu folgen." id="return-note-407-6" href="#note-407-6" onmouseover="tooltip.show('Siehe dazu auch Diskussion auf http://stackoverflow.com/questions/1524925/howto-use-the-has-filter-wordpress-function-with-an-object-based-callback.');" onmouseout="tooltip.hide();"><sup>6</sup></a> wird bei jeder neuen Instanz von nacin_footnotes() auch jeweils ein entsprechender Content-Filter eingehängt, was a) inperformant ist und b) dazu führt, dass der Fußnotenblock in seiner Gesamtheit mehrfach am Ende eines Posts angezeigt werden kann. Leider habe ich für dieses Problem keine Optimallösung parat, so dass nur die Anpassung des der Datei simple-footnotes.php des Plugins bleibt. Hier muss ganz am Ende der Datei folgende Änderung durchgeführt werden:</p>
<pre class="brush:php">//new nacin_footnotes();
global $footnotes;
$footnotes = new nacin_footnotes();</pre>
<p>Hierdurch wird sichergestellt, dass das Plugin nur einmal erzeugt wird, egal ob direkt oder über das Gallery-Template. Zusätzlich ist es ggf. noch erforderlich, die folgende Änderung an der shortcode-Funktion des Plugins vorzunehmen. Hierdurch wird sichergestellt, dass die Fußnoten immer korrekt durchgezählt werden und bei 1 beginnen:</p>
<pre class="brush:php">//FO we have to check if the footnote text is already present, otherwise the gallery plugin mechanism will not work (don't know why)
/*
if ( ! isset( $this-&gt;footnotes[$id] ) )
	$this-&gt;footnotes[$id] = array( 0 =&gt; false );
$this-&gt;footnotes[$id][] = $content;
$note = count( $this-&gt;footnotes[$id] ) - 1;
*/
if (!in_array($content,$this-&gt;footnotes[$id])){
	$this-&gt;footnotes[$id][] = $content;
	$note = count( $this-&gt;footnotes[$id] ) - 1;
}
else{
	$note =  array_search($content,$this-&gt;footnotes[$id]);
}</pre>
<p>Ersetzt man nun noch den von NextGEN für die Bildunterschriften verwendeten span-Tag im Gallery-Template nun noch durch den von WordPress standardmäßig genutzten p-Tag der Klasse wp-caption-text und fügt dem ngg-gallery-thumbnail-Container die Klasse wp-caption hinzu, erhält man das folgende &#8222;fertige&#8220; Gallery-Tempalte:</p>
<pre class="brush:php">&lt;?php
/**
Template Page for the gallery overview

Follow variables are useable :

	$gallery     : Contain all about the gallery
	$images      : Contain all images, path, title
	$pagination  : Contain the pagination content

 You can check the content when you insert the tag &lt;?php var_dump($variable) ?&gt;
 If you would like to show the timestamp of the image ,you can use &lt;?php echo $exif['created_timestamp'] ?&gt;
**/

// FO: muss global erzeugt werden, da sonst die Nummerierung für jede Galerie neu beginnt
global $footnotes;
if (!$footnotes){
	$footnotes = new nacin_footnotes();
}
if (!function_exists('imagesourcelink')) {
	function imagesourcelink($text){
		// text starts with http://
		if (strpos($text, "http://") === 0){
			return '&lt;a href="' . $text . '" title="Go to external Source" &gt;' .$text . '&lt;/a&gt;';
		}
		else{
			return $text;
		}
	}
}

/*	FO: Da $gallery-&gt;<a href="https://test.soziotech.org/glossar/id/" class="glossaryLink" title="Klicken Sie, um zum detaillierten Glossareintrag für ID zu springen." onmouseover="tooltip.show('Identifikator oder auch Kennung; ist ein künstlich zugewiesenes Merkmal zur eindeutigen Identifizierung eines Objektes. ');" onmouseout="tooltip.hide();">ID</a> als Group-ID für jQuery Colorbox / Slimbox nur dann funktioniert,
	wenn echte Gallerien verwendet werden, nicht aber bei nggtags (Tag-basierter Auswahl)
	muss hier noch einmal gesondert mitgezählt werden
*/
global $lightboxgroup;
if (!$lightboxgroup){
	$lightboxgroup = 0;
}

?&gt;
&lt;?php if (!defined ('ABSPATH')) die ('No direct access allowed'); ?&gt;&lt;?php if (!empty ($gallery)) : ?&gt;

&lt;div id="&lt;?php echo $gallery-&gt;anchor . $lightboxgroup ?&gt;"&gt;

&lt;?php if ($gallery-&gt;show_slideshow) { ?&gt;
	&lt;!-- Slideshow link --&gt;
	&lt;div&gt;
		&lt;a href="&lt;?php echo $gallery-&gt;slideshow_link ?&gt;"&gt;
			&lt;?php echo $gallery-&gt;slideshow_link_text ?&gt;
		&lt;/a&gt;
	&lt;/div&gt;
&lt;?php } ?&gt;

&lt;?php if ($gallery-&gt;show_piclens) { ?&gt;
	&lt;!-- Piclense link --&gt;
	&lt;div&gt;
		&lt;a href="&lt;?php echo $gallery-&gt;piclens_link ?&gt;"&gt;
			&lt;?php _e('[View with PicLens]','nggallery'); ?&gt;
		&lt;/a&gt;
	&lt;/div&gt;
&lt;?php } ?&gt;

	&lt;!-- Thumbnails --&gt;
	&lt;?php foreach ( $images as $image ) : ?&gt;

	&lt;div id="ngg-image-&lt;?php echo $image-&gt;pid ?&gt;" &lt;?php echo $image-&gt;style ?&gt; &gt;
		&lt;div &gt;
			&lt;a rel="lightbox-&lt;?php echo $lightboxgroup ?&gt;" href="&lt;?php echo $image-&gt;imageURL ?&gt;" title="
			&lt;?php
			echo $image-&gt;description;
			if ($image-&gt;ngg_custom_fields["Source"]){
				echo ', Quelle: ' . $image-&gt;ngg_custom_fields["Source"] . ".";
			}
			?&gt;
			" &lt;?php echo $image-&gt;thumbcode ?&gt; &gt;
				&lt;?php if ( !$image-&gt;hidden ) { ?&gt;
				&lt;img alt="&lt;?php echo $image-&gt;description ?&gt;" src="&lt;?php echo $image-&gt;thumbnailURL ?&gt;" &lt;?php echo $image-&gt;size ?&gt; /&gt;
				&lt;?php } ?&gt;
			&lt;/a&gt;
			&lt;p-caption-text&gt;&lt;?php 

			echo $image-&gt;alttext;

			if ($image-&gt;ngg_custom_fields["Source"]){
				echo ($footnotes-&gt;shortcode('', "Bildquelle: " . imagesourcelink($image-&gt;ngg_custom_fields["Source"]) . "."));
			}

			?&gt;&lt;/p&gt;
		&lt;/div&gt;
	&lt;/div&gt;
	&lt;?php if ( $image-&gt;hidden ) continue; ?&gt;
	&lt;?php if ( $gallery-&gt;columns &gt; 0 &amp;&amp; ++$i % $gallery-&gt;columns == 0 ) { ?&gt;
	&lt;br style="clear: both" /&gt;
	&lt;?php }
	endforeach;
	$lightboxgroup++;
	?&gt;

	&lt;!-- Pagination --&gt;
 	&lt;?php echo $pagination ?&gt;

&lt;/div&gt;

&lt;?php endif; ?&gt;
</pre>
<p>Zusätzlich zu den hier beschriebenen Punkten ist in diesem Template von Zeile 32-39 auch eine Zählervariable für Bildergruppen in Lightboxen, wie beispielsweise <a href="http://www.digitalia.be/software/slimbox" target="_blank" class="link-external">Slimbox </a>oder <a href="http://colorpowered.com/colorbox/" target="_blank" class="link-external">Colorbox </a>enthalten, die es auch bei tagbasierten Galerien ermöglicht, Bilder einer Galerie nacheinander durchzuklicken. Außerdem enthält das Template die Funktion imagesourcelink (Zeile 20-30), die im Source-Feld eingetragene URLs in den Fußnoten automatisch verlinkt.</p>
<h2>Endergebnis</h2>
<p>Das Ergebnis der Bemühungen sieht anschließend wie folgt aus:</p>
<div class="ngg-singlepic wp-caption">
<a rel="lightbox" href="https://test.soziotech.org/wp-content/uploads/wordpress-screenshots/thumbnails-mit-fussnoten.png" title="
			Fertige Galerie basierend auf dem erstellten Gallery-Template mit Verwendung von Fußnoten für die Bildquelle (Source)			" 

 >
	<img src="https://test.soziotech.org/wp-content/uploads/cache/247__614xfloat=_thumbnails-mit-fussnoten.png" alt="Thumbnails mit Fußnoten" title="Thumbnails mit Fußnoten" />
</a>
			<p class="wp-caption-text">Thumbnails mit Fußnoten</p>
</div>

<p>Für den Fall, dass noch kein CSS für die Galerie-Darstellung existiert, sind ggf. noch folgende ergänzenden CSS-Angaben erforderlich, um die Darstellung der Thumbnails gleichmäßig über die Seite zu verteilen. Die Größenangaben basieren hierbei auf einer in NextGEN eingestellten Thumbnail-Größe von 126x100px. Die Pixeldifferenz zu 146px Breite rührt von den CSS-Einstellungen des hier verwendeten Twentyten Child-Themes bzw. den dort vorgegebenen Paddings:</p>
<pre class="brush:css">.ngg-gallery-thumbnail{
	width: 146px;
	height: 160px;
	overflow: hidden;
}
</pre>
<p>Die ggf. erforderlichen Änderungen an der singlepic.php zur Darstellung von Einzelbildern erfolgen analog.</p><img src="https://analytics.flottmedia.com/piwik/piwik.php?idsite=2&amp;rec=1&amp;url=https%3A%2F%2Ftest.soziotech.org%2Fquellenangaben-und-fussnoten-fur-nextgen-gallery%2F&amp;action_name=Quellenangaben+und+Fu%C3%9Fnoten+f%C3%BCr+NextGEN+Gallery&amp;urlref=http%3A%2F%2Ffeeds.feedburner.com%2Fsoziotech" style="border:0;width:0;height:0" width="0" height="0" alt="" /><div class="simple-footnotes"><h2 class="notes">Quellen und Fußnoten:</h2><ol><li id="note-407-1">Downloaddes Plugins im WordPress-Repository unter <a href="http://wordpress.org/extend/plugins/nextgen-gallery/" title="Zum Download von NextGEN Gallery" target="_blank" class="link-external">http://wordpress.org/extend/plugins/nextgen-gallery/</a> <a class="simple-footnote-backlink" href="#return-note-407-1">&#8617;</a></li><li id="note-407-2">Dokumentation unter <a href="http://nextgen-gallery.com/gallery-tags/ " title="Dokumentation des nggtags-Shortcodes" target="_blank" class="link-external">http://nextgen-gallery.com/gallery-tags/</a>. <a class="simple-footnote-backlink" href="#return-note-407-2">&#8617;</a></li><li id="note-407-3">Achtung: Die Leerzeichen innerhalb der eckigen Klammern müssen nach einem Copy &amp; Paste entfernt werden, damit der Shortcode von WordPress ausgeführt wird. <a class="simple-footnote-backlink" href="#return-note-407-3">&#8617;</a></li><li id="note-407-4">Beispielsweise würden mithilfe des Shortcodes [ nggtags gallery=Referenzverwaltung ] alle Bilder angezeigt werden, die mit &#8222;Referenzverwaltung&#8220; verschalgwortet wurden, sowohl aus der Galerie &#8222;Doktorandenseminare&#8220; als auch aus der Galerie &#8222;WordPress Screenshots&#8220; (sowie allen ggf. vorhandenen weiteren Galerien). <a class="simple-footnote-backlink" href="#return-note-407-4">&#8617;</a></li><li id="note-407-5">Informatiker mögen mir die unsaubere Verwendung an dieser Stelle verzeihen. <a class="simple-footnote-backlink" href="#return-note-407-5">&#8617;</a></li><li id="note-407-6"> Siehe dazu auch Diskussion auf <a href="http://stackoverflow.com/questions/1524925/howto-use-the-has-filter-wordpress-function-with-an-object-based-callback" target="_blank" class="link-external">http://stackoverflow.com/questions/1524925/howto-use-the-has-filter-wordpress-function-with-an-object-based-callback</a>. <a class="simple-footnote-backlink" href="#return-note-407-6">&#8617;</a></li></ol></div><div class='yarpp-related-rss'>
<h3>Verwandte Artikel:</h3><ol>
<li><a href="https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/" rel="bookmark" title="Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP">Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP </a></li>
<li><a href="https://test.soziotech.org/wordpress-xml-sitemap-fur-multisite-installationen/" rel="bookmark" title="WordPress XML Sitemap für Multisite-Installationen">WordPress XML Sitemap für Multisite-Installationen </a></li>
<li><a href="https://test.soziotech.org/datenschutzrichtlinien-google-analytics-fur-wordpress/" rel="bookmark" title="Datenschutz &amp; Google Analytics für WordPress">Datenschutz &amp; Google Analytics für WordPress </a></li>
</ol>
</div>
]]></content:encoded>
			<wfw:commentRss>https://test.soziotech.org/quellenangaben-und-fussnoten-fur-nextgen-gallery/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP</title>
		<link>https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/</link>
		<comments>https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/#comments</comments>
		<pubDate>Tue, 11 Jan 2011 16:30:35 +0000</pubDate>
		<dc:creator><![CDATA[Florian Ott]]></dc:creator>
				<category><![CDATA[Dienstintegration]]></category>
		<category><![CDATA[Linux / Apache]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Technologien]]></category>
		<category><![CDATA[Wordpress / Buddypress]]></category>
		<category><![CDATA[Buddypress]]></category>
		<category><![CDATA[Gallery]]></category>
		<category><![CDATA[NextGEN]]></category>
		<category><![CDATA[Rechte]]></category>
		<category><![CDATA[suPHP]]></category>
		<category><![CDATA[Thumbnails]]></category>
		<category><![CDATA[umask]]></category>
		<category><![CDATA[Wordpress]]></category>

		<guid isPermaLink="false">http://sevastyanova.cscwlab.de/?p=89</guid>
		<description><![CDATA[<p><img src="https://test.soziotech.org/wp-content/uploads/cache/228_crop_940x198_suphp-apache.jpg" width="618" height="130" alt="Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP" /></p>Auf unserer Multiblogging-Plattform setzen wir aus Sicherheitsgründen suPHP statt mod_php ein. Einer der großen Vorteile ist, dass Skripte so unter dem Benutzer des jeweiligen vHosts ausgeführt werden und so weder schreibbar noch ausführbar für andere Benutzer sein müssen. Da die &#8230; <a href="https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/">Weiterlesen <span class="meta-nav">&#8594;</span></a><img src="https://analytics.flottmedia.com/piwik/piwik.php?idsite=2&amp;rec=1&amp;url=https%3A%2F%2Ftest.soziotech.org%2Fnicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp%2F&amp;action_name=Nicht+lesbare+Thumbnails+bei+WordPress+%2F+Buddypress+mit+suPHP&amp;urlref=http%3A%2F%2Ffeeds.feedburner.com%2Fsoziotech" style="border:0;width:0;height:0" width="0" height="0" alt="" /><div class='yarpp-related-rss'>
<h3>Verwandte Artikel:</h3><ol>
<li><a href="https://test.soziotech.org/wordpress-xml-sitemap-fur-multisite-installationen/" rel="bookmark" title="WordPress XML Sitemap für Multisite-Installationen">WordPress XML Sitemap für Multisite-Installationen </a></li>
<li><a href="https://test.soziotech.org/jquery-is-not-defined-fehler-im-wordpress-backend/" rel="bookmark" title="&#8222;jQuery is not defined&#8220;-Fehler im WordPress Backend">&#8222;jQuery is not defined&#8220;-Fehler im WordPress Backend </a></li>
</ol>
</div>
]]></description>
				<content:encoded><![CDATA[<p><img src="https://test.soziotech.org/wp-content/uploads/cache/228_crop_940x198_suphp-apache.jpg" width="618" height="130" alt="Nicht lesbare Thumbnails bei WordPress / Buddypress mit suPHP" /></p><p>Auf unserer Multiblogging-Plattform setzen wir aus Sicherheitsgründen suPHP statt mod_php ein. Einer der großen Vorteile ist, dass Skripte so unter dem Benutzer des jeweiligen vHosts ausgeführt werden und so weder schreibbar noch ausführbar für andere Benutzer sein müssen. Da die Dateien dem vHost-Besitzer &#8222;gehören&#8220; genügt für normale Dateien, wie z.B. Bilder, eine Linux-Dateisystem-Berechtigung von umask 644 bzw. -rwxr&#8211;r&#8211; oder auf Deutsch:  Besitzer (vHost owner) darf lesen und schreiben, der Rest &#8211; insbesondere der Apache-User www-data darf nur lesen.</p>
<h2>Das Problem &#8230;</h2>
<p>In der Debian / Ubuntu Default-Konfiguration für von Skripten erstellte Dateien, also z.B. für von WordPress / Buddypress erzeugte Profilbilder oder vom <a href="http://wordpress.org/extend/plugins/nextgen-gallery/" title="Wordpress Plugin NextGEN Gallery" target="_blank" class="link-external">Plugin NextGEN Gallery</a> erstellte Thumbnails, setzt suPHP die Berechtigung 600 bzw. -rw&#8212;&#8212;-, wodurch die Dateien nicht durch den Apache-User gelesen werden können. Das führt i.d.R. zu klassischen 404-Fehlermeldungen beim Zugriff auf die <a href="https://test.soziotech.org/glossar/url/" class="glossaryLink" title="Klicken Sie, um zum detaillierten Glossareintrag für URL zu springen." onmouseover="tooltip.show('Unter URLs (Uniform Resource Locator) versteht man eindeutige menschenlesbare Adressen, die Inhalte wie beispielsweise Webseiten im Internet identifizieren und dadurch zugreifbar machen. URLs werden meist als Internetadressen bezeichnet. ');" onmouseout="tooltip.hide();">URLs</a> oder dazu, dass Bilder einfach nicht dargestellt werden, sondern lediglich deren Alternativtext (sofern überhaupt verfügbar).</p>
<h2>Die Lösung &#8230;</h2>
<p>&#8230; ist prinzipiell relativ einfach. Allerdings ist zur Änderung Zugriff auf die Webserverkonfiguration erforderlich, was jedoch inzwischen aufgrund der immer häufiger genutzten eigenen vServer mit Root-Zugriff vielfach gegeben ist. In diesem Fall muss lediglich der umask-Eintrag der Datei /etc/suphp/suphp.conf von 0077 (entspricht 600 in Oktalnotation) auf 0022 (entspricht 644 in Oktalnotation) geändert werden:</p>
<pre class="brush:cpp">;Umask to set, specify in octal notation
;umask=0077</pre>
<p>Sicherheitshalber ggf. noch den Apache-Prozess neu starten, so dass die Änderungen auch auf jeden Fall übernommen werden und ab sofort sollten von PHP-Prozessen erzeugte Dateien mit den korrekten und v.a. von Apache lesbaren Berechtigungen 644 erzeugt werden:</p>
<pre class="brush:cpp">/etc/init.d/apache2 restart</pre><img src="https://analytics.flottmedia.com/piwik/piwik.php?idsite=2&amp;rec=1&amp;url=https%3A%2F%2Ftest.soziotech.org%2Fnicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp%2F&amp;action_name=Nicht+lesbare+Thumbnails+bei+WordPress+%2F+Buddypress+mit+suPHP&amp;urlref=http%3A%2F%2Ffeeds.feedburner.com%2Fsoziotech" style="border:0;width:0;height:0" width="0" height="0" alt="" /><div class='yarpp-related-rss'>
<h3>Verwandte Artikel:</h3><ol>
<li><a href="https://test.soziotech.org/wordpress-xml-sitemap-fur-multisite-installationen/" rel="bookmark" title="WordPress XML Sitemap für Multisite-Installationen">WordPress XML Sitemap für Multisite-Installationen </a></li>
<li><a href="https://test.soziotech.org/jquery-is-not-defined-fehler-im-wordpress-backend/" rel="bookmark" title="&#8222;jQuery is not defined&#8220;-Fehler im WordPress Backend">&#8222;jQuery is not defined&#8220;-Fehler im WordPress Backend </a></li>
</ol>
</div>
]]></content:encoded>
			<wfw:commentRss>https://test.soziotech.org/nicht-lesbare-thumbnails-bei-wordpress-buddypress-mit-suphp/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
