首頁 後端開發 php教程 PHP使用Curl實現模擬登入及抓取資料功能範例

PHP使用Curl實現模擬登入及抓取資料功能範例

Apr 27, 2018 pm 03:51 PM
curl php 登入

這篇文章主要介紹了PHP使用Curl實現模擬登入及抓取資料功能,結合實例形式分析了php使用curl進行登陸、驗證、cookie操作與資料抓取等相關實現技巧,需要的朋友可以參考下

本文實例講述了PHP使用Curl實現模擬登入及抓取資料功能。分享給大家供大家參考,具體如下:

使用PHP的Curl擴充庫可以模擬實作登錄,並抓取一些需要使用者帳號登入以後才能查看的資料。具體實現的流程如下(個人總結):

1. 首先需要對對應的登入頁面的html原始碼進行分析,獲得一些必要的資訊:

(1)登入頁面的位址;

(2)驗證碼的位址;

(3)登入表單需要提交的各個欄位的名稱和提交方式;

(4)登入表單提交的位址;

(5)另外要知道要抓取的資料所在的位址。

2. 取得cookie並儲存(針對使用cookie檔案的網站):

$login_url = 'http://www.xxxxx';  //登录页面地址
$cookie_file = dirname(__FILE__)."/pic.cookie";  //cookie文件存放位置(自定义)
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $login_url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);
curl_exec($ch);
curl_close($ch);
登入後複製

3. 取得驗證碼並儲存(針對使用驗證碼的網站):

$verify_url = "http://www.xxxx";   //验证码地址
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $verify_url);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$verify_img = curl_exec($ch);
curl_close($ch);
$fp = fopen("./verify/verifyCode.png",'w');  //把抓取到的图片文件写入本地图片文件保存
fwrite($fp, $verify_img);
fclose($fp);
登入後複製

#說明:

由於無法實作驗證碼的識別,所以我在這裡的做法是,把驗證碼圖片抓取下來存放到本地文件中,然後在自己項目中的html頁面中顯示,讓用戶去填寫,等用戶填寫完帳號、密碼和驗證碼,並點擊提交按鈕之後再去進行下一步的操作。

4. 模擬提交登入表單:

$ post_url = 'http://www.xxxx';   //登录表单提交地址
$post = "username=$account&password=$password&seccodeverify=$verifyCode";//表单提交的数据(根据表单字段名和用户输入决定)
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $ post_url);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post);     //提交方式为post
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
curl_exec($ch);
curl_close($ch);
登入後複製

#5. 抓取資料:

$data_url = "http://www.xxxx";   //数据所在地址
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $data_url);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,0);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
$data = curl_exec($ch);
curl_close($ch);
登入後複製

到目前為止,已經把資料所在位址的這個頁面都抓取下來儲存在字串變數$data中了。

要注意的是抓取下來的是一個網頁的html原始碼,也就是說這個字串中不僅包含了你想要的數據,還包含了許多的html標籤等你不想要的東西。所以如果你想要從中提取出你需要的資料的話,你還要對存放資料的頁面的html程式碼進行分析,然後結合字串操作函數、正規匹配等方法從中提取出你想要的資料。

以上方法對使用http協議的一般網站是有效的。但如果你要模擬登入的是使用了https協議的網站的話還需要添加以下一些處理:

1. 跳過https驗證:

curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
登入後複製

2. 使用用戶代理:

$UserAgent = 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0; SLCC1; .NET CLR 2.0.50727; .NET CLR 3.0.04506; .NET CLR 3.5.21022; .NET CLR 1.0.3705; .NET CLR 1.1.4322)';
curl_setopt($curl, CURLOPT_USERAGENT, $UserAgent);
登入後複製

#注意:如果不加入這些處理的話模擬登入時是不能成功的。

使用以上程式模擬登入網站一般都是能成功的,但實際上還是需要針對模擬登入的網站具體情況具體考慮。例如:有些網站編碼不同,所以你抓取下來的頁面是亂碼的,這時就要進行一下編碼轉換,如:$data = iconv("gb2312", "utf-8",$data) ;,把gbk編碼轉換為utf8編碼。還有一些對安全性要求比較高的網站,例如網銀,會把驗證碼放在一個內聯框架中,這時你就需要先抓取到內聯框架的頁面然後在從中提取出驗證碼的位址,再去抓取驗證碼。還有一些網站(例如網路銀)是在js程式碼中去提交表單的,提交表單之前還會去做一些處理,例如加密等,所以如果你是直接提交的話也是不能登入成功的,你必須要去做類似的處理後再提交,但是這種情況如果你能知道js程式碼中進行的具體操作,比如加密的話,加密演算法是怎樣的,你就可以進行跟它一樣的處理,然後再去提交數據,這樣也是能成功的。但是,關鍵的地方來了,如果你根本不知道它進行的是什麼操作,例如它進行了加密,但是你不知道加密的具體演算法,那麼你就無法進行相同的操作,也就不能成功地模擬登入了。這方面典型的案例就是網銀,它在js程式碼中提交表單之前使用網銀控制項對使用者提交的密碼和驗證碼進行了一些處理,但是我們根本不知道它進行的是什麼操作,所以無法模擬。所以如果你以為你看了本文之後就能模擬登入網路銀行的話那麼你就太天真了,人家銀行的網站能那麼容易被你模擬登入嗎?當然,如果你能破解網路銀控制的話,那就另當別論了。話說回來,為什麼我的感受如此深刻,因為我就遇到這個難題了,不說了,說多了都是淚啊。 。 。

相關推薦:

php使用gearman進行任務分發

#PHP使用zlib擴充實作GZIP壓縮輸出的方法

PHP使用Nginx實作反向代理

###########################

以上是PHP使用Curl實現模擬登入及抓取資料功能範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

CakePHP 日期和時間 CakePHP 日期和時間 Sep 10, 2024 pm 05:27 PM

為了在 cakephp4 中處理日期和時間,我們將使用可用的 FrozenTime 類別。

討論 CakePHP 討論 CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP 是 PHP 的開源框架。它旨在使應用程式的開發、部署和維護變得更加容易。 CakePHP 基於類似 MVC 的架構,功能強大且易於掌握。模型、視圖和控制器 gu

CakePHP 檔案上傳 CakePHP 檔案上傳 Sep 10, 2024 pm 05:27 PM

為了進行文件上傳,我們將使用表單助理。這是文件上傳的範例。

CakePHP 建立驗證器 CakePHP 建立驗證器 Sep 10, 2024 pm 05:26 PM

可以透過在控制器中新增以下兩行來建立驗證器。

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

CakePHP 快速指南 CakePHP 快速指南 Sep 10, 2024 pm 05:27 PM

CakePHP 是一個開源MVC 框架。它使應用程式的開發、部署和維護變得更加容易。 CakePHP 有許多函式庫可以減少大多數常見任務的過載。

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

See all articles