{"id":1239,"date":"2007-07-11T16:00:01","date_gmt":"2007-07-11T21:00:01","guid":{"rendered":"http:\/\/www.shamusyoung.com\/twentysidedtale\/?p=1239"},"modified":"2007-11-03T11:47:57","modified_gmt":"2007-11-03T16:47:57","slug":"akismet-vs-two-billion-spam","status":"publish","type":"post","link":"https:\/\/www.shamusyoung.com\/twentysidedtale\/?p=1239","title":{"rendered":"Akismet vs. Two Billion Spam"},"content":{"rendered":"<p>Akismet, the anti-spam WordPress plugin, has been around since November 2005.  In that time, the software has dealt with 2 billion spam messages.  What&#8217;s really alarming is the <a href=\"http:\/\/akismet.com\/stats\/\">shape of the curve<\/a>.  To be fair, some of the curve is the result of more and more people using WordPress, and more of those people getting Akismet, but still.<\/p>\n<p>Such a mammoth waste of everyone&#8217;s time and energy for just a tiny bit of money for a miniscule number of people.  <\/p>\n<p>The spam solution <a href=\"?p=1174\">I&#8217;m using<\/a> is still going strong.  It&#8217;s been 2 weeks since the last time I saw a spam.  It&#8217;s been over a month since one slipped by that I had to delete manually.  Given the sheer volume of spam I was getting <a href=\"?p=928\">five months ago<\/a>, and given the fact that this site is <a href=\"?p=1219\">several times larger now<\/a>, I&#8217;m very grateful for how well the CAPTCHA is working. <\/p>\n<p>If you look at the problem from the POV of the spam programmer, there are many ways to make his job harder and more annoying.  You can&#8217;t make it impossible, of course, but the appeal of spam has always been the fact that it is &#8220;free&#8221; for the spammer.  Making it less free might go a long way to making less of it.  Given the normal level of lazyness and stupidity of the average spammer, I think that even CAPTCHA are probably overkill.  <\/p>\n<p>Most spam scripts go right for the wordpress comment-posting script.  Just having this script to have a configuarable name would probably be just as effective as the CAPTCHA solution I&#8217;m using now. <\/p>\n<p>Another technique would be to simply insist that comment POSTS are the result of an honest-to-goodness page load.  Embed a secret number (which changes automatically) into the form as a hidden field, and make sure incoming form submissions contain the number.  The advantage of this would be that it would be seamless and transparent to normal users &#8211; they wouldn&#8217;t even need to enter a CAPTCHA.  The only downside would be if a user loaded the page, and then did something else for a couple of hours, and then came back and left a comment on the open page without reloading it first, then their number would have expired and the system would eat their comment.  The disadvantage for the spammer is that they will have to parse all that HTML on the page if they want their comment to get through.  <\/p>\n","protected":false},"excerpt":{"rendered":"<p>Akismet, the anti-spam WordPress plugin, has been around since November 2005. In that time, the software has dealt with 2 billion spam messages. What&#8217;s really alarming is the shape of the curve. To be fair, some of the curve is the result of more and more people using WordPress, and more of those people getting [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[41,40],"class_list":["post-1239","post","type-post","status-publish","format-standard","hentry","category-general","tag-spam","tag-wordpress"],"_links":{"self":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/1239","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1239"}],"version-history":[{"count":0,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/1239\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1239"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1239"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1239"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}