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 ↺

Entschuldigung? Hochheben? – Spam-Splitter (7)

Spam? Yukk! Mal wieder eine kleine Sammlung kurioser Spam-Ausschnitte, die keine separaten Beiträge wert sind…

Dass sich eine deutsche Autovermietung vor ein paar Monaten per Bot-Netzwerk durch massenweise Blogs kommentar­gespammt hat, ist höchstens insofern erwähnenswert, als dass aus solchen Quellen sonst meist englisch oder russisch kommt – aber man muss halt mit der Zeit gehen, dachte sich da wohl ein Marketing-Praktikant, der seinen Job hoffentlich los ist…

Den Vogel dieser Art des Marketings schießt mal wieder einer ab, der so für seine eigenen (oder vergleichbare) Dienste wirbt – ob die Preisliste typisch, Wucher oder Dumping ist, kann ich nicht beurteilen, aber vielleicht interessiert sie euch ja:

Sending messages on forums about the world.

Forum Backlink service : Registered + activation + backlink (in profile & signature) : euro10 per 100 forums
Discussion board public message : Registered + activation + public message (article): euro10 per 100 forums
Discussion board private message : Registered + activation + private message to 1000 users discussion board: euro50 per 100 forums (100,000 private mails send)
Forum package : Registered + activation + backlink + public message + private message to 1000 users discussion board: euro60 per 100 forums (100,000 private mails send)

Sollte dieser halbseidene Anbieter tatsächlich noch Skrupel haben? Siehe diese Einschränkung:

We do not do any orders that contain:

1. Anything Illegal
2. Stealing Identities
3. Hacking Accounts
4. Posting negative comments on a profile/group/page
5. Anything E-whoring related: you may use the account after you receive it in any way you please; however, do not ask us to promote anything e-whoring related
6. Misguiding users: we will comment with catchy phrases and gain users’ attention but we will not „lie“, same with messages.

Aber die Bezeichnung „ehrenwerter Spammer“ wird er sich so trotzdem nicht verdienen…

Hochheben?

Ein kurzes Nebenjob-Angebot – also wohl das übliche Geldwäsche-Zeug – kam mit dem Betreff

Lassen Sie uns Ihr Vermoegen hochheben

Aber was soll das bringen? Vor allem wenn man gar kein Vermögen hat?

Und mit simplem Linktausch wird man auch nicht reich – schon gar nicht mit so einem dubiosen wie einem, bei dem jemand auf einem wenig aufwendigen Pseudoblog über Kindergeschenke unter einer eher zu einem Therapiezentrum passenden Domain einen ach so tollen Keyword-Link in einer „Blogroll“ von mittlerweile über 300 Links anbietet. Aber wie man sieht, gibt’s genug Leute, die solch seltsame Nachbarschaft nichts ausmacht. Der Disclaimer am Ende dieser Mail ist auch irgendwie witzig:

PLEASE NOTE THAT THIS IS NOT A SPAM OR AUTOMATED EMAIL, IT’S ONLY A REQUEST FOR A LINK EXCHANGE. YOUR EMAIL ADDRESS HAS NOT BEEN ADDED TO ANY LISTS, AND YOU WILL NOT BE CONTACTED AGAIN.IF YOU’D LIKE TO MAKE SURE WE DON’T CONTACT YOU AGAIN, PLEASE FILL IN THE FOLLOWING FORM: HTTP://WWW.NOMOREMAILS.COM; OR WRITE AN EMAIL TO STOP@NOMOREMAILS.COM . PLEASE ACCEPT OUR APOLOGIES FOR CONTACTING YOU.

Also eine Art Robinson-Liste einer Spammer-Organisation, die keine eigenen Listen führt, sondern „nur“ selber anderswo einkauft, und eine Antwort bzw. einen Eintrag auf dieser „please stop sending me emails“-Website auch noch berücksichtigt? Ja, klar, das glaub ich euch sofort! (Nicht.) Unten auf dieser Website heißt’s auch noch „Your details will not be added to any lists or provided to any third parties.“ Wenn sie jetzt noch erklären würden, wie sie eine Adresse blocken wollen, ohne Listen zu führen…

…und wieso wenige Wochen später eine nahezu identisch formulierte Anfrage – diesmal aber ausgerechnet für zwei Horoskopseiten! – kommt, die als Nicht-Liste stop@stopemails.info und die zugehörige, mit Google Docs aufgebaute Domain verwendet…

(Ich dachte ich sage es dir|Wollte erst nicht Fragen)

Im April gab’s zwei Mails – leider nicht mehr – in denen Extrem-Nymphomaninnen mit Hunderttausenden Freunden die Empfänger mit vermeintlich persönlichen, aber Textbausteine verwendenden „Mitleidsbekundungen“ zum Pillenkauf zu bewegen. Ich hab das hier mal entsprechend zusammengefasst:

Betreff: (Ich dachte ich sage es dir|Wollte erst nicht Fragen)
An: Freund (361323|4272411)

Hallo Du,

mir ist klar, es ist dir (absolut|unsagbar) unangenehm, dass du (neulich|gestern Nacht) so (klaeglich|schmaehlich) versagt hast, als du mich ficken wolltest, aber das finde ich wirklich nicht (schlimm|so tragisch). (Zum einen|Erstens) (passiert|geschieht) das jedem Mann hin und wieder, dass er seinen (Schwanz|Penis) nicht (hoch kriegt|zum Funktionieren bekommt). Du hattest sicher einfach (nur|bloss) (Stress|Sorgen). Und (zweitens|zum zweiten) gibt es etwas, was wir dagegen (machen|tun) koennen, dass es dir noch einmal geschieht. Schau doch mal im Netz nach unter http://[…].spaces.live.com . Da kann man (ohne Probleme|einfach und sicher) so (Tabletten|blaue Pillen) (kaufen|bestellen), die sollen dir (unverzueglich|umgehend) helfen, dass du beim (Poppen|Bumsen) (garantiert|ganz bestimmt) nie wieder (nicht kannst|versagst)! Meine (Freundin|Nachbarin) (sagt|bestaetigt) das auch; bei ihrem (Verlobten|Mann) haben die (sofort gewirkt|ganz toll geholfen), und die zwei treiben es jetzt (taeglich mehrfach|jeden Tag) miteinander! Die solltest du mal sofort ordern!
Wir sehen uns (morgen|in Kürze)

(Sabine|Heidi)

Die einen kommen gar nicht, andere vielleicht zu früh, aber manche viel zu spät – am 16.3., zwei Monate und zwei Tage nach Valentinstag, kam diese Mail:

Betreff: Valentinstag

Gruess Gott, derzeitig beanspruchen wir fur sie ein Hauch ganz aussergewohnliches anzureichen.
Damit haben Sie wieder sehr viel Spass am Liebesleben

Link war allerdings keiner dabei. Wahrscheinlich ist der unterwegs müde geworden…

Rechtschreibfehler mögen keine Sünde sein…

…aber Lügen und Betrügereien wie bei den unzähligen Vorschussbetrügern sind sicher nicht nur Sünden, sondern auch irdisch strafbar. Entsprechend darf sich diese Möchtegern-Prinzessin weder great noch regreat fühlen:

I am writing this letter in confidence believing that if it is the wish of God for you to help me and my family, God almighty will bless and reward you aboundantly and you would never regreat this.
My family and i are true Christian and worship’s God truthfully, […]

Wieso kann Gott da nicht mal einen Blitz in deren Computer einschlagen lassen, so als kleine Warnung vor Höllenstrafen?

Entschuldigung

Oh, schon wieder so lang geworden, diese Spam-Sammlung? Dabei hätte ich doch noch ein paar längere – naja, ein anderes Mal. Enden wir mit einer kurzen Mail von irgendeinem dubiosen Dienst mit „tv“ im Domainnamen, deren Entschuldigung am Ende mit Sicherheit ebenso aufrichtig gemeint ist wie die Behauptung am Anfang, ich hätte die Zugangsdaten selbst angefordert, wahr ist:

Salut Kunde,

hier sind Ihre kostenlosen Benutzerdaten die Sie kürzlich auf unserer Webseite angefordert haben:
[…]
___________________________________________
Möchten Sie keinen Kontakt mehr mit uns, klicken Sie hier zum austragen:
http://www.[…]
Wir entschuldigen uns dafür. Danke.

Wofür „danke“? Glaubt so ein Gesocks wirklich, jemand würde so eine Entschuldigung – um die man übrigens höchstens bitten und sich nicht selbst geben kann – tatsächlich annehmen?


Foto (Orig.): Justin Hall – Fotolia.com