亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? robotstxt.html

?? 網絡爬蟲開源代碼
?? HTML
字號:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"><head><meta http-equiv="content-type" content="text/html; charset=UTF-8" /><title>Robotstxt xref</title><link type="text/css" rel="stylesheet" href="../../../../stylesheet.css" /></head><body><div id="overview"><a href="../../../../../apidocs/org/archive/crawler/datamodel/Robotstxt.html">View Javadoc</a></div><pre><a name="1" href="#1">1</a>   <em class="comment">/*<em class="comment"> Robots.java</em></em><a name="2" href="#2">2</a>   <em class="comment"> *</em><a name="3" href="#3">3</a>   <em class="comment"> * $Id: Robotstxt.java 4947 2007-03-01 04:47:24Z gojomo $</em><a name="4" href="#4">4</a>   <em class="comment"> *</em><a name="5" href="#5">5</a>   <em class="comment"> * Created Sep 1, 2005</em><a name="6" href="#6">6</a>   <em class="comment"> *</em><a name="7" href="#7">7</a>   <em class="comment"> * Copyright (C) 2005 Internet Archive.</em><a name="8" href="#8">8</a>   <em class="comment"> *</em><a name="9" href="#9">9</a>   <em class="comment"> * This file is part of the Heritrix web crawler (crawler.archive.org).</em><a name="10" href="#10">10</a>  <em class="comment"> *</em><a name="11" href="#11">11</a>  <em class="comment"> * Heritrix is free software; you can redistribute it and/or modify</em><a name="12" href="#12">12</a>  <em class="comment"> * it under the terms of the GNU Lesser Public License as published by</em><a name="13" href="#13">13</a>  <em class="comment"> * the Free Software Foundation; either version 2.1 of the License, or</em><a name="14" href="#14">14</a>  <em class="comment"> * any later version.</em><a name="15" href="#15">15</a>  <em class="comment"> *</em><a name="16" href="#16">16</a>  <em class="comment"> * Heritrix is distributed in the hope that it will be useful,</em><a name="17" href="#17">17</a>  <em class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</em><a name="18" href="#18">18</a>  <em class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the</em><a name="19" href="#19">19</a>  <em class="comment"> * GNU Lesser Public License for more details.</em><a name="20" href="#20">20</a>  <em class="comment"> *</em><a name="21" href="#21">21</a>  <em class="comment"> * You should have received a copy of the GNU Lesser Public License</em><a name="22" href="#22">22</a>  <em class="comment"> * along with Heritrix; if not, write to the Free Software</em><a name="23" href="#23">23</a>  <em class="comment"> * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA</em><a name="24" href="#24">24</a>  <em class="comment"> */</em><a name="25" href="#25">25</a>  <strong>package</strong> <a href="../../../../org/archive/crawler/datamodel/package-summary.html">org.archive.crawler.datamodel</a>;<a name="26" href="#26">26</a>  <a name="27" href="#27">27</a>  <strong>import</strong> java.io.BufferedReader;<a name="28" href="#28">28</a>  <strong>import</strong> java.io.IOException;<a name="29" href="#29">29</a>  <strong>import</strong> java.util.ArrayList;<a name="30" href="#30">30</a>  <strong>import</strong> java.util.LinkedList;<a name="31" href="#31">31</a>  <strong>import</strong> java.util.List;<a name="32" href="#32">32</a>  <strong>import</strong> java.util.Map;<a name="33" href="#33">33</a>  <a name="34" href="#34">34</a>  <em>/**<em>*</em></em><a name="35" href="#35">35</a>  <em> * Utility class for parsing 'robots.txt' format directives, into a list</em><a name="36" href="#36">36</a>  <em> * of named user-agents and map from user-agents to disallowed paths. </em><a name="37" href="#37">37</a>  <em> */</em><a name="38" href="#38">38</a>  <strong>public</strong> <strong>class</strong> <a href="../../../../org/archive/crawler/datamodel/Robotstxt.html">Robotstxt</a> {<a name="39" href="#39">39</a>      <strong>public</strong> <strong>static</strong> <strong>boolean</strong> parse(BufferedReader reader,<a name="40" href="#40">40</a>              <strong>final</strong> LinkedList&lt;String> userAgents, <a name="41" href="#41">41</a>              <strong>final</strong> Map&lt;String,List&lt;String>> disallows)<a name="42" href="#42">42</a>      throws IOException {<a name="43" href="#43">43</a>          <strong>boolean</strong> hasErrors = false;<a name="44" href="#44">44</a>          String read;<a name="45" href="#45">45</a>          <em class="comment">// current is the disallowed paths for the preceding User-Agent(s)</em><a name="46" href="#46">46</a>          ArrayList&lt;String> current = <strong>null</strong>;<a name="47" href="#47">47</a>          <em class="comment">// whether a non-'User-Agent' directive has been encountered</em><a name="48" href="#48">48</a>          <strong>boolean</strong> hasDirectivesYet = false; <a name="49" href="#49">49</a>          String catchall = <strong>null</strong>;<a name="50" href="#50">50</a>          <strong>while</strong> (reader != <strong>null</strong>) {<a name="51" href="#51">51</a>              <strong>do</strong> {<a name="52" href="#52">52</a>                  read = reader.readLine();<a name="53" href="#53">53</a>                  <em class="comment">// Skip comments &amp; blanks</em><a name="54" href="#54">54</a>              } <strong>while</strong> ((read != <strong>null</strong>) &amp;&amp; ((read = read.trim()).startsWith(<span class="string">"#"</span>) ||<a name="55" href="#55">55</a>                  read.length() == 0));<a name="56" href="#56">56</a>              <strong>if</strong> (read == <strong>null</strong>) {<a name="57" href="#57">57</a>                  reader.close();<a name="58" href="#58">58</a>                  reader = <strong>null</strong>;<a name="59" href="#59">59</a>              } <strong>else</strong> {<a name="60" href="#60">60</a>                  <strong>int</strong> commentIndex = read.indexOf(<span class="string">"#"</span>);<a name="61" href="#61">61</a>                  <strong>if</strong> (commentIndex > -1) {<a name="62" href="#62">62</a>                      <em class="comment">// Strip trailing comment</em><a name="63" href="#63">63</a>                      read = read.substring(0, commentIndex);<a name="64" href="#64">64</a>                  }<a name="65" href="#65">65</a>                  read = read.trim();<a name="66" href="#66">66</a>                  <strong>if</strong> (read.matches(<span class="string">"(?i)^User-agent:.*"</span>)) {<a name="67" href="#67">67</a>                      String ua = read.substring(11).trim().toLowerCase();<a name="68" href="#68">68</a>                      <strong>if</strong> (current == <strong>null</strong> || hasDirectivesYet ) {<a name="69" href="#69">69</a>                          <em class="comment">// only create new rules-list if necessary</em><a name="70" href="#70">70</a>                          <em class="comment">// otherwise share with previous user-agent</em><a name="71" href="#71">71</a>                          current = <strong>new</strong> ArrayList&lt;String>();<a name="72" href="#72">72</a>                          hasDirectivesYet = false; <a name="73" href="#73">73</a>                      }<a name="74" href="#74">74</a>                      <strong>if</strong> (ua.equals(<span class="string">"*"</span>)) {<a name="75" href="#75">75</a>                          ua = <span class="string">""</span>;<a name="76" href="#76">76</a>                          catchall = ua;<a name="77" href="#77">77</a>                      } <strong>else</strong> {<a name="78" href="#78">78</a>                          userAgents.addLast(ua);<a name="79" href="#79">79</a>                      }<a name="80" href="#80">80</a>                      disallows.put(ua, current);<a name="81" href="#81">81</a>                      <strong>continue</strong>;<a name="82" href="#82">82</a>                  }<a name="83" href="#83">83</a>                  <strong>if</strong> (read.matches(<span class="string">"(?i)Disallow:.*"</span>)) {<a name="84" href="#84">84</a>                      <strong>if</strong> (current == <strong>null</strong>) {<a name="85" href="#85">85</a>                          <em class="comment">// buggy robots.txt</em><a name="86" href="#86">86</a>                          hasErrors = <strong>true</strong>;<a name="87" href="#87">87</a>                          <strong>continue</strong>;<a name="88" href="#88">88</a>                      }<a name="89" href="#89">89</a>                      String path = read.substring(9).trim();<a name="90" href="#90">90</a>                      current.add(path);<a name="91" href="#91">91</a>                      hasDirectivesYet = <strong>true</strong>; <a name="92" href="#92">92</a>                      <strong>continue</strong>;<a name="93" href="#93">93</a>                  }<a name="94" href="#94">94</a>                  <strong>if</strong> (read.matches(<span class="string">"(?i)Crawl-delay:.*"</span>)) {<a name="95" href="#95">95</a>                      <strong>if</strong> (current == <strong>null</strong>) {<a name="96" href="#96">96</a>                          <em class="comment">// buggy robots.txt</em><a name="97" href="#97">97</a>                          hasErrors = <strong>true</strong>;<a name="98" href="#98">98</a>                          <strong>continue</strong>;<a name="99" href="#99">99</a>                      }<a name="100" href="#100">100</a>                     <em class="comment">// consider a crawl-delay, even though we don't </em><a name="101" href="#101">101</a>                     <em class="comment">// yet understand it, as sufficient to end a </em><a name="102" href="#102">102</a>                     <em class="comment">// grouping of User-Agent lines</em><a name="103" href="#103">103</a>                     hasDirectivesYet = <strong>true</strong>;<a name="104" href="#104">104</a>                     <em class="comment">// TODO: understand/save/respect 'Crawl-Delay' </em><a name="105" href="#105">105</a>                     <strong>continue</strong>;<a name="106" href="#106">106</a>                 }<a name="107" href="#107">107</a>                 <strong>if</strong> (read.matches(<span class="string">"(?i)Allow:.*"</span>)) {<a name="108" href="#108">108</a>                     <strong>if</strong> (current == <strong>null</strong>) {<a name="109" href="#109">109</a>                         <em class="comment">// buggy robots.txt</em><a name="110" href="#110">110</a>                         hasErrors = <strong>true</strong>;<a name="111" href="#111">111</a>                         <strong>continue</strong>;<a name="112" href="#112">112</a>                     }<a name="113" href="#113">113</a>                     <em class="comment">// consider an Allow, even though we don't </em><a name="114" href="#114">114</a>                     <em class="comment">// yet understand it, as sufficient to end a </em><a name="115" href="#115">115</a>                     <em class="comment">// grouping of User-Agent lines</em><a name="116" href="#116">116</a>                     hasDirectivesYet = <strong>true</strong>;<a name="117" href="#117">117</a>                     <em class="comment">// TODO: understand/save/respect 'Allow' </em><a name="118" href="#118">118</a>                     <strong>continue</strong>;<a name="119" href="#119">119</a>                 }<a name="120" href="#120">120</a>                 <em class="comment">// unknown line; do nothing for now</em><a name="121" href="#121">121</a>             }<a name="122" href="#122">122</a>         }<a name="123" href="#123">123</a> <a name="124" href="#124">124</a>         <strong>if</strong> (catchall != <strong>null</strong>) {<a name="125" href="#125">125</a>             userAgents.addLast(catchall);<a name="126" href="#126">126</a>         }<a name="127" href="#127">127</a>         <strong>return</strong> hasErrors;<a name="128" href="#128">128</a>     }<a name="129" href="#129">129</a> <a name="130" href="#130">130</a>     <em>/**<em>*</em></em><a name="131" href="#131">131</a> <em>     * @param args Command-line arguments.</em><a name="132" href="#132">132</a> <em>     */</em><a name="133" href="#133">133</a>     <strong>public</strong> <strong>static</strong> <strong>void</strong> main(String[] args) {<a name="134" href="#134">134</a>         <em class="comment">// TODO Auto-generated method stub</em><a name="135" href="#135">135</a>     }<a name="136" href="#136">136</a> }</pre><hr/><div id="footer">This page was automatically generated by <a href="http://maven.apache.org/">Maven</a></div></body></html>

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人av在线电影| 91精品婷婷国产综合久久竹菊| 日韩精品中文字幕一区| 亚洲黄色免费网站| 色综合咪咪久久| 国产精品青草综合久久久久99| 久久国产夜色精品鲁鲁99| 欧美一区二区三区喷汁尤物| 精品影视av免费| 国产精品家庭影院| 欧洲亚洲精品在线| 天堂午夜影视日韩欧美一区二区| 欧美日韩精品久久久| 看电影不卡的网站| 亚洲视频一区在线| 69av一区二区三区| 国产精品99精品久久免费| 国产三级欧美三级日产三级99| 岛国一区二区在线观看| 玉足女爽爽91| 制服丝袜中文字幕一区| 粉嫩久久99精品久久久久久夜 | 94-欧美-setu| 欧美a一区二区| 亚洲国产精品ⅴa在线观看| 欧美亚洲另类激情小说| 紧缚奴在线一区二区三区| 一区二区三区中文字幕在线观看| 欧美在线观看18| 成人精品视频一区| 日本亚洲天堂网| 国模少妇一区二区三区| 一区二区欧美国产| 2020国产成人综合网| 在线视频一区二区免费| 国产a久久麻豆| 乱中年女人伦av一区二区| 亚洲成人一区在线| 一区二区三区av电影| 国产精品久久久久久久午夜片| 精品日韩成人av| 欧美一区二区久久| 欧美一级久久久| 在线成人免费观看| 欧美高清你懂得| 欧美一区二区视频免费观看| 欧美久久久影院| 91精品国产黑色紧身裤美女| 欧美色窝79yyyycom| 欧美视频一区二区三区四区| 欧美唯美清纯偷拍| 正在播放亚洲一区| 欧美大肚乱孕交hd孕妇| 国产亚洲欧美日韩俺去了| 国产精品久久久久久久岛一牛影视| 国产嫩草影院久久久久| 亚洲天堂av老司机| 偷窥国产亚洲免费视频| 久久国产精品无码网站| 国产高清在线精品| 一本大道久久a久久综合| 欧美日韩午夜在线视频| 欧美大片日本大片免费观看| 中文一区二区在线观看| 日韩一区欧美二区| 成人在线视频一区| 欧美日韩一区精品| 国产偷国产偷亚洲高清人白洁| 亚洲精品视频在线观看免费| 美女看a上一区| 99re6这里只有精品视频在线观看| 在线观看一区日韩| 国产精品美女久久久久av爽李琼| 水野朝阳av一区二区三区| 国产精品亚洲а∨天堂免在线| 91美女精品福利| 国产欧美日韩一区二区三区在线观看| 一区二区三区精品| 成人免费视频国产在线观看| 欧美日韩卡一卡二| 偷窥少妇高潮呻吟av久久免费| 成人夜色视频网站在线观看| 8x福利精品第一导航| 亚洲精选免费视频| 91丨九色丨黑人外教| 日本一区二区三区在线观看| 免费看日韩精品| 这里只有精品视频在线观看| 亚洲国产精品天堂| 欧美色视频一区| 亚洲最大成人网4388xx| 国产午夜精品久久久久久久| 色噜噜狠狠成人中文综合| 久久精品无码一区二区三区| 日本sm残虐另类| 久久婷婷一区二区三区| 国内精品视频666| 精品久久国产老人久久综合| 精品亚洲免费视频| 精品国精品国产尤物美女| 欧美a级理论片| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 伊人婷婷欧美激情| 色婷婷久久久亚洲一区二区三区| 中文字幕日韩av资源站| 成人看片黄a免费看在线| 亚洲欧美另类久久久精品2019| 色呦呦国产精品| 午夜电影网一区| 精品免费日韩av| 成人性生交大合| 亚洲精品一二三| 欧美一区二区人人喊爽| 盗摄精品av一区二区三区| 亚洲色欲色欲www| 337p亚洲精品色噜噜噜| 国产成人aaa| 日韩黄色小视频| 国产精品污网站| 欧美一级日韩免费不卡| 色综合一区二区| 国产一区二区h| 婷婷成人激情在线网| 中文字幕不卡在线观看| 911精品国产一区二区在线| 风间由美一区二区三区在线观看 | 在线视频国内一区二区| 国产真实乱子伦精品视频| 亚洲一卡二卡三卡四卡无卡久久| 2020国产成人综合网| 在线播放亚洲一区| 在线观看亚洲专区| 色激情天天射综合网| 成人激情开心网| 国内精品自线一区二区三区视频| 一区二区三区美女| 亚洲色图都市小说| 国产精品久久久久精k8| 久久精品夜夜夜夜久久| 日韩免费高清视频| 欧美一级艳片视频免费观看| 欧美精品一卡两卡| 欧美性xxxxx极品少妇| 色噜噜狠狠色综合中国| 国产精品自拍一区| 精品一区二区三区免费毛片爱| 日本少妇一区二区| 麻豆成人在线观看| 国产成人一区在线| 99精品国产99久久久久久白柏| 99在线精品视频| 精品视频一区三区九区| 日韩欧美另类在线| 亚洲国产精华液网站w| 亚洲免费观看高清完整版在线观看熊 | 亚洲欧洲三级电影| 亚洲高清中文字幕| 男男视频亚洲欧美| 国产一区在线观看麻豆| 成人av午夜影院| 欧美性视频一区二区三区| 3d成人h动漫网站入口| 国产亚洲精品久| 午夜精品在线看| 国产一区亚洲一区| 成人毛片视频在线观看| 欧美手机在线视频| 欧美一区二区三区思思人| 国产亚洲欧美日韩在线一区| 亚洲美女在线国产| 久久精工是国产品牌吗| 99re6这里只有精品视频在线观看| 欧美日韩视频在线观看一区二区三区| 日韩一区二区精品葵司在线| 国产欧美精品国产国产专区 | 国产精品美女www爽爽爽| 午夜久久久久久电影| 丁香婷婷综合网| 日韩欧美高清dvd碟片| 一区二区三区在线视频观看58| 免费人成精品欧美精品| 成人午夜又粗又硬又大| 日韩美女一区二区三区四区| 亚洲一区二区偷拍精品| 国产麻豆成人精品| 欧美一区二区美女| 日本强好片久久久久久aaa| 欧洲精品在线观看| 国产精品美女视频| 成人丝袜视频网| 日本一区二区三区四区在线视频 | 久久综合久色欧美综合狠狠| 青青国产91久久久久久| 91精品黄色片免费大全| 日韩电影免费一区| 欧美日韩美少妇| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美色男人天堂| 日本大胆欧美人术艺术动态| 欧美日韩日日摸|