歡迎訪問個人原創地址: https://www.phpthinking.com/archives/468
使用PHP的cURL庫可以簡單和有效地去抓網頁。你隻需要運行一個腳本,然後分析一下你所抓取的網頁,然後就可以以程式的方式得到你想要的數據瞭。無論是你想從從一個鏈接上取部分數據,或是取一個XML文件並把其導入伺服器,那怕就是簡單的獲取網頁內容,cURL 是一個功能強大的PHP庫。本文主要講述如果使用這個PHP庫。
啟用 cURL 設置
首先,我們得先要確定我們的PHP是否開啟瞭這個庫,你可以通過使用php_info()函數來得到這一信息。
|
如果你可以在網頁上看到下面的輸出,那麼表示cURL庫已被開啟。
如果你看到的話,那麼你需要設置你的PHP並開啟這個庫。如果你是在Windows平臺下,那麼非常簡單,你需要改一改你的php.ini文件的設置,找到php_curl.dll,並取消前面的分號註釋就行瞭。如下所示:
|
如果你是在Linux下面,那麼,你需要重新編譯你的PHP瞭,編輯時,你需要打開編譯參數——在configure命令上加上“–with-curl” 參數。
一個小示例
如果一切就緒,下面是一個小例程:
|
如何POST數據
上面是抓取網頁的代碼,下面則是向某個網頁POST數據。假設我們有一個處理表單的網址https://www.example.com/sendSMS.php,其可以接受兩個表單域,一個是電話號碼,一個是短信內容。
|
從上面的程式我們可以看到,使用CURLOPT_POST設置HTTP協議的POST方法,而不是GET方法,然後以CURLOPT_POSTFIELDS設置POST的數據。
關於代理伺服器
下面是一個如何使用代理伺服器的示例。請註意其中高亮的代碼,代碼很簡單,我就不用多說瞭。
|
關於SSL和Cookie
關於SSL也就是HTTPS協議,你隻需要把CURLOPT_URL連接中的https://變成https://就可以瞭。當然,還有一個參數叫CURLOPT_SSL_VERIFYHOST可以設置為驗證站點。
關於Cookie,你需要瞭解下面三個參數:
- CURLOPT_COOKIE,在當面的會話中設置一個cookie
- CURLOPT_COOKIEJAR,當會話結束的時候保存一個Cookie
-
CURLOPT_COOKIEFILE,Cookie的文件。
HTTP伺服器認證
最後,我們來看一看HTTP伺服器認證的情況。
<?php
$ch
=
curl_init();curl_setopt(
$ch
,
CURLOPT_URL,'https://www.example.com'
);
curl_setopt(
$ch
,
CURLOPT_RETURNTRANSFER, 1);curl_setopt(
$ch
,
CURLOPT_HTTPAUTH, CURLAUTH_BASIC);curl_setopt(CURLOPT_USERPWD,
'[username]:[password]'
)
$data
=
curl_exec();curl_close(
$ch
);
?>