怎麼用php模擬登陸(php實現登陸)

本文目錄一覽:

php模擬登陸知乎

想要爬取知乎,首先要解決的就是登錄問題,知乎登錄還是比較簡單的,這裡有一個示例:

而爬取,不過是對登錄成功之後的得到的cookie進行再次利用,使用

curl_setopt($ch,CURLOPT_COOKIEFILE,$cookie_file);

即可。

上面示例最後一步獲取登錄成功後的首頁就做了示範。

至於爬取過程對鏈接(文章鏈接、專欄鏈接等)的解析,需要針對來處理了。

解析可以用phpQuery,也可以用正則。

你可以參考我這個全站爬取程序:

更多關於PHP cURL的內容,請參考《PHP cURL實現模擬登錄與採集使用方法詳解》

更深入討論可以通過我的博客找我。

PHP模擬用戶登錄模塊

html(login.html)

!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “”

html xmlns=””

head

meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″ /

title用戶登錄頁面/title

script language=”javascript”

function check(){

var user = document.getElementById(“user”);

var passwd = document.getElementById(“passwd”);

if(user.value.length == 0){

alert(“用戶名不能為空!”);

return false;

}

if(passwd.value.length  6){

alert(“密碼至少6位!”);

return false;

}

}

/script

/head

body

div style=” width:300px; height:200px; margin:auto auto;”

form name=”login” method=”post” action=”check_login.php”

table width=”300″ height=”200″ cellpadding=”0″ cellspacing=”0″ border=”1px”

tr

td height=”70″用戶名:/td

tdinput id=”user” name=”username” type=”text” //td

/tr

tr

td height=”78″密碼/td

tdinput id=”passwd” name=”password” type=”password” //td

/tr

tr

td colspan=”2″centerinput type=”submit” value=”登錄” onclick=”return check();” /input type=”reset” value=”重置” //center/td

/tr

/table

/form

/div

/body

/html

php(check_login.php)

?php

/*

* 驗證登錄頁

* 2015-6-6

* 預設用戶名admin,密碼1234567,

*  如果相同則顯示登錄成功!,錯誤則顯示用戶或密碼錯誤;

*/

$username = $_POST[‘username’];

$password = $_POST[‘password’];

if($username == ‘admin’  $password ==’1234567′){

echo “登錄成功!”;

}else{

echo “用戶或密碼錯誤”;

}

?

關於php模擬登錄

所謂登錄,一般是POST或者GET一些數據到伺服器,由伺服器進行驗證。

CURL就是HTTP協議的封裝,能個代替瀏覽器發送POST或者GET請求到web server,然後再接收web server的應答數據。

php 模擬 登錄

打開網站讀取cookie然後判斷是否存在cookie如果存在在提示他是否登錄,順便把帳號和密碼存cookie中就行了

如何通過php程序模擬用戶登錄

模擬用戶可以用php的curl的post,例如

$url = “”;

$post_data = array (“username” = “uzuzuz”,”password” = “12345”);

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

// post數據

curl_setopt($ch, CURLOPT_POST, 1);

// post的變數

curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);

$output = curl_exec($ch);

curl_close($ch);

//列印獲得的數據

print_r($output);

具體參考:

怎樣用php中的curl模擬登陸

在我的博客《PHP cURL模擬登錄與採集分析過程詳解》做了詳細的介紹,步驟有:

1. 訪問目標網站

2. 打開Firebug(快捷鍵:F12)

3. 清除【Cookie】

4. 重新訪問目標網站

5. 設置【網路】為[保持]狀態

6. 填寫表單,提交登錄請求

7. 利用【網路】,分析提交信息

8. 複製請求的cURL命令

9. 分析命令傳輸的參數與Cookie和前面頁面響應內容的關聯性

10. 如果遇到Cookie和響應內容都無法查找到的參數,Ctrl+S保存當前頁面為全部,利用文本搜索該參數的位置

11. 利用cURL命令組裝模擬登錄程序

詳情請參考博客內容:

原創文章,作者:MPMPW,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/130053.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
MPMPW的頭像MPMPW
上一篇 2024-10-03 23:27
下一篇 2024-10-03 23:27

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若伺服器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台伺服器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24
  • PHP數組去重詳解

    一、array_unique函數 array_unique是php中常用的數組去重函數,它基於值來判斷元素是否重複,具體使用方法如下: $array = array(‘a’, ‘b…

    編程 2025-04-24
  • PHP導出Excel文件

    一、PHP導出Excel文件列寬調整 當我們使用PHP導出Excel文件時,有時需要調整單元格的列寬。可以使用PHPExcel類庫中的setWidth方法來設置單元格的列寬。下面是…

    編程 2025-04-24
  • php擴展庫初探

    一、什麼是php擴展庫? PHP擴展庫(PHP extension)是一些用C語言編寫的動態鏈接庫,用於擴展PHP的功能。PHP擴展庫使得PHP可以與各種資料庫系統相連、SMTP、…

    編程 2025-04-23

發表回復

登錄後才能評論