github.com/requaos/go-readability@v0.0.0-20181130134248-61a0ddd715c5/test/getArticleMetadata1.html (about)

     1  <!DOCTYPE html>
     2  <!--[if lt IE 7]> <html lang="en-us" class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
     3  <!--[if IE 7]>    <html lang="en-us" class="no-js lt-ie9 lt-ie8"> <![endif]-->
     4  <!--[if IE 8]>    <html lang="en-us" class="no-js ie8 lt-ie9"> <![endif]-->
     5  <!--[if IE 9]>    <html lang="en-us" class="no-js ie9"> <![endif]-->
     6  <!--[if gt IE 8]><!-->
     7  <html lang="en-us">
     8  <!--<![endif]-->
     9  
    10  <head>
    11      <title>Just-released Minecraft exploit makes it easy to crash game servers | Ars Technica</title>
    12      <script type="text/javascript">
    13          ars = {
    14              "ASSETS": "http:\/\/cdn.arstechnica.net\/wp-content\/themes\/arstechnica\/assets",
    15              "HOME_URL": "http:\/\/arstechnica.com",
    16              "LOGIN_URL": "https:\/\/arstechnica.com\/services\/login-desktop.html?v=1",
    17              "CIVIS": "\/civis",
    18              "THEME": "light",
    19              "VIEW": "grid",
    20              "MOBILE": false,
    21              "PREMIER": false,
    22              "LOGGED": false,
    23              "ENV": "production",
    24              "AD": {
    25                  "kw": ["security", "int"],
    26                  "zone": "int",
    27                  "queue": []
    28              },
    29              "TOTAL": 68014,
    30              "UNREAD": 0,
    31              "RECENT": [659465, 659425, 659391, 659203, 659339, 659209, 659151, 659207, 659257, 659153, 657603, 659157, 659089, 659105, 658987, 658981, 658367, 658019, 658841, 658609, 658117, 658553, 658455, 657769, 658395],
    32              "LOGINS": true,
    33              "CROSS": false,
    34              "GEOALERTS": true,
    35              "PARSELY": "arstechnica.com",
    36              "COMMENTS": false,
    37              "HOMEPAGE": false,
    38              "COUNTRY": "us",
    39              "READY": [],
    40              "SHOW_ADS": true,
    41              "IMG_PROXY": "https:\/\/cdn.arstechnica.net\/i\/",
    42              "CATEGORY": "security"
    43          };
    44      </script>
    45      <!--[if lte IE 8]><script type="text/javascript" src="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/js/modernizr/modernizr.js"></script><![endif]-->
    46      <link rel="stylesheet" type="text/css" media="all" href="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/css/ars.min.55e632421d8225142fe8df15cdfe2a20.css"/>
    47      <link rel="alternate" type="application/rss+xml" href="http://feeds.arstechnica.com/arstechnica/index/"/>
    48      <link rel="shortcut icon" href="https://cdn.arstechnica.net/favicon.ico"/>
    49      <link rel="icon" type="image/x-icon" href="https://cdn.arstechnica.net/favicon.ico"/>
    50      <link rel="apple-touch-icon" sizes="180x180" href="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/images/ars-ios-icon.png"/>
    51      <link rel="icon" sizes="192x192" href="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/images/material-ars.png"/>
    52      <meta name="application-name" content="Ars Technica"/>
    53      <meta name="msapplication-starturl" content="http://arstechnica.com/"/>
    54      <meta name="msapplication-tooltip" content="Ars Technica: Serving the technologist for 1.2 decades"/>
    55      <meta name="msapplication-task" content="name=News;action-uri=http://arstechnica.com/;icon-uri=https://cdn.arstechnica.net/favicon.ico"/>
    56      <meta name="msapplication-task" content="name=Features;action-uri=http://arstechnica.com/features/;icon-uri=https://cdn.arstechnica.net/ie-jump-menu/jump-features.ico"/>
    57      <meta name="msapplication-task" content="name=OpenForum;action-uri=http://arstechnica.com/civis/;icon-uri=https://cdn.arstechnica.net/ie-jump-menu/jump-forum.ico"/>
    58      <meta name="msapplication-task" content="name=Subscribe;action-uri=http://arstechnica.com/subscriptions/;icon-uri=https://cdn.arstechnica.net/ie-jump-menu/jump-subscribe.ico"/>
    59      <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    60      <meta name="advertising" content="ask"/>
    61      <meta property="fb:admins" content="592156917"/>
    62      <meta name="format-detection" content="telephone=no"/>
    63      <meta name="theme-color" content="#000000"/>
    64      <meta name="viewport" content="width=1020"/>
    65      <!-- cache hit 459:single/meta:b3538aec37c1a165d2b4b62bd58e56e3 -->
    66      <meta name="parsely-page" content="{&quot;title&quot;:&quot;Just-released Minecraft exploit makes it easy to crash game servers&quot;,&quot;link&quot;:&quot;http:\/\/arstechnica.com\/security\/2015\/04\/16\/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers\/&quot;,&quot;type&quot;:&quot;post&quot;,&quot;author&quot;:&quot;Dan Goodin&quot;,&quot;post_id&quot;:648287,&quot;pub_date&quot;:&quot;2015-04-16T20:02:01Z&quot;,&quot;section&quot;:&quot;Risk Assessment&quot;,&quot;tags&quot;:[&quot;denial-of-service-attack&quot;,&quot;exploits&quot;,&quot;minecraft&quot;,&quot;vulnerabilities&quot;,&quot;type: report&quot;],&quot;image_url&quot;:&quot;http:\/\/cdn.arstechnica.net\/wp-content\/uploads\/2015\/04\/server-crash-150x150.jpg&quot;}"/>
    67      <meta name="parsely-metadata" content="{&quot;type&quot;:&quot;report&quot;,&quot;title&quot;:&quot;Just-released Minecraft exploit makes it easy to crash game servers&quot;,&quot;post_id&quot;:648287,&quot;lower_deck&quot;:&quot;Two-year-old bug exposes thousands of servers to crippling attack.&quot;,&quot;image_url&quot;:&quot;http:\/\/cdn.arstechnica.net\/wp-content\/uploads\/2015\/04\/server-crash-150x150.jpg&quot;,&quot;listing_image_url&quot;:&quot;http:\/\/cdn.arstechnica.net\/wp-content\/uploads\/2015\/04\/server-crash-300x150.jpg&quot;}"/>
    68      <link rel="canonical" href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/"/>
    69      <link rel="shorturl" href="http://ars.to/1CSWnf5"/>
    70      <meta name="description" content="Two-year-old bug exposes thousands of servers to crippling attack."/>
    71      <meta name="twitter:card" content="summary_large_image"/>
    72      <meta name="twitter:url" content="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/"/>
    73      <meta name="twitter:title" content="Just-released Minecraft exploit makes it easy to crash game servers"/>
    74      <meta name="twitter:description" content="Two-year-old bug exposes thousands of servers to crippling attack."/>
    75      <meta name="twitter:site" content="@arstechnica"/>
    76      <meta name="twitter:domain" content="arstechnica.com"/>
    77      <meta property="og:site_name" content="Ars Technica"/>
    78      <meta name="twitter:image:src" content="http://cdn.arstechnica.net/wp-content/uploads/2015/04/server-crash-640x426.jpg"/>
    79      <meta name="twitter:image:width" content="640"/>
    80      <meta name="twitter:image:height" content="426"/>
    81      <meta name="twitter:creator" content="@dangoodin001"/>
    82      <meta property="og:url" content="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/"/>
    83      <meta property="og:title" content="Just-released Minecraft exploit makes it easy to crash game servers"/>
    84      <meta property="og:image" content="http://cdn.arstechnica.net/wp-content/uploads/2015/04/server-crash-640x426.jpg"/>
    85      <meta property="og:description" content="Two-year-old bug exposes thousands of servers to crippling attack."/>
    86      <meta property="og:type" content="article"/>
    87      <!-- cache hit 459:single/header:b3538aec37c1a165d2b4b62bd58e56e3 -->
    88      <script type="text/javascript" src="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/js/omniture/mbox.js"></script>
    89  </head>
    90  
    91  <body class="single single-post postid-648287 single-format-standard grid-view light blog-us">
    92      <div id="container">
    93          <header id="masthead">
    94              <aside id="ad-top">
    95                  <div id="topBanner728x90_frame"></div>
    96                  <script type="text/javascript">
    97                      ars.AD.queue.push(['topBanner', {
    98                          sz: '728x90',
    99                          kws: [],
   100                          collapse: true
   101                      }]);
   102                  </script>
   103              </aside>
   104              <h1><a href="http://arstechnica.com"><em>Ars</em>Technica</a></h1>
   105              <div id="profile">
   106                  <!-- cache hit 459:header/site-toggle:f8ff57a97275618649c08b2cce8f06a6 -->
   107                  <ul class="site-toggle">
   108                      <li class="site-1 selected"><a href="http://arstechnica.com/?return">Ars Technica</a></li>
   109                      <li class="site-3"><a href="http://arstechnica.co.uk">Ars Technica UK</a></li>
   110                  </ul> <a href="/civis/ucp.php?mode=register" rel="nofollow">Register</a> <a id="login" href="http://arstechnica.com/civis/ucp.php?mode=login&amp;return_to=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F" rel="nofollow">Log in</a> </div>
   111              <nav id="primary">
   112                  <ul>
   113                      <li id="home-icon"> <a href="/"><span>Home</span></a> </li>
   114                      <li class="has-children"> <a href="#">Main Menu</a>
   115                          <div id="main-menu" class="dropdown">
   116                              <div id="sections">
   117                                  <ul class="cat-list">
   118                                      <li class="top-row even">
   119                                          <a class="cat-link" href="/information-technology"> <span class="cat-name">Information Technology</span> <span class="subheading cat-desc">Technology Lab</span> </a>
   120                                      </li>
   121                                      <li class="top-row odd">
   122                                          <a class="cat-link" href="/gadgets"> <span class="cat-name">Product News &amp; Reviews</span> <span class="subheading cat-desc">Gear &amp; Gadgets</span> </a>
   123                                      </li>
   124                                      <li class="even">
   125                                          <a class="cat-link" href="/business"> <span class="cat-name">Business of Technology</span> <span class="subheading cat-desc">Ministry of Innovation</span> </a>
   126                                      </li>
   127                                      <li class="odd">
   128                                          <a class="cat-link" href="/security"> <span class="cat-name">Security &amp; Hacktivism</span> <span class="subheading cat-desc">Risk Assessment</span> </a>
   129                                      </li>
   130                                      <li class="even">
   131                                          <a class="cat-link" href="/tech-policy"> <span class="cat-name">Civilization &amp; Discontents</span> <span class="subheading cat-desc">Law &amp; Disorder</span> </a>
   132                                      </li>
   133                                      <li class="odd">
   134                                          <a class="cat-link" href="/apple"> <span class="cat-name">The Apple Ecosystem</span> <span class="subheading cat-desc">Infinite Loop</span> </a>
   135                                      </li>
   136                                      <li class="even">
   137                                          <a class="cat-link" href="/gaming"> <span class="cat-name">Gaming &amp; Entertainment</span> <span class="subheading cat-desc">Opposable Thumbs</span> </a>
   138                                      </li>
   139                                      <li class="odd">
   140                                          <a class="cat-link" href="/science"> <span class="cat-name">Science &amp; Exploration</span> <span class="subheading cat-desc">The Scientific Method</span> </a>
   141                                      </li>
   142                                      <li class="even">
   143                                          <a class="cat-link" href="/cars"> <span class="cat-name">All Things Automotive</span> <span class="subheading cat-desc">Cars Technica</span> </a>
   144                                      </li>
   145                                  </ul>
   146                              </div>
   147                              <aside class="drop-extras">
   148                                  <style type="text/css">
   149                                      #layout-swap {
   150                                          margin-top: -6px;
   151                                          color: #808f95
   152                                      }
   153                                  </style>
   154                                  <aside id="layout-swap"> <span class="subheading">Layout:</span>
   155                                      <ul>
   156                                          <li class="grid active"> <a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?view=grid"><span>Grid View</span></a> </li>
   157                                          <li class="article"> <a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?view=archive"><span>Article View</span></a> </li>
   158                                      </ul>
   159                                  </aside>
   160                                  <h2 class="subheading notched">Site Theme</h2>
   161                                  <ul id="theme-switch">
   162                                      <li class="light active"> <a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?theme=light"><span class="subheading">Dark on light</span></a> </li>
   163                                      <li class="dark "> <a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?theme=dark"><span class="subheading">Light on dark</span></a> </li>
   164                                  </ul>
   165                                  <div id="explore-ars">
   166                                      <h2 class="subheading notched">Explore Ars</h2>
   167                                      <ul>
   168                                          <!--         <li><a href="/reviews/">Reviews</a></li> -->
   169                                          <li><a href="/video/">Video</a></li>
   170                                          <li><a href="/staff/">Staff Blogs</a></li>
   171                                          <li><a href="/features/">Feature Archive</a></li>
   172                                          <li><a href="/staff-directory/">Staff Directory</a></li>
   173                                          <li><a href="/contact-us/">Contact Us</a></li>
   174                                      </ul>
   175                                  </div>
   176                                  <div id="featured-disciplines">
   177                                      <h2 class="subheading notched">Featured Disciplines</h2>
   178                                      <ul>
   179                                          <li><a href="/discipline/photography/">Photography</a></li>
   180                                          <li><a href="/discipline/productivity/">Productivity</a></li>
   181                                          <li><a href="/discipline/cloud-2/">Cloud</a></li>
   182                                          <!-- <li><a href="/discipline/gadgets-3/">Gadgets</a></li> -->
   183                                          <li><a href="/discipline/tablets-2/">Tablets</a></li>
   184                                      </ul>
   185                                  </div>
   186                              </aside>
   187                          </div>
   188                      </li>
   189                      <li class="has-children" id="my-stories"> <a href="#">My Stories: <span class="unread-count">0</span></a>
   190                          <div class="dropdown">
   191                              <nav class="my-stories-nav first">
   192                                  <h2 class="subheading notched">New Since Last Visit <span class="unread-count"></span></h2>
   193                                  <ol class="new-stories with-numbers"></ol>
   194                                  <footer><a class="subheading" href="#" id="more-unread-stories">See more news stories</a></footer>
   195                              </nav>
   196                              <nav class="my-stories-nav middle">
   197                                  <h2 class="subheading notched">We Recommend</h2>
   198                                  <ol class="recommendations"></ol>
   199                              </nav>
   200                              <nav class="my-stories-nav">
   201                                  <h2 class="subheading notched">My Discussions</h2>
   202                                  <p class="discussions disabled">Log in to track your discussions.</p>
   203                              </nav>
   204                          </div>
   205                      </li>
   206                      <li class="no-children"><a href="http://arstechnica.com/civis/">Forums</a></li>
   207                      <li class="no-children subscribe"> <a href="/subscriptions/">Subscribe</a> </li>
   208                      <li class="no-children"><a href="/jobs/">Jobs</a></li>
   209                      <li class="no-children"><a href="/feature-series/chasing-brilliance/">Ars Consortium</a></li>
   210                      <li id="search-container" class="right inactive">
   211                          <a id="search-switch" href="/search/"></a>
   212                          <form action="/search/" method="GET" id="search_form">
   213                              <input type="hidden" name="ie" value="UTF-8"/>
   214                              <input type="text" name="q" id="hdr_search_input" value=""/>
   215                              <input type="submit" value=""/> </form>
   216                          <style type="text/css">
   217                              table.gstl_50.gssb_c {
   218                                  top: 30px !important;
   219                                  left: 0 !important;
   220                                  width: 100% !important;
   221                              }
   222                          </style>
   223                      </li>
   224                  </ul>
   225              </nav>
   226          </header>
   227          <section id="content" class="clearfix">
   228              <!-- cache hit 459:home/toppost:f3fda06d4fb35e8aa360e369ff702613 -->
   229              <h1 id="archive-head" class="subheading thick-divide-bottom">
   230  	<a href="http://arstechnica.com/security/">	<span class="archive-name">Risk Assessment</span>
   231  		<span class="divider"> / </span>
   232  	<span class="archive-desc">Security &amp; Hacktivism</span>
   233  		</a></h1>
   234              <script type="text/javascript">
   235                  ars.ARTICLE = {
   236                      "url": "http:\/\/arstechnica.com\/security\/2015\/04\/16\/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers\/",
   237                      "short_url": "http:\/\/ars.to\/1CSWnf5",
   238                      "title": "Just-released Minecraft exploit makes it easy to crash game servers",
   239                      "author": 329388,
   240                      "id": 648287,
   241                      "topic": 1280621,
   242                      "pages": 1,
   243                      "current_page": 1,
   244                      "superscroll": false,
   245                      "promoted": [],
   246                      "single_page": false,
   247                      "comments": 75,
   248                      "fullwidth": false
   249                  };
   250              </script>
   251              <article itemscope="" itemtype="http://schema.org/NewsArticle" class="standalone">
   252                  <header>
   253                      <h1 class="heading" itemprop="headline">Just-released <i>Minecraft</i> exploit makes it easy to crash game servers</h1>
   254                      <h2 class="standalone-deck" itemprop="description">Two-year-old bug exposes thousands of servers to crippling attack.</h2>
   255                      <div class="post-meta">
   256                          <p class="byline" itemprop="author creator" itemscope="" itemtype="http://schema.org/Person"> by <a itemprop="url" href="http://arstechnica.com/author/dan-goodin/" rel="author"><span itemprop="name">Dan Goodin</span></a> - <span class="date" data-time="1429214521">Apr 16, 2015 8:02 pm UTC</span> </p>
   257                          <div class="corner-info">
   258                              <ul class="share-buttons">
   259                                  <li class="share-facebook">
   260                                      <a href="https://www.facebook.com/sharer.php?u=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F" target="_blank" data-dialog="400:368"> <span class="share-text">Share</span> </a>
   261                                  </li>
   262                                  <li class="share-twitter">
   263                                      <a href="https://twitter.com/share?text=Just-released+Minecraft+exploit+makes+it+easy+to+crash+game+servers&amp;url=http%3A%2F%2Fars.to%2F1CSWnf5" target="_blank" data-dialog="364:250"> <span class="share-text">Tweet</span> </a>
   264                                  </li>
   265                                  <li class="share-google">
   266                                      <a href="https://plus.google.com/share?url=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F" target="_blank" data-dialog="485:600"> <span class="share-text">Google</span> </a>
   267                                  </li>
   268                                  <li class="share-reddit">
   269                                      <a href="https://www.reddit.com/submit?url=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F&amp;title=Just-released+Minecraft+exploit+makes+it+easy+to+crash+game+servers" target="_blank"> <span class="share-text">Reddit</span> </a>
   270                                  </li>
   271                              </ul> <a title="51 posters participating" class="comment-count" href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?comments=1"><span>75</span></a> </div>
   272                      </div>
   273                  </header>
   274                  <section id="article-guts">
   275                      <div itemprop="articleBody" class="article-content clearfix">
   276                          <figure class="intro-image image center full-width" style="width:640px"> <img src="http://cdn.arstechnica.net/wp-content/uploads/2015/04/server-crash-640x426.jpg" width="640" height="331"/>
   277                              <figcaption class="caption">
   278                                  <div class="caption-credit"> <a rel="nofollow" href="https://en.wikipedia.org/wiki/Kernel_panic#/media/File:Kernel-panic.jpg">Kevin</a> </div>
   279                              </figcaption>
   280                          </figure>
   281                          <!-- cache hit 459:single/related:1ad28a5dc0a24868be6b031b5fdecb2e -->
   282                          <!-- empty -->
   283                          <p>A flaw in the wildly popular online game <em>Minecraft</em> makes it easy for just about anyone to crash the server hosting the game, according to a computer programmer who has released proof-of-concept code that exploits the vulnerability.</p>
   284                          <p>"I thought a lot before writing this post," Pakistan-based developer Ammar Askar wrote in a <a href="http://blog.ammaraskar.com/minecraft-vulnerability-advisory">blog post published Thursday</a>, 21 months, he said, after privately reporting the bug to <em>Minecraft</em> developer Mojang. "On the one hand I don't want to expose thousands of servers to a major vulnerability, yet on the other hand Mojang has failed to act on it."</p>
   285                          <p>The bug resides in the <a href="https://github.com/ammaraskar/pyCraft">networking internals of the <em>Minecraft </em>protocol</a>. It allows the contents of inventory slots to be exchanged, so that, among other things, items in players' hotbars are displayed automatically after logging in. <em>Minecraft</em> items can also store arbitrary metadata in a file format known as <a href="http://wiki.vg/NBT">Named Binary Tag (NBT)</a>, which allows complex data structures to be kept in hierarchical nests. Askar has released <a href="https://github.com/ammaraskar/pyCraft/tree/nbt_exploit">proof-of-concept attack code</a> he said exploits the vulnerability to crash any server hosting the game. Here's how it works.</p>
   286                          <blockquote>
   287                              <p>The vulnerability stems from the fact that the client is allowed to send the server information about certain slots. This, coupled with the NBT format’s nesting allows us to <em>craft</em> a packet that is incredibly complex for the server to deserialize but trivial for us to generate.</p>
   288                              <p>In my case, I chose to create lists within lists, down to five levels. This is a json representation of what it looks like.</p>
   289                              <div class="highlight"> <pre><code class="language-javascript" data-lang="javascript"><span class="nx">rekt</span><span class="o">:</span> <span class="p">{</span>
   290      <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   291          <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   292              <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   293                  <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   294                      <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   295                          <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   296                          <span class="p">]</span>
   297                          <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   298                          <span class="p">]</span>
   299                          <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   300                          <span class="p">]</span>
   301                          <span class="nx">list</span><span class="o">:</span> <span class="p">[</span>
   302                          <span class="p">]</span>
   303                          <span class="p">...</span>
   304                      <span class="p">]</span>
   305                      <span class="p">...</span>
   306                  <span class="p">]</span>
   307                  <span class="p">...</span>
   308              <span class="p">]</span>
   309              <span class="p">...</span>
   310          <span class="p">]</span>
   311          <span class="p">...</span>
   312      <span class="p">]</span>
   313      <span class="p">...</span>
   314  <span class="p">}</span></code></pre> </div>
   315                              <p>The root of the object, <code>rekt</code>, contains 300 lists. Each list has a list with 10 sublists, and each of those sublists has 10 of their own, up until 5 levels of recursion. That’s a total of <code>10^5 * 300 = 30,000,000</code> lists.</p>
   316                              <p>And this isn’t even the theoretical maximum for this attack. Just the nbt data for this payload is 26.6 megabytes. But luckily Minecraft implements a way to compress large packets, lucky us! zlib shrinks down our evil data to a mere 39 kilobytes.</p>
   317                              <p>Note: in previous versions of Minecraft, there was no protocol wide compression for big packets. Previously, NBT was sent compressed with gzip and prefixed with a signed short of its length, which reduced our maximum payload size to <code>2^15 - 1</code>. Now that the length is a varint capable of storing integers up to <code>2^28</code>, our potential for attack has increased significantly.</p>
   318                              <p>When the server will decompress our data, it’ll have 27 megs in a buffer somewhere in memory, but that isn’t the bit that’ll kill it. When it attempts to parse it into NBT, it’ll create java representations of the objects meaning suddenly, the sever is having to create several million java objects including ArrayLists. This runs the server out of memory and causes tremendous CPU load.</p>
   319                              <p>This vulnerability exists on almost all previous and current Minecraft versions as of 1.8.3, the packets used as attack vectors are the <a href="http://wiki.vg/Protocol#Player_Block_Placement">0x08: Block Placement Packet</a> and <a href="http://wiki.vg/Protocol#Creative_Inventory_Action">0x10: Creative Inventory Action</a>.</p>
   320                              <p>The fix for this vulnerability isn’t exactly that hard, the client should never really send a data structure as complex as NBT of arbitrary size and if it must, some form of recursion and size limits should be implemented.</p>
   321                              <p>These were the fixes that I recommended to Mojang 2 years ago.</p>
   322                          </blockquote>
   323                          <p>Ars is asking Mojang for comment and will update this post if company officials respond.</p>
   324                      </div>
   325                      <div class="article-expander">
   326                          <p><a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/">Expand full story</a></p>
   327                      </div>
   328                  </section>
   329                  <div id="article-footer-wrap">
   330                      <section id="comments-area">
   331                          <a name="comments-bar"></a>
   332                          <div class="comments-bar"> <a class="subheading comments-read-link" href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?comments=1"><span class="text">Reader comments</span> <span class="comment-count"><span proptype="">75</span></span></a> </div>
   333                          <div id="comments-container"></div>
   334                          <div id="comments-posting-container" class="thick-divide-bottom">
   335                              <p id="reply">You must <a href="/civis/ucp.php?mode=login" class="vote_login">login or create an account</a> to comment.</p>
   336                          </div>
   337                      </section>
   338                      <aside class="thin-divide-bottom">
   339                          <ul class="share-buttons">
   340                              <li class="share-facebook">
   341                                  <a href="https://www.facebook.com/sharer.php?u=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F" target="_blank" data-dialog="400:368"> <span class="share-text">Share</span>
   342                                      <div class="share-count-container">
   343                                          <div class="share-count">-</div>
   344                                      </div>
   345                                  </a>
   346                              </li>
   347                              <li class="share-twitter">
   348                                  <a href="https://twitter.com/share?text=Just-released+Minecraft+exploit+makes+it+easy+to+crash+game+servers&amp;url=http%3A%2F%2Fars.to%2F1CSWnf5" target="_blank" data-dialog="364:250"> <span class="share-text">Tweet</span>
   349                                      <div class="share-count-container">
   350                                          <div class="share-count">-</div>
   351                                      </div>
   352                                  </a>
   353                              </li>
   354                              <li class="share-google">
   355                                  <a href="https://plus.google.com/share?url=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F" target="_blank" data-dialog="485:600"> <span class="share-text">Google</span>
   356                                      <div class="share-count-container">
   357                                          <div class="share-count">-</div>
   358                                      </div>
   359                                  </a>
   360                              </li>
   361                              <li class="share-reddit">
   362                                  <a href="https://www.reddit.com/submit?url=http%3A%2F%2Farstechnica.com%2Fsecurity%2F2015%2F04%2F16%2Fjust-released-minecraft-exploit-makes-it-easy-to-crash-game-servers%2F&amp;title=Just-released+Minecraft+exploit+makes+it+easy+to+crash+game+servers" target="_blank"> <span class="share-text">Reddit</span>
   363                                      <div class="share-count-container">
   364                                          <div class="share-count">-</div>
   365                                      </div>
   366                                  </a>
   367                              </li>
   368                          </ul>
   369                      </aside>
   370                      <!-- cache hit 459:single/author:ec67ae7d8397f22698e2822e36453902 -->
   371                      <section class="article-author clearfix-redux">
   372                          <a href="/author/dan-goodin"><img width="47" height="47" src="http://cdn.arstechnica.net/wp-content/uploads/authors/Dan-Goodin-sq.jpg"/></a>
   373                          <p><a href="/author/dan-goodin" class="author-name">Dan Goodin</a> / Dan is the Security Editor at Ars Technica, which he joined in 2012 after working for The Register, the Associated Press, Bloomberg News, and other publications.</p>
   374                      </section>
   375                      <table class="post-links thick-divide-top thin-divide-bottom clearfix-redux" cellspacing="0" cellpadding="0" border="0" width="100%">
   376                          <tbody>
   377                              <tr>
   378                                  <td width="50%" class="subheading older"> <a href="http://arstechnica.com/tech-policy/2015/04/16/dozens-of-us-government-online-whistleblower-sites-not-secured-by-https/" rel="prev"><span class="arrow">←</span> Older Story</a> </td>
   379                                  <td class="subheading newer"> <a href="http://arstechnica.com/gaming/2015/04/16/hidden-files-suggest-street-fighters-ryu-may-come-to-smash-bros/" rel="next">Newer Story <span class="arrow">→</span></a> </td>
   380                              </tr>
   381                          </tbody>
   382                      </table>
   383                      <footer id="article-footer">
   384                          <div id="instream300x255_frame"></div>
   385                          <script type="text/javascript">
   386                              ars.AD.queue.push(['instream', {
   387                                  sz: '300x255',
   388                                  kws: ["blogvertorial", "inStream"],
   389                                  collapse: true
   390                              }]);
   391                          </script>
   392                          <h2 class="subheading notched">You May Also Like</h2>
   393                          <ul id="recommendations" class="clearfix-redux">
   394                              <!-- cache miss 459:single/sponsored-recs:885d56085f538f75cf5e9bcb302f399f -->
   395                          </ul>
   396                      </footer>
   397                  </div>
   398              </article>
   399              <section id="article-sidebar" class="column-1 right">
   400                  <!-- cache hit 459:column/article-bottom:b3538aec37c1a165d2b4b62bd58e56e3 -->
   401                  <aside class="side-ad thick-divide-bottom">
   402                      <div id="xrailTop300x250_frame"></div>
   403                      <script type="text/javascript">
   404                          ars.AD.queue.push(['xrailTop', {
   405                              sz: '300x250',
   406                              kws: ["top"],
   407                              collapse: true
   408                          }]);
   409                      </script>
   410                  </aside>
   411                  <h2 id="recent-featured-title" class="subheading notched">Latest Feature Story</h2>
   412                  <ul class="column">
   413                      <li class="post" id="post-658367">
   414                          <article class="in-column" data-post-id="658367">
   415                              <a href="http://arstechnica.com/apple/2015/05/03/review-the-absolutely-optional-apple-watch-and-watch-os-1-0/" class="headline-image"> <img src="http://cdn.arstechnica.net/wp-content/uploads/2015/05/DSC00588-300x100.jpg" width="300" height="100"/>
   416                                  <h2 class="page-count subheading">Feature Story (7 pages)</h2>
   417                                  <h1 class="heading">Review: The absolutely optional Apple Watch and Watch OS 1.0</h1> </a>
   418                              <p class="excerpt">A pragmatist's guide to a nice but not quite necessary gadget.</p>
   419                          </article>
   420                      </li>
   421                      <aside class="thick-divide-top">
   422                          <h2 class="subheading notched">Watch Ars Video</h2>
   423                          <article class="in-column">
   424                              <div class="column-video" data-player="2196096102001" data-video="4202322531001" data-key="AQ~~,AAAAlDCBGhk~,VcmqiTAuekrwPweJ20LLt7jwm8LxmhCE"> <img src="https://cdn.arstechnica.net/i/http://brightcove.vo.llnwd.net/v1/unsecured/media/636468927001/201504/641/636468927001_4202397654001_LG-G4.jpg?pubId=636468927001" width="300" height="169"/>
   425                                  <div class="column-video-overlay"></div>
   426                              </div> <a href="http://arstechnica.com/gadgets/2015/04/28/hands-on-with-the-leather-backed-lg-g4/"><h1 class="heading videohead">Hands-on with the New LG G4</h1></a>
   427                              <p class="excerpt">LG goes with a wild rear design and a Snapdragon 808.</p>
   428                          </article>
   429                      </aside>
   430                      <li id="in-the-know">
   431                          <h2 class="subheading notched">Stay in the know with</h2>
   432                          <ul class="social clearfix">
   433                              <li class="fb">
   434                                  <a href="https://www.facebook.com/arstechnica"></a>
   435                              </li>
   436                              <li class="twit">
   437                                  <a href="https://twitter.com/arstechnica"></a>
   438                              </li>
   439                              <li class="gplus">
   440                                  <a href="https://plus.google.com/+ArsTechnica/posts"></a>
   441                              </li>
   442                              <li class="email">
   443                                  <a href="http://arstechnica.us1.list-manage.com/subscribe?u=af7f013bad7e785d15aab736f&amp;id=0adf3ee3d9"></a>
   444                              </li>
   445                              <li class="rss">
   446                                  <a href="/rss-feeds/"></a>
   447                              </li>
   448                          </ul>
   449                      </li>
   450                      <h2 class="subheading notched">Latest News</h2>
   451                      <ol class="rail latest-stories">
   452                          <li>
   453                              <a href="http://arstechnica.com/information-technology/2015/05/04/microsoft-bangs-the-cybersecurity-drum-with-advanced-threat-analytics/">
   454                                  <h2>Protecting networks from your own employees</h2>
   455                                  <h1 class="heading">Microsoft bangs the cybersecurity drum with Advanced Threat Analytics</h1> </a>
   456                          </li>
   457                          <li>
   458                              <a href="http://arstechnica.com/information-technology/2015/05/04/windows-update-for-business-brings-windows-updates-to-your-business/">
   459                                  <h2>WUB WUB WUB WUB</h2>
   460                                  <h1 class="heading">Windows Update for Business brings Windows updates to your business</h1> </a>
   461                          </li>
   462                          <li>
   463                              <a href="http://arstechnica.com/security/2015/05/04/super-secretive-malware-wipes-hard-drive-to-prevent-analysis/">
   464                                  <h2>INITIATE SELF-DESTRUCT SEQUENCE</h2>
   465                                  <h1 class="heading">Super secretive malware wipes hard drive to prevent analysis</h1> </a>
   466                          </li>
   467                          <li>
   468                              <a href="http://arstechnica.com/gaming/2015/05/04/failed-christian-shoe-promoter-makes-anti-gay-first-person-shooter/"> <img src="http://cdn.arstechnica.net/wp-content/uploads/2015/05/Screen-Shot-2015-05-04-at-2.45.22-PM-150x150.png" width="50" height="50"/>
   469                                  <h1 class="heading">Failed Christian shoe promoter makes anti-gay first-person shooter</h1> </a>
   470                          </li>
   471                          <li>
   472                              <a href="http://arstechnica.com/information-technology/2015/05/04/prime-minister-of-singapore-shares-his-c-code-for-sudoku-solver/">
   473                                  <h2>#include stdio.h</h2>
   474                                  <h1 class="heading">Prime Minister of Singapore shares his C++ code for Sudoku solver</h1> </a>
   475                          </li>
   476                          <li>
   477                              <a href="http://arstechnica.com/tech-policy/2015/05/04/9th-circuit-judges-rip-into-prenda-law-copyright-trolling-scheme/"> <img src="http://cdn.arstechnica.net/wp-content/uploads/2015/05/Screen-Shot-2015-05-04-at-11.09.05-AM-150x150.png" width="50" height="50"/>
   478                                  <h1 class="heading">9th Circuit judges rip into Prenda law copyright trolling scheme</h1> </a>
   479                          </li>
   480                          <div style="display:none">
   481                              <div id="polar195x130_frame"></div>
   482                              <script type="text/javascript">
   483                                  ars.AD.queue.push(['polar', {
   484                                      sz: '195x130',
   485                                      kws: [],
   486                                      collapse: true
   487                                  }]);
   488                              </script>
   489                          </div>
   490                      </ol>
   491                      <li>
   492                          <aside class="side-ad">
   493                              <div id="xrailBottom300x250_frame"></div>
   494                              <script type="text/javascript">
   495                                  ars.AD.queue.push(['xrailBottom', {
   496                                      sz: '300x250',
   497                                      kws: ["bottom"],
   498                                      collapse: true
   499                                  }]);
   500                              </script>
   501                          </aside>
   502                      </li>
   503                      <li class="thick-divide-top thick-divide-bottom">
   504                          <aside class="side-ad">
   505                              <script type="text/javascript" language="JavaScript">
   506                                  // <![CDATA[
   507                                  google_ad_client = 'ca-conde_arstechnica';
   508                                  google_ad_channel = 'ars_technica_standard_a';
   509                                  google_language = 'en';
   510                                  google_ad_width = '300';
   511                                  google_ad_height = '250';
   512                                  google_ad_type = 'text';
   513                                  google_encoding = 'utf8';
   514                                  google_safe = 'high';
   515                                  google_adtest = 'off';
   516                                  google_ad_format = '';
   517                                  google_ad_section = 'default';
   518                                  // ]]>
   519                              </script>
   520                              <script type="text/javascript" src="//pagead2.googlesyndication.com/pagead/show_ads.js" language="JavaScript"></script>
   521                          </aside>
   522                      </li>
   523                  </ul>
   524              </section>
   525          </section>
   526          <footer id="page-footer">
   527              <nav id="footer-nav" class="clearfix">
   528                  <div class="nav-section">
   529                      <h2 class="subheading">Site Links</h2>
   530                      <ul>
   531                          <li><a href="/about-us/">About Us</a></li>
   532                          <li><a href="/advertise-with-us/">Advertise with us</a></li>
   533                          <li><a href="/contact-us/">Contact Us</a></li>
   534                          <li><a href="/reprints/">Reprints</a></li>
   535                      </ul>
   536                      <h2 class="subheading">Subscriptions</h2>
   537                      <ul>
   538                          <li><a href="/subscriptions/">Subscribe to Ars</a></li>
   539                      </ul>
   540                  </div>
   541                  <div class="nav-section">
   542                      <h2 class="subheading">More Reading</h2>
   543                      <ul>
   544                          <li><a href="/rss-feeds/">RSS Feeds</a></li>
   545                          <li><a href="/newsletters/">Newsletters</a></li>
   546                      </ul>
   547                  </div>
   548                  <div class="nav-section">
   549                      <h2 class="subheading">Conde Nast Sites</h2>
   550                      <ul class="conde-nast-sites">
   551                          <li><a href="http://www.reddit.com/">Reddit</a></li>
   552                          <li><a href="http://www.wired.com/">Wired</a></li>
   553                          <li><a href="http://www.vanityfair.com/">Vanity Fair</a></li>
   554                          <li><a href="http://www.style.com/">Style</a></li>
   555                          <li><a href="http://www.details.com/">Details</a></li>
   556                      </ul>
   557                      <form method="get" action="#">
   558                          <select id="mag_list" name="mag_list" onchange="(this.options[this.selectedIndex].value) ? (window.location = this.options[this.selectedIndex].value) : null">
   559                              <option value="" selected="selected">Visit our sister sites</option>
   560                              <option value="">- - - - - - - - - - - - - -</option>
   561                              <option value="http://www.gq.com">GQ</option>
   562                              <option value="http://www.concierge.com">Concierge</option>
   563                              <option value="http://www.epicurious.com">Epicurious</option>
   564                              <option value="http://men.style.com">Men.Style.com</option>
   565                              <option value="http://www.style.com">Style.com</option>
   566                              <option value="http://www.wired.com">Wired.com</option>
   567                              <option value="http://www.lipstick.com">Lipstick.com</option>
   568                              <option value="http://www.nutritiondata.com">NutritionData</option>
   569                              <option value="http://www.allure.com">Allure</option>
   570                              <option value="http://www.architecturaldigest.com">Architectural Digest</option>
   571                              <option value="http://www.bonappetit.com">Bon Appétit</option>
   572                              <option value="http://www.brides.com">Brides</option>
   573                              <option value="http://www.portfolio.com">Condé Nast Portfolio</option>
   574                              <option value="http://www.glamour.com">Glamour</option>
   575                              <option value="http://www.golfdigest.com">Golf Digest</option>
   576                              <option value="http://www.golfworld.com">Golf World</option>
   577                              <option value="http://www.luckymag.com">Lucky</option>
   578                              <option value="http://www.self.com">Self</option>
   579                              <option value="http://www.teenvogue.com">Teen Vogue</option>
   580                              <option value="http://www.newyorker.com">The New Yorker</option>
   581                              <option value="http://www.vanityfair.com">Vanity Fair</option>
   582                              <option value="http://www.wmagazine.com">W</option>
   583                          </select>
   584                      </form>
   585                      <form method="get" action="#">
   586                          <select size="1" id="sub_list" name="sub_list" onchange="(this.options[this.selectedIndex].value) ? (window.location = this.options[this.selectedIndex].value) : null">
   587                              <option value="" selected="selected">Subscribe to a magazine</option>
   588                              <option value="http://www.magazinestoresubscriptions.com?source=univdropdown">View All Titles</option>
   589                              <option value="">- - - - - - - - - - - - - -</option>
   590                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Allure?source=SITEFOOTER">Allure</option>
   591                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_ArchitecturalDigest">Architectural Digest</option>
   592                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_BonAppetite?source=SITEFOOTER">Bon Appétit</option>
   593                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Brides?source=SITEFOOTER">Brides</option>
   594                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_CondeNastPortfolio?source=SITEFOOTER">Condé Nast Portfolio</option>
   595                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_CondeNastTraveler?source=SITEFOOTER">Condé Nast Traveler</option>
   596                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Details?source=SITEFOOTER">Details</option>
   597                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_ElegantBride?source=SITEFOOTER">Elegant Bride</option>
   598                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Glamour?source=SITEFOOTER">Glamour</option>
   599                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_GolfDigest?source=SITEFOOTER">Golf Digest</option>
   600                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_GolfWorld?source=SITEFOOTER">Golf World</option>
   601                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_GQ?source=SITEFOOTER">GQ</option>
   602                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Lucky?source=SITEFOOTER">Lucky</option>
   603                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_ModernBride?source=SITEFOOTER">Modern Bride</option>
   604                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Self?source=SITEFOOTER">Self</option>
   605                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_TeenVogue?source=SITEFOOTER">Teen Vogue</option>
   606                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_NewYorker?source=SITEFOOTER">The New Yorker</option>
   607                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_VanityFair?source=SITEFOOTER">Vanity Fair</option>
   608                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Vogue?source=SITEFOOTER">Vogue</option>
   609                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_W?source=SITEFOOTER">W</option>
   610                              <option value="https://www.magazinestoresubscriptions.com/webapp/wcs/stores/servlet/Subscriptions_Wired?source=SITEFOOTER">Wired</option>
   611                          </select>
   612                      </form>
   613                  </div>
   614                  <div class="nav-section" id="mobile-site">
   615                      <h2 class="subheading"><a href="http://arstechnica.com/security/2015/04/16/just-released-minecraft-exploit-makes-it-easy-to-crash-game-servers/?view=mobile">View Mobile Site</a></h2> </div>
   616              </nav>
   617              <p style="text-align:center;margin-top:30px;margin-bottom:0">
   618                  <a href="http://condenast.com"><img src="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/images/condenast-logo.png" width="131" height="19"/></a>
   619              </p>
   620              <div id="copyright-terms"> © 2015 Condé Nast. All rights reserved
   621                <br/> Use of this Site constitutes acceptance of our <a href="http://www.condenast.com/privacy-policy" target="_blank">User Agreement</a> (effective 1/2/14) and <a href="http://www.condenast.com/privacy-policy#privacypolicy" target="_blank">Privacy Policy</a> (effective 1/2/14), and <a href="/amendment-to-conde-nast-user-agreement-privacy-policy/">Ars Technica Addendum (effective 5/17/2012)</a>
   622                <br/> <a href="http://www.condenast.com/privacy-policy#privacypolicy-california" target="_blank">Your California Privacy Rights</a>
   623                <br/> The material on this site may not be reproduced, distributed, transmitted, cached or otherwise used, except with the prior written permission of Condé Nast.
   624                <br/>
   625                <br/> <a href="http://www.condenast.com/privacy-policy#privacypolicy-optout" target="_blank">Ad Choices</a><img width="10" height="10" border="0" src="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/images/ad_choices_arrow.png"/> </div>
   626          </footer>
   627      </div>
   628      <script type="text/javascript" src="//www.google.com/jsapi?autoload={'modules':[{'name':'search','version':'1','packages':[],'language':'en'}]}"></script>
   629      <script type="text/javascript" src="http://cdn.arstechnica.net/wp-content/themes/arstechnica/assets/js/ars.min.4963c9cfd2e7a5799f3b8c40325988b4.js"></script>
   630      <!-- what the christ -->
   631      <script type="text/javascript" src="//www.googletagservices.com/tag/js/gpt.js"></script>
   632      <script type="text/javascript" src="http://cdn.arstechnica.net/ads/js/cn.dart.bun.min.js"></script>
   633      <script type="text/javascript">
   634          (function() {
   635              if ("CN" in window) {
   636                  if (ars.MOBILE && "UAParser" in window) {
   637                      var ua = new UAParser();
   638                      if (ua.getOS().name == "Android" && ua.getBrowser().name == "Chrome") {
   639                          return;
   640                      }
   641                  }
   642                  CN.site.init({
   643                      code: "ars",
   644                      title: "Ars",
   645                      name: ars.MOBILE ? "ars.mobile" : "ars",
   646                      env: ars.ENV === "production" ? "PROD" : "DEV",
   647                      debug: ars.ENV !== "production"
   648                  });
   649                  CN.dart.init({
   650                      site: CN.site.name + '.dart',
   651                      zone: ars.AD.zone,
   652                      kws: ars.AD.kw,
   653                      gptCallback: function(e) {
   654                          ars.sda.ad_loaded(e);
   655                      }
   656                  });
   657                  CN.dart.getCommon()["domDelay"]["defaultVal"] = 100;
   658                  for (var i = 0; i &lt; ars.AD.queue.length; i++) {
   659                      var ad = ars.AD.queue[i],
   660                          id = ad[0],
   661                          args = ad[1];
   662                      if ($('#' + id + args.sz + "_frame").length) CN.dart.call(id, args);
   663                  }
   664                  ars.AD.queue = [];
   665              }
   666          })();
   667      </script>
   668      <script type="text/javascript">
   669          CN.ad.polar.article = function(Handlebars, depth0, helpers, partials, data) {
   670              this.compilerInfo = [4, '>= 1.0.0'];
   671              helpers = this.merge(helpers, Handlebars.helpers);
   672              data = data || {};
   673              var buffer = "",
   674                  stack1, stack2, functionType = "function",
   675                  escapeExpression = this.escapeExpression,
   676                  self = this;
   677  
   678              function program1(depth0, data) {
   679                  var buffer = "",
   680                      stack1;
   681                  buffer += "\n      &lt;span style=\"width:50px; height:50px; overflow:hidden; display:inline-block; float:left; margin:2px 10px 5px 0\">\n        &lt;img src=\"" + escapeExpression(((stack1 = ((stack1 = depth0.image), stack1 == null || stack1 === false ? stack1 : stack1.href)), typeof stack1 === functionType ? stack1.apply(depth0) : stack1)) + "\" style=\"float:none; margin:0; height:50px; width:auto;\" />\n      &lt;/span>\n    ";
   682                  return buffer;
   683              }
   684              buffer += "&lt;li>\n  &lt;a href=\"";
   685              if (stack1 = helpers.link) {
   686                  stack1 = stack1.call(depth0, {
   687                      hash: {},
   688                      data: data
   689                  });
   690              } else {
   691                  stack1 = depth0.link;
   692                  stack1 = typeof stack1 === functionType ? stack1.apply(depth0) : stack1;
   693              }
   694              buffer += escapeExpression(stack1) + "\">\n    &lt;h2 style=\"color:#00A3D3;\">Sponsored by: &lt;span style=\"text-transform:none;\">" + escapeExpression(((stack1 = ((stack1 = depth0.sponsor), stack1 == null || stack1 === false ? stack1 : stack1.name)), typeof stack1 === functionType ? stack1.apply(depth0) : stack1)) + "&lt;/span>&lt;/h2>\n    ";
   695              stack2 = helpers['if'].call(depth0, ((stack1 = depth0.image), stack1 == null || stack1 === false ? stack1 : stack1.href), {
   696                  hash: {},
   697                  inverse: self.noop,
   698                  fn: self.program(1, program1, data),
   699                  data: data
   700              });
   701              if (stack2 || stack2 === 0) {
   702                  buffer += stack2;
   703              }
   704              buffer += "\n    &lt;h1 class=\"heading\">";
   705              if (stack2 = helpers.title) {
   706                  stack2 = stack2.call(depth0, {
   707                      hash: {},
   708                      data: data
   709                  });
   710              } else {
   711                  stack2 = depth0.title;
   712                  stack2 = typeof stack2 === functionType ? stack2.apply(depth0) : stack2;
   713              }
   714              buffer += escapeExpression(stack2) + "&lt;/h1>\n  &lt;/a>\n&lt;/li>";
   715              return buffer;
   716          };
   717      </script>
   718      <!-- cache hit 459:single/javascript-footer:1ad28a5dc0a24868be6b031b5fdecb2e -->
   719      <noscript>
   720          <a href="http://www.omniture.com" title="Web Analytics"><img src="http://condenast.112.2o7.net/b/ss/condenet-dev/1/H.15.1--NS/0" height="1" width="1" border="0" alt="" /></a>
   721      </noscript>
   722      <!-- Google Analytics start -->
   723      <script type="text/javascript">
   724          var _gaq = _gaq || [];
   725          _gaq.push(
   726              ['_setAccount', 'UA-31997-1'], ['_setCustomVar', 1, 'view', "grid"], ['_setCustomVar', 2, 'theme', "light"], ['_setCustomVar', 3, 'logged_in', "false"], ['_setCustomVar', 4, 'show_comments', "false"], ['_setCustomVar', 5, 'is_premier', "false"], ['_trackPageview']);
   727          (function() {
   728              var ga = document.createElement('script');
   729              ga.type = 'text/javascript';
   730              ga.async = true;
   731              ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
   732              var s = document.getElementsByTagName('script')[0];
   733              s.parentNode.insertBefore(ga, s);
   734          })();
   735      </script>
   736      <!-- Google Analytics end -->
   737      <!-- Parse.ly start -->
   738      <script type="text/javascript">
   739          (function(d) {
   740              var site = "arstechnica.com",
   741                  b = d.body,
   742                  e = d.createElement("div");
   743              e.innerHTML = '<span id="parsely-cfg" data-parsely-site="' + site + '"></span>';
   744              e.id = "parsely-root";
   745              e.style.display = "none";
   746              b.appendChild(e);
   747          })(document);
   748          (function(s, p, d) {
   749              var h = d.location.protocol,
   750                  i = p + "-" + s,
   751                  e = d.getElementById(i),
   752                  r = d.getElementById(p + "-root"),
   753                  u = h === "https:" ? "d1z2jf7jlzjs58.cloudfront.net" : "static." + p + ".com";
   754              if (e) return;
   755              e = d.createElement(s);
   756              e.id = i;
   757              e.async = true;
   758              e.src = h + "//" + u + "/p.js";
   759              r.appendChild(e);
   760          })("script", "parsely", document);
   761      </script>
   762      <!-- Parse.ly end -->
   763  </body>
   764  
   765  </html>