November 2009

Stop blaming us

Occasionally, I see articles like this.

Hackers don’t, as a rule, need to go to such lengths to crack passwords. That’s because most of us fail to follow good security habits. A recent article on PhysOrg cites a study that found people are the weak link in computer security.

This is silly. People don’t need to “follow good security habits” unless they have “security” somewhere in their title. Security is a means to an end, and not the target. The target is to get the job done (or surf the web, or read your emails).

Saying this is not just silly – it’s also dangerous. When experts say “people are the weakest link in computer security”, they remove all responsibility from the security industry to make security better, and easier, for users. Why work on preventing brute-force attacks on passwords? Instead lets force our users to choose a 10 character password including at least 1 number and 1 letter of each case. Oh, and lets prevent those walking security hazards from saving the password in the browser on their malware infested machines. Yeah, that’ll teach them. The article over at suggests I use e$4WruX7 as a password – a most helpful advice if I ever saw one. Here’s a better suggestion for you Jonathan: have the system lock out for 24 hours after 3 failed tries.That will make guessing a simple 6 digit-only PIN take more than 450 years.

Enough with this.  Users are not the weakest link any more than drivers are the weakest link in driving accidents. Sure, if we remove users (or drivers) from the equation, that solves all our problems. But since we can’t do that, lets focus on making seat belts, and airbags, and warning systems. Or easier (not harder!) password systems, better protected servers and better user interface.

Heathrow calling

Here’s a weird spam I got last night:


The route taken through Customs is mainly determined by your point of departure and whether you are bringing into the country more duty payable goods than your free allowance. For those passengers who have flown in from outside the European Community (EC), their baggage will have a white tag and they must pass through either the Red or Green channel according to the amount of duty free goods they have. Those passengers arriving from countries within the EC should use the Blue channel, and their baggage will have green-edged tag.

As part of our routine check and based on the above, we have a consignment in your name; you are advised to come to the office address below

Customs office
Terminal 3
Heathrow Airport

You are required to come with the following:
1. Your ID
2. Diplomatic Tag either white or green-edge tag.
3. Non Inspection document

Your appointment time is 10am GMT, failure to comply; we will have over the matter to Metropolitan and the FBI. I am the officer in charge of your matter.

Thomas Smith
UK Customs
Heathrow Airport

It’s weird, because it contains no advertisement, and no links. There’s nothing “encoded” in it –  it seems to be an old version of this notice.

So why would a spammer waste valuable botnet cycles on sending me the email? The only explanation I could come up with is “a boy who cried wolf” attack. You send this email a few times, and the Baysian filtering systems train themselves that this is a good email (i.e. “ham”). Most Baysian spam filtering systems have a loopback mechanism where spam email is used to train the system further, and ham email is used to teach the system what “good” email is. If this email is seen a few times and considered ham, spam filters will accept something similar to it that contains a link. That link, can be the spam or phishing attack.

Another guess is that it’s simply used to verify email addresses – you read that a scary Customs agent from Heathrow wants you in his office first thing tomorrow morning, and you quickly reply to ask what it’s about; the spammer (whose reply-to address is different than the “From”) gets a confirmation that your email address is valid, maybe with some more details like your phone number. This is a plausible explanation but it seems like too much hard work just to get some valid email addresses.
Any other guesses?

Fuzzing anything that moves

<meta content=" 3.0 (Linux)" name="GENERATOR" /><br /> <style type="text/css"> <!-- @page { margin: 0.79in } P { margin-bottom: 0.08in } A:link { so-language: zxx } --></style> <p style="margin-bottom: 0in">I’m in New Delhi, for the local <a href="(">OWASP Conference</a>. There’s a <a href="">really nice lineup</a> and if you’re in the New Delhi area I highly recommend attending.</p> <p style="margin-bottom: 0in"> <p style="margin-bottom: 0in">I’ll be speaking twice. On Tuesday about blackbox testing. The abstract can be paraphrased from the immortal words of the great fuzzing master Ice-T:</p> <blockquote> <p style="margin-bottom: 0in">If you’re from Mars, and you have inputs, we will fuzz you.</p> </blockquote> <p style="margin-bottom: 0in">(Look up the <a href="">original text</a>, I guarantee it’s worth it)</p> <p style="margin-bottom: 0in"> <p style="margin-bottom: 0in">On Wednesday I’ll be talking a bit about breaking JSON applications, relying on the great research done by Amit Klein, Blueinfy, Jeremiah Grossman, Fortify, and many others.</p> <p style="margin-bottom: 0in"> <p style="margin-bottom: 0in">If you spot any errors in either of my presentations let me know and I will buy you a beer. This offer does not include anything stupid I say while on a discussion panel…</p> <p style="margin-bottom: 0in"> <p style="margin-bottom: 0in"> </div> <ul class="meta bottom"> <li class="cat post-tags"><a href="" rel="category tag">Culture</a> <a href="" rel="category tag">Fuzzing</a> <a href="" rel="category tag">Web</a></li> </ul> <ul class="meta sharer"> <li class="share-on"> <a target="blank" title="Fuzzing+anything+that+moves" href="" onclick="'','twitter','width=450,height=300,left='+(screen.availWidth/2-375)+',top='+(screen.availHeight/2-150)+'');return false;" class="twitter"> <i class="fa fa-twitter-square"></i><span class="i">Twitter</span> </a> </li> <li class="share-on"> <a href="" target="_blank" class=" pinterest offblack"> <i class="fa fa-pinterest-square"></i><span class="i">Pinterest</span> </a> </li> <li class="share-on"> <a target="blank" title="Fuzzing+anything+that+moves" href="" onclick="'','facebook','width=450,height=300,left='+(screen.availWidth/2-375)+',top='+(screen.availHeight/2-150)+'');return false;" class=" facebook "> <i class="fa fa-facebook-square"></i><span class="i">Facebook</span> </a> </li> <li class="share-on"> <a onclick="'','gplusshare','width=450,height=300,left='+(screen.availWidth/2-375)+',top='+(screen.availHeight/2-150)+'');return false;" href="" class=" googleplus offblack"> <i class="fa fa-google-plus-square"></i><span class="i">Google+</span> </a> </li> </ul> </div> </article> <nav class="pagination"> <ul> <li class="older-posts next-last"> <span class="inactive"><i class="fa fa-long-arrow-left"></i> <span>Previous</span></span> </li> <li class="newer-posts next-last"> <a href="" ><span>Next</span> <i class="fa fa-long-arrow-right"></i></a> </li> </ul> </nav> </div> </section> <div class="sidebar" id="subnavigation"> <div class="widget side"> <div class="textwidget"><div class="fb-like" data-href="" data-send="true" data-width="400" data-show-faces="true"></div></div> </div><div class="widget side"> <div class="textwidget"><div id="fb-root"></div> <script>(function(d, s, id) { var js, fjs = d.getElementsByTagName(s)[0]; if (d.getElementById(id)) return; js = d.createElement(s); = id; js.src = "//"; fjs.parentNode.insertBefore(js, fjs); }(document, 'script', 'facebook-jssdk'));</script></div> </div> <div class="widget side"> <h4>Most recent posts</h4> <ul> <li> <a href="">SSD Advisory – Axigen HTML Attachments Cross Site Scripting</a> </li> <li> <a href="">SSD Advisory – ManageEngine Exchange Reporter Plus Auth Bypass / Arbitrary SQL Statement Execution</a> </li> <li> <a href="">SSD Advisory – Internet Explorer 11 Rendering Engine DLL Hijacking</a> </li> <li> <a href="">SSD Advisory – Oracle Endeca Workbench (CAS) Beanshell Script Remote Code Execution / Session Generation Authentication Bypass</a> </li> <li> <a href="">SSD Advisory – Comtrol RTS Configuration Modification and Memory Corruption</a> </li> <li> <a href="">SSD Advisory – OneNote 2007 Arbitrary Code Execution</a> </li> <li> <a href="">SSD Advisory – Trend Micro Threat Intelligence Manager Multiple Vulnerabilities Remote Code Execution</a> </li> <li> <a href="">SSD Advisory – LibreOffice Impress Remote Control Use-after-Free Vulnerability</a> </li> <li> <a href="">SSD Advisory – Adobe Reader Combobox Code Execution</a> </li> <li> <a href="">SSD Advisory – Symantec Critical System Protection Remote Code Execution</a> </li> </ul> </div><div class="widget side"> <div class="textwidget"><BR/><BR/><BR/><BR/><BR/><BR/><BR/></div> </div><div class="widget side"><h4>Archives</h4> <ul> <li><a href=''>July 2015</a></li> <li><a href=''>June 2015</a></li> <li><a href=''>May 2015</a></li> <li><a href=''>January 2015</a></li> <li><a href=''>August 2014</a></li> <li><a href=''>June 2014</a></li> <li><a href=''>May 2014</a></li> <li><a href=''>April 2014</a></li> <li><a href=''>March 2014</a></li> <li><a href=''>February 2014</a></li> <li><a href=''>January 2014</a></li> <li><a href=''>December 2013</a></li> <li><a href=''>November 2013</a></li> <li><a href=''>October 2013</a></li> <li><a href=''>September 2013</a></li> <li><a href=''>August 2013</a></li> <li><a href=''>July 2013</a></li> <li><a href=''>June 2013</a></li> <li><a href=''>May 2013</a></li> <li><a href=''>April 2013</a></li> <li><a href=''>March 2013</a></li> <li><a href=''>February 2013</a></li> <li><a href=''>January 2013</a></li> <li><a href=''>December 2012</a></li> <li><a href=''>November 2012</a></li> <li><a href=''>October 2012</a></li> <li><a href=''>September 2012</a></li> <li><a href=''>August 2012</a></li> <li><a href=''>July 2012</a></li> <li><a href=''>June 2012</a></li> <li><a href=''>May 2012</a></li> <li><a href=''>April 2012</a></li> <li><a href=''>March 2012</a></li> <li><a href=''>February 2012</a></li> <li><a href=''>January 2012</a></li> <li><a href=''>December 2011</a></li> <li><a href=''>November 2011</a></li> <li><a href=''>October 2011</a></li> <li><a href=''>September 2011</a></li> <li><a href=''>August 2011</a></li> <li><a href=''>July 2011</a></li> <li><a href=''>June 2011</a></li> <li><a href=''>May 2011</a></li> <li><a href=''>April 2011</a></li> <li><a href=''>March 2011</a></li> <li><a href=''>February 2011</a></li> <li><a href=''>January 2011</a></li> <li><a href=''>December 2010</a></li> <li><a href=''>November 2010</a></li> <li><a href=''>October 2010</a></li> <li><a href=''>September 2010</a></li> <li><a href=''>August 2010</a></li> <li><a href=''>July 2010</a></li> <li><a href=''>June 2010</a></li> <li><a href=''>May 2010</a></li> <li><a href=''>April 2010</a></li> <li><a href=''>March 2010</a></li> <li><a href=''>February 2010</a></li> <li><a href=''>January 2010</a></li> <li><a href=''>December 2009</a></li> <li><a href=''>November 2009</a></li> <li><a href=''>October 2009</a></li> <li><a href=''>September 2009</a></li> <li><a href=''>August 2009</a></li> <li><a href=''>July 2009</a></li> <li><a href=''>June 2009</a></li> <li><a href=''>May 2009</a></li> <li><a href=''>April 2009</a></li> <li><a href=''>March 2009</a></li> <li><a href=''>February 2009</a></li> <li><a href=''>January 2009</a></li> <li><a href=''>December 2008</a></li> <li><a href=''>November 2008</a></li> <li><a href=''>October 2008</a></li> <li><a href=''>September 2008</a></li> <li><a href=''>August 2008</a></li> <li><a href=''>July 2008</a></li> <li><a href=''>June 2008</a></li> <li><a href=''>May 2008</a></li> <li><a href=''>April 2008</a></li> <li><a href=''>March 2008</a></li> <li><a href=''>February 2008</a></li> <li><a href=''>January 2008</a></li> <li><a href=''>December 2007</a></li> <li><a href=''>November 2007</a></li> <li><a href=''>October 2007</a></li> <li><a href=''>September 2007</a></li> <li><a href=''>August 2007</a></li> <li><a href=''>July 2007</a></li> <li><a href=''>June 2007</a></li> <li><a href=''>May 2007</a></li> <li><a href=''>April 2007</a></li> <li><a href=''>March 2007</a></li> <li><a href=''>February 2007</a></li> <li><a href=''>January 2007</a></li> <li><a href=''>December 2006</a></li> <li><a href=''>November 2006</a></li> <li><a href=''>October 2006</a></li> <li><a href=''>September 2006</a></li> <li><a href=''>August 2006</a></li> <li><a href=''>July 2006</a></li> <li><a href=''>June 2006</a></li> <li><a href=''>May 2006</a></li> <li><a href=''>April 2006</a></li> <li><a href=''>March 2006</a></li> <li><a href=''>February 2006</a></li> <li><a href=''>January 2006</a></li> <li><a href=''>December 2005</a></li> <li><a href=''>November 2005</a></li> <li><a href=''>October 2005</a></li> <li><a href=''>September 2005</a></li> <li><a href=''>August 2005</a></li> <li><a href=''>July 2005</a></li> </ul> </div></div> </div><!-- /content-wrap --> <footer class="main-footer"> <div class="footer-wrap"> <div class="footer-left">© 2015 Textual. Built by <a href="" target="_blank">MeanThemes</a></div> <div class="footer-right"> <a href="#top" id="btt"><i class="fa fa-chevron-up"></i><span class="i">Top</span></a> </div> </div> </footer> </div><!-- /wrap --> <script> var ie9 = false; </script> <!--[if lte IE 9 ]> <script> var ie9 = true; </script> <![endif]--> <script> var mobilePosition = 'right'; </script> <script type='text/javascript' src=''></script> <script type='text/javascript' src=''></script> <script type='text/javascript' src=''></script> <script type='text/javascript' src=''></script> <script type="text/javascript" id="slb_context">/* <![CDATA[ */if ( !!window.jQuery ) {(function($){$(document).ready(function(){if ( !!window.SLB ) { {$.extend(SLB, {"context":["public","user_guest"]});} }})})(jQuery);}/* ]]> */</script> <script> (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','//','ga'); ga('create', 'UA-29522810-1', 'auto'); ga('send', 'pageview'); </script> </body> </html>