php curl發送請求實例方法

在本篇文章裏小編給大家整理的是關於php curl發送請求詳細教程以及相關知識點,需要的朋友們可以學習下。

cURL可以使用URL的語法模擬瀏覽器來傳輸數據,因爲它是模擬瀏覽器,因此它同樣支持多種協議,FTP, FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE 以及 LDAP等協議都可以很好的支持,包括一些:HTTPS認證,HTTP POST方法,HTTP PUT方法,FTP上傳,keyberos認證,HTTP上傳,代理服務器,cookies,用戶名/密碼認證,下載文件斷點續傳,上傳文件斷點續傳,http代理服務器管道,甚至它還支持IPv6,scoket5代理服務器,通過http代理服務器上傳文件到FTP服務器等等。

使用PHP的cURL庫可以簡單和有效地去抓網頁。你只需要運行一個腳本,然後分析一下你所抓取的網頁,然後就可以以程序的方式得到你想要的數據了。無論是你想從從一個鏈接上取部分數據,或是取一個XML文件並把其導入數據庫,那怕就是簡單的獲取網頁內容,cURL 是一個功能強大的PHP庫。

1、PHP建立CURL請求的基本步驟

①:初始化

curl_init()

②:設置屬性

curl_setopt().有一長串cURL參數可供設置,它們能指定URL請求的各個細節。

③:執行並獲取結果

curl_exec()

④:釋放句柄

curl_close()

2、實例:

php curl 發送get請求:

//初始化

$curl = curl_init();

//設置抓取的url

curl_setopt($curl, CURLOPT_URL, 'http://www.baidu.com');

//設置頭文件的信息作爲數據流輸出

curl_setopt($curl, CURLOPT_HEADER, 1);

//設置獲取的信息以文件流的形式返回,而不是直接輸出。

curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

//執行命令

$data = curl_exec($curl);

echo curl_getinfo($curl,CURLINFO_HTTP_CODE); //輸出請求狀態碼

//關閉URL請求

curl_close($curl);

//顯示獲得的數據

print_r($data);

php curl 發送post請求:

//初始化

$curl = curl_init();

//設置抓取的url

curl_setopt($curl, CURLOPT_URL, 'http://localhost/test/test.php');

//設置頭文件的信息作爲數據流輸出

curl_setopt($curl, CURLOPT_HEADER, 1);

//設置獲取的信息以文件流的形式返回,而不是直接輸出。

curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

//設置post方式提交

curl_setopt($curl, CURLOPT_POST, 1);

//設置post數據

$post_data = array(

  "title" => "1290800466",

  "content" => "3424243243"

);

//post提交的數據

curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);

//執行命令

$data = curl_exec($curl);

//關閉URL請求

curl_close($curl);

//顯示獲得的數據

print_r($data);

test.php:

<?php

$title = $_REQUEST['title'];

$content = $_REQUEST['content'];

error_log($title."\n",3,'error.log');

error_log($content."\n",3,'error.log');

echo 'ok';

3、PHP cURL 函數:

以下包含了PHP cURL函數列表:

函數 描述
curl_close() 關閉一個cURL會話。
curl_copy_handle() 複製一個cURL句柄和它的所有選項。
curl_errno() 返回最後一次的錯誤號。
curl_error() 返回一個保護當前會話最近一次錯誤的字符串。
curl_escape() 返回轉義字符串,對給定的字符串進行URL編碼。
curl_exec() 執行一個cURL會話。
curl_file_create() 創建一個 CURLFile 對象。
curl_getinfo() 獲取一個cURL連接資源句柄的信息。
curl_init() 初始化一個cURL會話。
curl_multi_add_handle() 向curl批處理會話中添加單獨的curl句柄。
curl_multi_close() 關閉一組cURL句柄。
curl_multi_exec() 運行當前 cURL 句柄的子連接。
curl_multi_getcontent() 如果設置了CURLOPT_RETURNTRANSFER,則返回獲取的輸出的文本流。
curl_multi_info_read() 獲取當前解析的cURL的相關傳輸信息。
curl_multi_init() 返回一個新cURL批處理句柄。
curl_multi_remove_handle() 移除curl批處理句柄資源中的某個句柄資源。
curl_multi_select() 等待所有cURL批處理中的活動連接。
curl_multi_setopt() 設置一個批處理cURL傳輸選項。
curl_multi_strerror() 返回描述錯誤碼的字符串文本。
curl_pause() 暫停及恢復連接。
curl_reset() 重置libcurl的會話句柄的所有選項。
curl_setopt_array() 爲cURL傳輸會話批量設置選項。
curl_setopt() 設置一個cURL傳輸選項。
curl_share_close() 關閉cURL共享句柄。
curl_share_init() 初始化cURL共享句柄。
curl_share_setopt() 設置一個共享句柄的cURL傳輸選項。
curl_strerror() 返回錯誤代碼的字符串描述。
curl_unescape() 解碼URL編碼後的字符串。
curl_version() 獲取cURL版本信息。

成功時返回 TRUE, 或者在失敗時返回 FALSE。

一些狀態代碼

1xx:請求收到,繼續處理

2xx:操作成功收到,分析、接受

3xx:完成此請求必須進一步處理

4xx:請求包含一個錯誤語法或不能完成

5xx:服務器執行一個完全有效請求失敗

100——客戶必須繼續發出請求

101——客戶要求服務器根據請求轉換HTTP協議版本

200——交易成功

201——提示知道新文件的URL

202——接受和處理、但處理未完成

203——返回信息不確定或不完整

204——請求收到,但返回信息爲空

205——服務器完成了請求,用戶代理必須復位當前已經瀏覽過的文件

206——服務器已經完成了部分用戶的GET請求

300——請求的資源可在多處得到

301——刪除請求數據

302——在其他地址發現了請求數據

303——建議客戶訪問其他URL或訪問方式

304——客戶端已經執行了GET,但文件未變化

305——請求的資源必須從服務器指定的地址得到

306——前一版本HTTP中使用的代碼,現行版本中不再使用

307——申明請求的資源臨時性刪除

400——錯誤請求,如語法錯誤

401——請求授權失敗

402——保留有效ChargeTo頭響應

403——請求不允許

404——沒有發現文件、查詢或URl

405——用戶在Request-Line字段定義的方法不允許

406——根據用戶發送的Accept拖,請求資源不可訪問

407——類似401,用戶必須首先在代理服務器上得到授權

408——客戶端沒有在用戶指定的餓時間內完成請求

409——對當前資源狀態,請求不能完成

410——服務器上不再有此資源且無進一步的參考地址

411——服務器拒絕用戶定義的Content-Length屬性請求

412——一個或多個請求頭字段在當前請求中錯誤

413——請求的資源大於服務器允許的大小

414——請求的資源URL長於服務器允許的長度

415——請求資源不支持請求項目格式

416——請求中包含Range請求頭字段,在當前請求資源範圍內沒有range指示值,請求

也不包含If-Range請求頭字段

417——服務器不滿足請求Expect頭字段指定的期望值,如果是代理服務器,可能是下一級服務器不能滿足請求

500——服務器產生內部錯誤

501——服務器不支持請求的函數

502——服務器暫時不可用,有時是爲了防止發生系統過載

503——服務器過載或暫停維修

504——關口過載,服務器使用另一個關口或服務來響應用戶,等待時間設定值較長

505——服務器不支持或拒絕支請求頭中指定的HTTP版本

以上就是本次介紹的php curl發送請求的全部知識點,感謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章