<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                ## # cURL的10種常見用法示例 **前言** 在Linux中curl是一個利用URL規則在命令行下工作的文件傳輸工具,可以說是一款很強大的http命令行工具。它支持文件的上傳和下載,是綜合傳輸工具,但按傳統,習慣稱url為下載工具。 語法:`# curl [option] [url]` 本文主要跟大家分享了Linux命令行cURL的10種常見用法,分享出來供大家參考學習,下面來一起看看詳細的介紹: **1\. 獲取頁面內容** 當我們不加任何選項使用 curl 時,默認會發送 GET 請求來獲取鏈接內容到標準輸出。 ``` curl http://www.codebelief.com ``` **2. 顯示 HTTP 頭** 如果我們只想要顯示 HTTP 頭,而不顯示文件內容,可以使用 -I 選項: ``` curl -I http://www.codebelief.com ``` 輸出為: 12345678910HTTP/1.1 200 OKServer: nginx/1.10.3Date: Thu, 11 May 2017 08:24:45 GMTContent-Type: text/html; charset=utf-8Content-Length: 24206Connection: keep-aliveX-Powered-By: ExpressCache-Control: public, max-age=0ETag: W/"5e8e-Yw5ZdnVVly9/aEnMX7fVXQ"Vary: Accept-Encoding 也可以同時顯示 HTTP 頭和文件內容,使用 -i 選項: ``` curl -i http://www.codebelief.com ``` 輸出為: 123456789101112131415HTTP/1.1 200 OKServer: nginx/1.10.3Date: Thu, 11 May 2017 08:25:46 GMTContent-Type: text/html; charset=utf-8Content-Length: 24206Connection: keep-aliveX-Powered-By: ExpressCache-Control: public, max-age=0ETag: W/"5e8e-Yw5ZdnVVly9/aEnMX7fVXQ"Vary: Accept-Encoding&nbsp;&lt;!DOCTYPE html&gt;&lt;html lang="en"&gt;......&lt;/html&gt; **3\. 將鏈接保存到文件** 我們可以使用 > 符號將輸出重定向到本地文件中。 ``` curl http://www.codebelief.com &gt; index.html ``` 也可以通過 curl 自帶的`-o`/`-O`選項將內容保存到文件中。 * `-o`(小寫的 o):結果會被保存到命令行中提供的文件名 * `-O`(大寫的 O):URL 中的文件名會被用作保存輸出的文件名 12curl -o index.html http://www.codebelief.comcurl -O http://www.codebelief.com/page/2/ **注意:**使用`-O`選項時,必須確保鏈接末尾包含文件名,否則 curl 無法正確保存文件。如果遇到鏈接中無文件名的情況,應該使 用`-o`選項手動指定文件名,或使用重定向符號。 **4\. 同時下載多個文件** 我們可以使用`-o`或`-O`選項來同時指定多個鏈接,按照以下格式編寫命令: ``` curl -O http://www.codebelief.com/page/2/ -O http://www.codebelief.com/page/3/ ``` 或者: ``` curl -o page1.html http://www.codebelief.com/page/1/ -o page2.html http://www.codebelief.com/page/2/ ``` **5\. 使用 -L 跟隨鏈接重定向** 如果直接使用 curl 打開某些被重定向后的鏈接,這種情況下就無法獲取我們想要的網頁內容。例如: ``` curl http://codebelief.com ``` 會得到如下提示: 1234567&lt;html&gt;&lt;head&gt;&lt;title&gt;301 Moved Permanently&lt;/title&gt;&lt;/head&gt;&lt;body bgcolor="white"&gt;&lt;center&gt;&lt;h1&gt;301 Moved Permanently&lt;/h1&gt;&lt;/center&gt;&lt;hr&gt;&lt;center&gt;nginx/1.10.3&lt;/center&gt;&lt;/body&gt;&lt;/html&gt; 而當我們通過瀏覽器打開該鏈接時,會自動跳轉到 http://www.codebelief.com。此時我們想要 curl 做的,就是像瀏覽器一樣跟隨鏈接的跳轉,獲取最終的網頁內容。我們可以在命令中添加 -L 選項來跟隨鏈接重定向: ``` curl -L http://codebelief.com ``` 這樣我們就能獲取到經過重定向后的網頁內容了。 **6\. 使用 -A 自定義 User-Agent** 我們可以使用`-A`來自定義用戶代理,例如下面的命令將偽裝成安卓火狐瀏覽器對網頁進行請求: ``` curl -A "Mozilla/5.0 (Android; Mobile; rv:35.0) Gecko/35.0 Firefox/35.0" http://www.baidu.com ``` 下面我們會使用 -H 來實現同樣的目的。 **7\. 使用 -H 自定義 header** 當我們需要傳遞特定的 header 的時候,可以仿照以下命令來寫: ``` curl -H "Referer: www.example.com" -H "User-Agent: Custom-User-Agent" http://www.baidu.com ``` 可以看到,當我們使用`-H`來自定義 User-Agent 時,需要使用 "`User-Agent: xxx`" 的格式。 我們能夠直接在 header 中傳遞 Cookie,格式與上面的例子一樣: ``` curl -H "Cookie: JSESSIONID=D0112A5063D938586B659EF8F939BE24" http://www.example.com ``` 另一種方式會在下面介紹。 **8\. 使用 -c 保存 Cookie** 當我們使用 cURL 訪問頁面的時候,默認是不會保存 Cookie 的。有些情況下我們希望保存 Cookie 以便下次訪問時使用。例如登陸了某個網站,我們希望再次訪問該網站時保持登陸的狀態,這時就可以現將登陸時的 Cookie 保存起來,下次訪問時再讀取。 `-c`后面跟上要保存的文件名。 ``` curl -c "cookie-example" http://www.example.com ``` **9\. 使用 -b 讀取 Cookie** 前面講到了使用`-H`來發送 Cookie 的方法,這種方式是直接將 Cookie 字符串寫在命令中。如果使用 -b 來自定義 Cookie,命令如下: ``` curl -b "JSESSIONID=D0112A5063D938586B659EF8F939BE24" http://www.example.com ``` 如果要從文件中讀取 Cookie,-H 就無能為力了,此時可以使用`-b`來達到這一目的: ``` curl -b "cookie-example" http://www.example.com ``` 即`-b`后面既可以是 Cookie 字符串,也可以是保存了 Cookie 的文件名。 **10\. 使用 -d 發送 POST 請求** 我們以登陸網頁為例來進行說明使用 cURL 發送 POST 請求的方法。假設有一個登錄頁面 www.example.com/login,只需要提交用戶名和密碼便可登錄。我們可以使用 cURL 來完成這一 POST 請求,-d 用于指定發送的數據,-X 用于指定發送數據的方式: ``` curl -d "userName=tom&amp;passwd=123456" -X POST http://www.example.com/login ``` 在使用`-d`的情況下,如果省略`-X`,則默認為 POST 方式: ``` curl -d "userName=tom&amp;passwd=123456" http://www.example.com/login ``` **強制使用 GET 方式** 發送數據時,不僅可以使用 POST 方式,也可以使用 GET 方式,例如: ``` curl -d "somedata" -X GET http://www.example.com/api ``` 或者使用`-G`選項: ``` curl -d "somedata" -G http://www.example.com/api ``` 從文件中讀取 data ``` curl -d "@data.txt" http://www.example.com/login ``` 帶 Cookie 登錄 當然,如果我們再次訪問該網站,仍然會變成未登錄的狀態。我們可以用之前提到的方法保存 Cookie,在每次訪問網站時都帶上該 Cookie 以保持登錄狀態。 ``` curl -c "cookie-login" -d "userName=tom&amp;passwd=123456" http://www.example.com/login ``` 再次訪問該網站時,使用以下命令: ``` curl -b "cookie-login" http://www.example.com/login ``` 這樣,就能保持訪問的是登錄后的頁面了。 **總結** 以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看