Monatsarchiv:

Mai 2010

Der Löwe zahnt

Seit ein paar Wochen hab ich für meine Canon 40D das 105mm-Makro-Objektiv von Sigma – das einen maximalen Abbildungsmaßstab von 1:1 bietet, verglichen mit dem Reisezoom-Nebenjob-Makro (dem Tamron 28-300) mit max. 1:3 natürlich „etwas“ besser und spezialisierter –, und (wetterbedingt erst) heute hab ich damit den ersten richtigen Fotospaziergang gemacht – die Fotos werde ich in den nächsten Tagen in drei Beiträgen präsentieren, in diesem ersten gibt’s nur 9x 10x Löwenzahn.

Wie ich gemerkt habe, ist es mitunter hilfreich, die schnelle Serienbildfunktion zu wählen und ein paar Bilder auf einmal zu schießen, denn sowohl der Fotograf als auch der Wind sorgt gerne für Verwacklungen…

» Zur Flickr-Diashow

Außer bei den letzten beiden (in der Reihenfolge hier im Blog) handelt es sich übrigens um die unbearbeiten JPGs direkt aus der Kamera.

IMG_10199

IMG_9991 IMG_10155

IMG_10203

IMG_10175

IMG_10167 IMG_10004

IMG_10198

IMG_10134

IMG_10221

WordPress: Hinweis bei Spam-Falscherkennung

Papierspam ?! Und wieder eine kleine Code-für-das-Blog-Lösung von mir, die zwar nicht unbedingt perfekt ist, aber doch hilfreich sein kann…

Viele sind dem Problem schon begegnet, dass ein Kommentar fälschlicherweise im Spam landet, weil der Spamfilter – sei es das bekannte Akismet (wie bei meinem Blog), sei es ein anderes Plugin oder einfach eine versehentlich zu scharf eingestellte Blacklist – übereifrig ist. Auf meinem Blog kommt so ein false positive im Schnitt alle drei Wochen einmal vor.

Der erfahrene Blogger oder Blogkommentierer weiß, dass er dann i.d.R. einfach darauf warten muss, dass der Blogbetreiber den Kommentar (hoffentlich) herausfischt und freigibt. Der unerfahrenere Kommentierende steht aber nicht selten wie der (Pfingst-)Ochse vor dem Berg, wenn er nach dem Absenden des Kommentars oben auf der Seite landet und auch beim Runterscrollen seinen Kommentar nicht findet; manche versuchen es dann auch erneut, manche kommen vielleicht gar nicht wieder.

Ein Hinweis könnte da helfen – doch WordPress bietet da (anders als bei noch zu moderierenden Kommentaren) keinen. Die normale Schleife, die die Kommentare ausgibt, weiß auch nicht direkt, welcher Kommentar aktuell vom Aufrufenden ist, denn der Teil der URL, in der das steht – #comment-123, was ja insbesondere für die Positionierung der Ansicht im Browser sorgt1 – ist nicht Teil der Anforderung, die der Server sieht, sondern bleibt im Browser.

Nun könnte man vielleicht die Kommentarnummer bei der Weiterleitung nach dem Abschicken auch als &-Parameter in die URL einbauen (und dann in der Ausgabeschleife mit abfragen), doch finde ich das irgendwie unschön – wer weiß, ob dadurch nicht mehrere solche URLs durch die Suchmaschinen geistern. Mir kamen zwei andere Ideen, die ich hier vorstellen will:

Lösung 1: Spam-Kommentar von derselben IP-Adresse?

Die erste Idee: Man schaut nach der Kommentarausgabe nach, ob in den letzten paar Minuten ein Spam-Kommentar von derselben IP-Adresse kam, von der die aktuelle Anfrage kommt. Das sieht dann in einer Funktion für die functions.php des Themes so aus:

function ag_spammed_comment ($gotcomments) {
    global $wpdb, $post;
    $spamcom = $wpdb->get_results ("
        SELECT * FROM $wpdb->comments
        WHERE comment_post_ID = '$post->ID'
          AND comment_author_IP = '".$_SERVER['REMOTE_ADDR']."'
          AND comment_approved = 'spam'
          AND comment_type = ''
          AND TIME_TO_SEC(TIMEDIFF(NOW(),comment_date))<120");
    if ($spamcom) {
        if (!$gotcomments) echo '<ol class="commentlist">';
        foreach ($spamcom as $sc) {
            echo '<li id="comment-'.$sc->comment_ID.'" class="comment caughtasspam">'.
            '<strong>Anscheinend wurde Ihr Kommentar von der Automatik als Spam markiert.</strong><br/>'.
            'Falls das ein Versehen war: bitte etwas Geduld, bis er manuell freigeschaltet wird.'.
            '</li>'."\n";
        }
        if (!$gotcomments) echo '</ol>';
    }
}

Aufzurufen dann in der comments.php mit ag_spammed_comment (true); (in <?php ?> eingeschlossen) nach der Ausgabe der vorhandenen Kommentare und mit false statt true im Zweig für den Fall, dass es noch keine Kommentare gibt – wobei diese Unterscheidung nur nötig ist, wenn man den Hinweis wie einen Kommentar in die ol/ul mit einbinden (und gestalten) will; wer einen separaten div-Block verwenden will, kann sich die Unterscheidung sparen.

Die Klasse .caughtasspam Ist dann natürlich noch in der style.css angemessen (z.B. mit rotem Rahmen) zu formatieren.

Allerdings gibt’s da ein…

Problem: Der Cache

Wer ein Cache-Plugin wie WP Super Cache einsetzt, das die erzeugten Seiten zwischenspeichert, steht dann vor dem Problem, dass dieses – eigentlich sinnvollerweise – den Cache der betroffenen Seite bei einem Spam-Kommentar nicht invalidiert, d.h. noch dieselbe alte Seite ausliefert, ohne dass der Code oben zur Ausführung kommt und seinen Hinweis ausgeben kann.

Eine Lösung dafür: Man ändert das Plugin so, dass Spam-Kommentare (aber nicht Spam-Trackbacks) doch die gecachete Seite löschen. Das geht bei WP Super Cache in wp-cache-phase2.php in der function wp_cache_get_postid_from_comment, wo man nach

} elseif ( $comment['comment_approved'] == 'spam' ) { 

die beiden Zeilen

if ( isset( $GLOBALS[ 'wp_super_cache_debug' ] ) && $GLOBALS[ 'wp_super_cache_debug' ] ) wp_cache_debug( "Spam comment. Don't delete any cache files.", 4 );
return $postid;

durch diese ersetzt:

//--ag: for false-positive message
if ( $comment['comment_type'] == '' ) {
    if ( isset( $GLOBALS[ 'wp_super_cache_debug' ] ) && $GLOBALS[ 'wp_super_cache_debug' ] ) wp_cache_debug( "Spam comment. But update cache for post $postid to allow for false-positive message.", 4 );
    return wp_cache_post_change($postid);
} else {
    if ( isset( $GLOBALS[ 'wp_super_cache_debug' ] ) && $GLOBALS[ 'wp_super_cache_debug' ] ) wp_cache_debug( "Spam trackback. Don't delete any cache files.", 4 );
    return $postid;
}

Dann funktioniert’s auch mit dem Hinweis. Allerdings auf Kosten der Performance, falls zufällig echte Spammer viele Spamkommentare auf eine Seite abzuladen versuchen, die auch häufig von Besuchern aufgerufen wird – was bei den meisten Blogs aber nicht so häufig sein dürfte, denke ich.

Der größere Nachteil ist m.E., dass man ein (weiteres?) Plugin hat, bei dem man bei einem Update aufpassen muss, dass man die Änderungen auch in die neue Version übernimmt. Diesen Aufwand will ich mir sparen, deshalb habe ich hier eine andere Lösung eingebaut:

Lösung 2: JavaScript (mit jQuery)

Diese Lösung funktioniert natürlich nicht, wenn der Kommentator JavaScript deaktiviert hat – ein Nachteil, den ich hier aber in Kauf nehme in der Hoffnung, dass diese Kombination selten genug auftritt – dafür funktioniert sie aber auch, wenn jemand über für jede Anfrage wechselnde Proxy-Server surft.

Hier gibt’s sogar zwei Lösungsvarianten, deren erste ich nur kurz anschneiden will: Man ändert mittels comment_post_redirect-Filter (der von wp-comments-post.php aufgerufen wird) die Ziel-URL so, dass bei einem Spam-Kommentar das #comment-123 durch etwas wie #spammed ersetzt wird, und sorgt dann per JavaScript dafür, dass ein im Theme eingebauter, anfangs auf display: none gesetzter (oder leerer) Hinweisblock eingeblendet (oder mit dem Hinweistext gefüllt) wird, wenn #spammed in der URL vorkommt – denn anders als der Server hat JavaScript auf diesen Teil Zugriff.

Variante 2, die auch hier eingebaut ist, kommt ohne einen solchen Filter aus und schaut einfach nach, ob es ein Element namens #comment-123 auf der (vollständig geladenen) Seite überhaupt gibt. Wenn nicht, wird der Hinweistext eingefügt (durch JavaScript deswegen, damit Suchmaschinen den Hinweis nicht indizieren):

<div id="spammedhint" class="comment caughtasspam" style="display:none;"></div>
<script type="text/javascript">
<!--
var theUrl = document.location.toString();
if (theUrl.match("#comment-")) {
    var theHash = theUrl.substr(theUrl.indexOf("#"));
    if (jQuery(theHash).length==0) {
        jQuery(document).ready(function() {
            jQuery("#spammedhint").html("<strong>Anscheinend wurde Dein Kommentar von der Automatik als Spam markiert.</strong><br/>"+
            "Falls das ein Versehen war: bitte etwas Geduld, bis er manuell freigeschaltet wird.").fadeIn();
            var targetOfs = jQuery("#spammedhint").offset().top;
            jQuery("html,body").animate({scrollTop: targetOfs-20}, 500);
        });
    }
}
//-->
</script>

Die Frage der Existenz wird mit if (jQuery(theHash).length==0) abgefragt, da jQuery() immer ein Objekt zurückliefert und ein ansonsten naheliegendes if (jQuery(theHash)) immer wahr ist. Mit der letzten jQuery-Zeile wird dann innerhalb 500 ms zum Hinweisblock gescrollt (bzw. knapp drüber); mit einer ganz kurzen Zeit gab’s manchmal Probleme, weil das document irgendwie doch noch nicht ganz ready war und der Browser dann an eine andere Stelle zurücksprang. (Kann aber sein, dass das nur beim Neuladen einer Seite, wie man’s beim Testen nunmal macht, passiert.)

Ich habe diesen HTML/JS-Code direkt (und natürlich nicht in <?php ?> eingeschlossen) in die comments.php eingefügt (also nicht in die functions.php ausgelagert), und zwar direkt nach <?php if ('open' == $post->comment_status) : ?> und damit direkt vor die Ausgabe der Eingabefelder.

Auch hier sollte man die Klasse .caughtasspam dann natürlich noch in der style.css angemessen formatieren.

Nun hat auch diese Methode einen Nebeneffekt, der sowohl unerwünschterweise (aber wohl sehr selten) auftritt, wenn jemand irgendwoher einen falschen Link mit einer nicht existierenden bzw. unsinnigen Kommentarnummer hat, als auch erwünschterweise, wenn jemand den Link mit seinem erstmal durchgegangenen Kommentar gebookmarkt hat und dieser nachträglich in den Spameimer geworfen wird, denn dann wird dieser Hinweis auch ausgegeben.

Was es euch auch ermöglicht, diese Funktion einfach zu testen – ich habe hier einen Link für euch vorbereitet. :) Ihr könnt aber auch einen neuen Kommentar schreiben und dort „diesisteinspamtest“ einfügen, dieses Wortkonglomerat hab ich für ebendiesen Zweck auf die Blacklist gesetzt. Aber übertreibt’s nicht, ich muss die schließlich alle freischalten…

Wer kein Cache-Plugin verwendet, kann also die erste Lösung gut verwenden, andernfalls gilt es eben Vor- und Nachteile abzuwägen; ich habe mich wie gesagt für die JavaScript-Lösung entschieden.

Meinungen, Kritik, Anregungen, Probleme, Fragen…?

  1. wer ein fehlerhaftes Theme hat, das diese ID für die Kommentare nicht erzeugt und somit alle Kommentatoren nach dem Kommentieren am Seitenanfang landen, sollte das jetzt endlich auch reparieren… []

Pfütze nass gespritzt

Ausschau haltend Entfernt schnell eure Außerirdische Microchip Implantate, hier kommen die neuesten Suchanfragen-Beantwortungen! Viele borno nakt mit mann frau gibt’s hier aber nicht.

Für die, die’s noch nicht wissen: Mit den grau hinterlegten Suchanfragen haben Leute hierher gefunden, und ich hab sie weder gekürzt noch erweitert noch erfunden.

Pfütze nass gespritzt
Oooh, wie gemein, die arme Pfütze nasszuspritzen! Schäm dich!

lotto statistik bei regen
…wird ganz verschwommen und aufgeweicht.

warum bekomm ich meinen lottogewinn in 500000 euro schritten ausgezahlt
Na solche Sorgen möchte ich auch mal haben…

hat der mond einfluß auf die lottozahlen
Natürlich! Hast du noch nie bemerkt, dass bei Halbmond nur halb so viele Lottozahlen gezogen werden?

wird die skorpion-frau 2010 den lottojackpott knacken
Vielleicht. Aber nur die eine und nicht alle Skorpion-Weibchen.

grenzen jesus
Sagen wir mal so: Das, was ihm ebenso phantasiereich wie realitätsfern zugeschrieben wird, hat wohl wirklich keine Grenzen.

turiner grabtuch elvis
Aber klar! Das muss es sein! Das Geheimnis der Person auf dem Grabtuch ist gelöst!

zahnstocher homöopathie ständig
Ständig Homöopathie? Besser nicht, so viel Zucker ist schädlich sowohl für Zähne als auch für Zahnstocher.

Nasenchakra spirituelle Bedeutung
Das sollte doch wirklich jeder wissen: Das Nasenchakra ist für Muskelkater und Gelenkbeschwerden wichtig! (Schließlich hat die Nase mit Muskelkater und Gelenken genauso viel zu tun wie das ganze Chakrensystem mit der Realität.)

nostradamus sagte italien zum weltmeister 2010 aus
Kommt drauf an, wen du fragst. Frag einfach 10 Nostradamus-„Experten“ und du wirst mindestens 20 Antworten bekommen…

wahrsager 0800
Ein Anruf bei einem Wahrsager mit 0800-Telefonnummer ist höchstens umsonst, aber nicht kostenlos, denn der verlangt die Kohle bestimmt direkt von dir, bevor er dir etwas „wahrsagt“. Und bestimmt mehr, als er über eine 0900-Nummer einziehen könnte.

glückszahlen vom universum
Das Universum hat keine Glückszahlen, weil es ganz ungücklich ist. Unglücklich insbesondere darüber, dass so viele Leute so einen Stuss glauben.

Esoterik Was verändert mein Leben, wenn ich den Geist von Rabbi Löw gesehen habe?
Dann wirst du von einem Golem so gefoult werden, dass du nicht zur WM fahren darfst, also Vorsicht!

bahn telekinese sex energie
Hmm, Telekinese bei der Bahn führt zu Sex auf der Zugtoilette, oder was darf ich mir da vorstellen? Aber Telekinese könnte sicher Energie sparen, wenn man die Züge damit antreibt. Nur die Dieselöl- und Kraftwerk- (und früher Kohle-) Konzerne verhindern diesbezügliche Forschungen natürlich.

Ich trage gerne String bin ich Schwul
Wenn du dich das erst fragen musst, wohl eher nicht.^^ Ansonsten würde ich mal sagen, das Hauptkriterium fürs Schwulsein ist, auf welches Geschlecht du stehst…

3 Ausserirdische frauen suchen Männer Sperma
Da gibt’s bestimmt unzählige Pornos mit so einem Thema. Wenn es auch Außerirdische gibt, die Sperma suchen, das nicht von Männern stammt, machen die aber etwas falsch.

:bye: Und ich mach mich dann auch auf die Suche nach außerirdischen Golems in Grabtüchern…


Foto: Coka – Fotolia.com

Erzähl Deine Hauptplatz

Während der Pfaffenhofener Hauptplatzeröffnung hing am Rathauseingang dieses Plakat:

Plakat mit hinzugefügtem handschriftlichem Text: HIER - Erzähl Deine Hauptplatz

Aber ich hatte keine Lust, meine Hauptplatz zu erzählen. Ich wüsste gar nicht, was ich da sagen soll – dürfte man da nur weibliche Wörter nehmen?

Ernsthaft: Ein paar Meter weiter stand dieses Plakat mit der Variante „Erzähl Deine Geschichte“ – dafür hatte der Schreiber des Tür-Plakats wohl keinen Platz mehr und das auch nicht rechtzeitig bemerkt…

Blogparade: Alter Computer-Kram –
Literatur, Software, Hardware

Blogparade alter Computer-Kram Angeregt durch BeetFreeQs Blogparade „Multimediale Kuriositäten“, die sich Tonträgern, DVDs, Videos, Büchern und Computer-/Videospielen widmet (» mein Beitrag), dachte ich mir, ich veranstalte selber eine Blogparade, die sich auf Computer konzentriert, insbesondere auf diese Fragen:

  • Was ist die älteste Computer-Literatur, die ihr noch habt?
  • Welche alten Originaldisketten oder sonstige Software liegen noch rum?
  • Welches alte Stück Hardware ist tatsächlich noch im Einsatz?

Zu allen drei Themenbereichen könnt ihr sowohl die ältesten, nicht mehr verwendeten und nur noch aus Nostalgie aufgehobenen Stücke nennen als auch die ältesten, die ihr noch benutzt, und ihr müsst auch nicht zu jedem Teilthema ein Stück herauskramen. Ich habe auch nichts dagegen, wenn ihr mehr Wert auf die Kuriosität als aufs Alter legt – bei einer Überschneidung mit BeetFreeQs Parade könnt ihr ja bei beiden mitmachen, wenn er nichts dagegen hat. :)

Gültig sind sowohl Heim- als auch Personal Computer1, aber keine Spielekonsolen, Handys u.ä. Fotos von euren „Schätzen“ wären natürlich auch nett.

Die Blogparade geht bis zum 20. Juni 2010, und es gelten die üblichen Regeln: Schreibt einen Beitrag mit eurem Computer-Kram in eurem Blog2 und verlinkt zu diesem Beitrag; wenn der automatische Trackback nicht kommt, schreibt einen Kommentar mit dem Link, damit ich weiß, wer alles teilnimmt. Das Bild oben dürft ihr für euren Beitrag natürlich auch verwenden.

So, dann legt mal los – auch wenn’s nichts zu gewinnen gibt.^^ Zur Einstimmung zeige ich euch auch gleich meinen Kram:


ROM-Listing CPC innen ROM-Listing CPC Front → Mein ältestes Buch ist dieses ROM-Listing für den guten alten Schneider CPC – ich hatte damals den CPC 664, und wer den ernsthaft (oder verspielt, das aber ernsthaft) und effizient program­mieren wollte, kam um Z80-Assemb­ler, direkte Hard­ware­zugriffe und die im ROM vorhan­denen Routinen nicht herum. Und eben letzteres fand sich – natürlich mit vielen weiteren Infos – in diesem Wälzer von 1986. Eine Beispiel-Doppelseite ist im zweiten Bild zu sehen.

Übrigens gab es damals durchaus Spiele, die schöner waren und flüssiger liefen als so manche Flash-Browserspiele heutzutage…

alte Disketten ← Beim weiteren Stöbern bin ich dann noch auf einige alte DOS-Disketten gestoßen – MS-DOS 6 Update, Novell DOS 7, PTS-DOS 6.4 –, dazu die Entwick­lungs­umgebung Borland Pascal 7, das gelegentlich sogar noch im Einsatz ist – wenn mal kleine DOS-Tools gefragt sind; aber dann muss auch nur der Befehlszeilen-Compiler arbeiten, der integrierte Textmodus-Editor ist mir dann doch zu antiquiert.

Sowie einige alte Spiele auf 5¼“-Disketten, bei denen ich mich frage, warum ich sie noch habe… ob sie noch lesbar wären, wenn ich noch ein Laufwerk dafür hätte?

Tastatur → Das ist eine Cherry G81-8308 mit 24 in 10 Ebenen mit beliebigen Zeichen- bzw. Tasten­druck­folgen programmier­baren Zusatz­tasten (mit Kappe, unter die man eine papierne Beschrif­tung legen kann) – ist zwar von 2002 und damit noch nicht sooo alt, aber anders als hier oder da ein altes Zubehör­teil, das auf einen gelegentlichen Einsatz in einem alten Test-PC wartet (oder ein Handscanner mit ISA-Karte, der noch im Keller versteckt sein könnte), noch (fast) täglich im Einsatz am Haupt-PC.

Die dunkelgraue Handballenauflage ist allerdings von einer anderen Tastatur – passt aber leidlich auch an diese und macht das ganze etwas bequemer.

Nun denn, dann bin ich mal auf eure Auswahl gespannt – wie gesagt und wie ihr seht, müsst ihr nicht zu allen 3×2 Kategorien (Literatur, Software, Hardware, je noch und nicht mehr in Gebrauch) etwas nennen. Ich freue mich auf hoffentlich zahlreiche Beteiligung…

Update 21.6.: » Zur Auswertung

  1. und das beschränkt sich auch nicht auf Intel-Windows-PCs []
  2. wer kein Blog hat, darf auch gern einfach hier kommentieren []