国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php中curl模擬登陸用戶百度知道的例子

2024-05-04 21:47:54
字體:
來源:轉載
供稿:網友

最近弄了一個工具,希望能獲取自己百度網盤里面的數據但又不想公開數據,于是想到了模擬登陸百度,用常規的模擬登陸測試了下發現不行,抓取登陸時的數據才發現,其實百度登陸過程中跳轉了幾次頁面,如果僅僅對http://passport.baidu.com/v2/api/?login一個頁面獲取cookie是不完整的那樣就只有BAIDUID的值,而僅僅這個cookie值是沒有多少作用的.

通過對抓包數據的分析,實際登陸過程中是先請求了一次http://passport.baidu.com/v2/api/?getapi&class=login&tpl=mn&tangram=true這個頁面,服務器同時給瀏覽器設置兩個cookie,一個BAIDUID的cookie值,這個應該是與seesion id相關的;另一個是

Set-Cookie:

HOSUPPORT=1; expires=Thu,19-Aug-2021 15:41:37 GMT; path=/; domain=passport.baidu.com; httponly

推測這個應該是百度檢測瀏覽器是否支持cookie;

再次請求該頁面,獲取網頁數據會得到一個token值用于登陸;

然后登陸成功會得到BDUSS等相關的cookie值,以上才是登陸成功,記錄下上面的cookie即可!

下面是簡單的請求及登陸函數集合,作為基礎類吧,可能簡單了點,以后再完善吧!

代碼如下:

  1. <?php 
  2. /** 
  3.  * 百度基礎類 
  4.  * @author  qaulau@hotmail.com 
  5.  * @file    baidu.php 
  6.  * @date    2013-6-2  m.survivalescaperooms.com 
  7. */ 
  8. class baidu{ 
  9.  private $cookie = '';   
  10.  private $username = ''
  11.  private $password = ''
  12.  const COOKIE_DIR = 'temp';   //cookie存放目錄 
  13.  const COOKIE_VALIDATE = 604800; //cookie有效期,默認為7天 
  14.  const SECRET_KEY = 'hAFS6as8askNBVSuiealkkw'//密鑰用于加密cookie文件名,防止保存的cookie路徑被猜測 
  15.  private function http_request($url$post_data$referef,$header = true){ 
  16.   $ch = curl_init(); 
  17.   curl_setopt($ch, CURLOPT_URL, $url); 
  18.   if ($post_data != ""){ 
  19.    curl_setopt($ch, CURLOPT_POST, 1); 
  20.    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); 
  21.   } 
  22.   if ($referef != ""){ 
  23.    curl_setopt($ch, CURLOPT_REFERER, $referef); 
  24.   } 
  25.   curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
  26.   curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
  27.   curl_setopt($ch, CURLOPT_HEADER, $header); 
  28.   curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.64 Safari/537.31"); 
  29.   if ($this->cookie != ""){ 
  30.    curl_setopt($ch, CURLOPT_COOKIE, $this->cookie); 
  31.   } 
  32.   $data = curl_exec($ch); 
  33.   curl_close($ch); 
  34.   if ($header){ 
  35.    preg_match_all('/Set-Cookie:((.+)=(.+))$/m '$data$cookies); 
  36.    if(is_array($cookies) && count($cookies) > 1 && count($cookies[1]) > 0){ 
  37.     foreach($cookies[1] as $i => $k){ 
  38.      $cookieinfos = explode(";"$k); 
  39.      if(is_array($cookieinfos) && count($cookieinfos) > 1){ 
  40.       $this->cookie .= $cookieinfos[0]; 
  41.       $this->cookie .= "; "
  42.      } 
  43.     } 
  44.    }  
  45.   } 
  46.   return $data
  47.  } 
  48.  private function login(){ 
  49.   //生成一個cookie 
  50.   $ret = $this->http_request("https://passport.baidu.com/v2/api/?getapi&class=login&tpl=mn&tangram=true"""""); 
  51.   //獲取token并保存cookie 
  52.   $ret = $this->http_request("https://passport.baidu.com/v2/api/?getapi&class=login&tpl=mn&tangram=true"""""); 
  53.   preg_match_all('/login_token='(.+)'/'$ret$tokens); 
  54.   $login_token = $tokens[1][0]; 
  55.   //登陸并保存cookie 
  56.   $post_data = array(); 
  57.   $post_data['username'] = $this->username; 
  58.   $post_data['password'] = $this->password; 
  59.   $post_data['token'] = $login_token
  60.   $post_data['charset'] = "UTF-8"
  61.   $post_data['callback'] = "parent.bd12Pass.api.login._postCallback"
  62.   $post_data['index'] = "0"
  63.   $post_data['isPhone'] = "false"
  64.   $post_data['mem_pass'] = "on"
  65.   $post_data['loginType'] = "1"
  66.   $post_data['safeflg'] = "0"
  67.   $post_data['staticpage'] = "https://passport.baidu.com/v2Jump.html"
  68.   $post_data['tpl'] = "mn"
  69.   $post_data['u'] = "http://www.baidu.com/"
  70.   $post_data['verifycode'] = ""
  71.   $ret = $this->http_request("http://passport.baidu.com/v2/api/?login"$post_data"https://passport.baidu.com/v2/?login&tpl=mn&u=http%3A%2F%2Fwww.baidu.com%2F"); 
  72.   //記錄下所有cookie 
  73.   $this->writeCookie();   
  74.  } 
  75.  private function writeCookie(){ 
  76.   if(!file_exists(self::COOKIE_DIR)){ 
  77.    @mkdir(self::COOKIE_DIR) && touch(self::COOKIE_DIR.'/index.html'); 
  78.   } 
  79.   $filename = self::COOKIE_DIR.'/'.md5($this->username.self::SECRET_KEY); 
  80.   file_put_contents($filename$this->cookie); 
  81.  } 
  82.  public function baidu($username,$password){ 
  83.   $this->username = $username
  84.   $this->password = $password
  85.   $filename = self::COOKIE_DIR.'/'.md5($this->username.self::SECRET_KEY); 
  86.   if ((@filemtime($filename)+ self::COOKIE_VALIDATE > time()) && ($cookie = file_get_contents($filename))!= ''){ 
  87.   //如果cookie在有效期內且不為空 
  88.    $this->cookie = $cookie
  89.   }else { 
  90.    $this->login(); 
  91.   } 
  92.  } 
  93.  /** m.survivalescaperooms.com 
  94.   * 請求頁面 
  95.   * @param string $url  :頁面地址 
  96.   * @param string $referef :引用頁面 
  97.   * @param string $post_data :post數據,如果填寫則為post方式否則為get方式 
  98.   * 返回頁面數據 
  99.   */ 
  100.  public function request($url,$referef = '',$post_data = ''){ 
  101.   return $this->http_request($url,$referef,$post_data,false); 
  102.  } 

這個只是基本的類,只涉及登陸及請求與提交數據,可在此基礎上使用,例如請求百度云網盤,代碼如下:

  1. $baidu = new baidu('用戶名','密碼'); 
  2. $data = $baidu->request('http://pan.baidu.com/api/list?channel=chunlei&clienttype=0&web=1&num=100&page=1&dir=%2F','http://pan.baidu.com'); 
  3. echo $data

還可以用來作為貼吧的發帖或百度空間更新工具.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 镇雄县| 福建省| 滦平县| 乌鲁木齐县| 浪卡子县| 永和县| 南川市| 宝应县| 潍坊市| 兴安县| 普安县| 武汉市| 田阳县| 汨罗市| 大丰市| 石泉县| 宾川县| 芜湖市| 旌德县| 青铜峡市| 丹江口市| 蒙山县| 元江| 兴业县| 赤峰市| 疏勒县| 瑞安市| 溧水县| 富宁县| 阿克| 安康市| 准格尔旗| 泰和县| 尉氏县| 通州市| 吉木萨尔县| 犍为县| 海安县| 阿坝县| 阿坝县| 施甸县|