国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

在PHP中使用CURL,“撩”服務器只需幾行——php curl詳細解析和常見大坑

SexySix / 1491人閱讀

摘要:七夕啦,作為開發,妹子沒得撩就撩下服務器吧,妹子有得撩的同學那就左擁妹子右抱服務器吧,況且妹子是要禮物的,服務器又不用。下面我們來看一些常用的情景,我們需要如何打扮自己配置參數才能正確撩妹正確撩到服務器。

七夕啦,作為開發,妹子沒得撩就“撩”下服務器吧,妹子有得撩的同學那就左擁妹子右抱服務器吧,況且妹子是要禮物的,服務器又不用。好啦,長話短說再長說,祭出今天的工具——CURL(Client URL Library),當然今天以PHP的方式來使用這件工具。

0. curl是個什么東西

PHP supports libcurl, a library created by Daniel Stenberg, that allows you to connect and communicate to many different types of servers with many different types of protocols. libcurl currently supports the http, https, ftp, gopher, telnet, dict, file, and ldap protocols. libcurl also supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading (this can also be done with PHP"s ftp extension), HTTP form based upload, proxies, cookies, and user+password authentication.

這是PHP對于curl的一個解釋,簡單地說就是,curl是一個庫,能讓你通過URL和許多不同種的服務器進行勾搭、搭訕和深入交流,并且還支持許多協議。并且人家還說了curl可以支持https認證、http post、ftp上傳、代理、cookies、簡單口令認證等等功能啦。

說了那么多其實沒什么感覺吧,在應用中才有感覺,我起初也是需要在服務器端向另一個服務器發起一個POST請求才開始接觸curl的,然后才有了感覺。

在正式講怎么用之前啊,先提一句,你得先在你的PHP環境中安裝和啟用curl模塊,具體方式我就不講了,不同系統不同安裝方式,可以google查一下,或者查閱PHP官方的文檔,還挺簡單的。

1. 拿來先試試手

工具到手,先要把玩,試試順不順手,不然一拿來就用,把你自己的代碼搞得烏煙瘴氣還怎么去撩服務器呢?

比如我們以著名的“測試網絡是否連接”的網站——百度為例,來嘗試下curl

當你在本地環境瀏覽器打開這個php文件時,頁面出現的是百度的首頁,特么我剛才輸入的“localhost”呢?

上面的代碼和注釋已經充分說明了這段代碼在干啥。

$ch = curl_init(),創建了一個curl會話資源,成功返回一個句柄;
curl_setopt($ch, CURLOPT_URL, "baidu.com"),設置URL,不用說;

上面兩句可以合起來變一句$ch = curl_init("baidu.com")

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0)這是設置是否將響應結果存入變量,1是存入,0是直接echo出;

$output = curl_exec($ch)執行,然后將響應結果存入$output變量,供下面echo;

curl_close($ch)關閉這個curl會話資源。

PHP中使用curl大致就是這么一個形式,其中第二步,通過curl_setopt方法來設置參數是最復雜也是最重要的,感興趣可以去看官方的關于可設置參數的詳細參考,長地讓你看得想吐,還是根據需要熟能生巧吧。

小結一下,php中curl用法就是:創建curl會話 -> 配置參數 -> 執行 -> 關閉會話。

下面我們來看一些常用的情景,我們需要如何“打扮自己”(配置參數)才能正確“撩妹”(正確撩到服務器)。

2. 打個招呼——GET和POST請求以及HTTPS協議處理

先和服務器打個招呼吧,給服務器發個Hello看她怎么回,這里最方便的方式就是向服務器發出GET請求,當然POST這種小紙條也OK咯。

2.1 GET請求

我們以“在某著名同性交友網站github中搜索關鍵詞”為例

//通過curl進行GET請求的案例

好像和之前那個例子沒啥差別,但這里有2個可以提的點:
1.默認請求方式是GET,所以不需要顯式指定GET方式;
2.https請求,非http請求,可能有人在各個地方看到過HTTPS請求需要加幾行代碼繞過SSL證書的檢查等方式來成功請求到資源,但是這里好像并不需要,原因是什么?

The two Curl options are defined as:

CURLOPT_SSL_VERIFYPEER - verify the peer"s SSL certificate  
CURLOPT_SSL_VERIFYHOST - verify the certificate"s name against host

They both default to true in Curl, and shouldn"t be disabled unless you"ve got a good reason. Disabling them is generally only needed if you"re sending requests to servers with invalid or self-signed certificates, which is only usually an issue in development. Any publicly-facing site should be presenting a valid certificate, and by disabling these options you"re potentially opening yourself up to security issues.

即,除非用了非法或者自制的證書,這大多數出現在開發環境中,你才將這兩行設置為false以避開ssl證書檢查,否者不需要這么做,這么做是不安全的做法。

2.2 POST請求

那如何進行POST請求呢?為了測試,先在某個測試服務器傳了一個接收POST的腳本:

//testRespond.php
發送普通數據

然后在本地寫一個請求:

 "Lei",
    "msg" => "Are you OK?"
    );

    $ch = curl_init(); 

    curl_setopt($ch, CURLOPT_URL, "http://測試服務器的IP馬賽克/testRespond.php"); 
    curl_setopt($ch, CURLOPT_POST, 1);
    //The number of seconds to wait while trying to connect. Use 0 to wait indefinitely.
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , http_build_query($data));
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);      
?>

瀏覽器運行結果是:

name=Lei&msg=Are you OK?

這里我們是構造了一個數組作為POST數據傳給服務器:

curl_setopt($ch, CURLOPT_POST, 1)表明是POST請求;

curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60)設置一個最長的可忍受的連接時間,秒為單位,總不能一直等下去變成木乃伊吧;

curl_setopt($ch, CURLOPT_POSTFIELDS , http_build_query($data))設置POST的數據域,因為這里是數組數據形式的(等會來講json格式),所以用http_build_query處理一下。

對于json數據呢,又怎么進行POST請求呢?

瀏覽器執行,顯示:

{"name":"Lei","msg":"Are you OK?"}
3. 如何上傳和下載文件

已經和服務器勾搭上了,這時候得要個照片來看一看了吧,你也得把自己的照片發上去讓人看一看了,雖然兩個人在一起外貌不重要,但是男俊女靚總是最棒的。

3.1 傳一張自己的照片過去表表誠意 —— POST上傳文件

同樣遠程服務器端我們先傳好一個接收腳本,接收圖片并且保存到本地,注意文件和文件夾權限問題,需要有寫入權限:

然后我們再來寫我們本地服務器的php curl部分:

"boy", "upload"=>"@boy.png");

    $ch = curl_init(); 

    curl_setopt($ch, CURLOPT_URL, "http://遠程服務器地址馬賽克/testRespond.php"); 
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);         
?>

瀏覽器中運行一下,什么都米有,去看一眼遠程的服務器,還是什么都沒有,并沒有上傳成功。

為什么會這樣呢?上面的代碼應該是大家搜索curl php POST圖片最常見的代碼,這是因為我現在用的是PHP5.6以上版本,@符號在PHP5.6之后就棄用了,PHP5.3依舊可以用,所以有些同學發現能執行啊,有些發現不能執行,大抵是因為PHP版本的不同,而且curl在這兩版本中實現是不兼容的,上面是PHP5.3的實現。

下面來講PHP5.6及以后的實現,:

"boy", "upload"=>"");
    $ch = curl_init(); 

    $data["upload"]=new CURLFile(realpath(getcwd()."/boy.png"));

    curl_setopt($ch, CURLOPT_URL, "http://115.29.247.189/test/testRespond.php");
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);         
?>

這里引入了一個CURLFile對象進行實現,關于此的具體可查閱文檔進行了解。這時候再去遠程服務器目錄下看看,發現有了一張圖片了,而且確實是我們剛才上傳的圖片。

3.2 獲取遠程服務器妹子的照片 —— 抓取圖片

服務器妹子也挺實誠的,看了照騙覺得我長得挺慈眉善目的,就大方得拿出了她自己的照片,但是有點害羞的是,她不愿意主動拿過來,得我們自己去取。

遠程服務器在她自己的目錄下存放了一個圖片叫girl.jpg,地址是她的web服務器根目錄/girl.jpg,現在我要去獲取這張照片。

現在,在我們當前目錄下就有了一張剛拿到的照片啦,是不是很激動呢!

這里值得一說的是curl_getinfo方法,這是一個獲取本次請求相關信息的方法,對于調試很有幫助,要善用。

4. HTTP認證怎么搞

這個時候呢,服務器的家長說這個我們女兒還太小,不能找對象,就將她女兒關了起來,并且上了一個密碼鎖,所謂的HTTP認證,服務器呢偷偷托信鴿將HTTP認證的用戶名和密碼給了你,要你去見她,帶她私奔。

那么拿到了用戶名和密碼,我們怎么通過PHP CURL搞定HTTP認證呢?

PS:這里偷懶就不去搭HTTP認證去試了,直接放一段代碼,我們分析下。

function curl_auth($url,$user,$passwd){
    $ch = curl_init();
    curl_setopt_array($ch, [
        CURLOPT_USERPWD => $user.":".$passwd,
        CURLOPT_URL     => $url,
        CURLOPT_RETURNTRANSFER => true
    ]);
    $result = curl_exec($ch);
    curl_close($ch);
    return $result;
}

$authurl = "http://要請求HTTP認證的地址";

echo curl_auth($authurl,"vace","passwd");

這里有一個地方比較有意思:
curl_setopt_array 這個方法可以通過數組一次性地設置多個參數,防止有些需要多處設置的出現密密麻麻的curl_setopt方法。

5.利用cookie模擬登陸

這時你成功見到了服務器妹子,想帶她私奔,但是無奈沒有盤纏走不遠,服務器妹子說,她媽服務器上有金庫,可以登陸上去搞一點下來。

首先我們先來分析一下,這個事情分兩步,一是去登陸界面通過賬號密碼登陸,然后獲取cookie,二是去利用cookie模擬登陸到信息頁面獲取信息,大致的框架是這樣的。

 "賬戶", 
    "pwd" => "密碼"
  ); 
  //登錄地址  
  $url = "登陸地址";  
  //設置cookie保存路徑  
  $cookie = dirname(__FILE__) . "/cookie.txt";  
  //登錄后要獲取信息的地址  
  $url2 = "登陸后要獲取信息的地址";  
  //模擬登錄 
  login_post($url, $cookie, $post);  
  //獲取登錄頁的信息  
  $content = get_content($url2, $cookie);  
  //刪除cookie文件 
  @ unlink($cookie);
     
  var_dump($content);    
?>

然后我們思考下下面兩個方法的實現:

login_post($url, $cookie, $post)

get_content($url2, $cookie)

//模擬登錄  
function login_post($url, $cookie, $post) { 
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 0);
    curl_setopt($curl, CURLOPT_COOKIEJAR, $cookie);
    curl_setopt($curl, CURLOPT_POST, 1);
    curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($post));
    curl_exec($curl); 
    curl_close($curl);
} 
//登錄成功后獲取數據  
function get_content($url, $cookie) { 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_HEADER, 0); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); 
    $rs = curl_exec($ch); 
    curl_close($ch); 
    return $rs; 
} 

至此,總算是模擬登陸成功,一切順利啦,通過php CURL“撩”服務器就是這么簡單。

當然,CURL的能力遠不止于此,本文僅希望就后端PHP開發中最常用的幾種場景做一個整理和歸納。最后一句話,具體問題具體分析。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/21870.html

相關文章

  • php curl抓取墻外圖片及sftp上傳【填坑指南】

    摘要:背景最近有需求下載頭像到本地,以文件形式上傳到第三方,遇坑就填第一版將獲取的信息以字符串返回,而不是直接輸出因為要寫文件啟用時會將頭文件的信息作為數據流輸出適合調試配置手冊文檔地址配置項需要什么翻著找找遇到幾個問題部分圖片所在主站防盜鏈機制 背景 最近有需求下載頭像到本地,以文件形式上傳到第三方,遇坑就填 curl 第一版 $ch = curl_init(); curl_setopt_...

    ralap 評論0 收藏0
  • 使用Authorize.net的SDK實現符合PCI標準的支付流程

    摘要:標準是為了最大限度保護持卡人數據的一套標準。實現符合標準的支付,有兩種方式加載的托管表單使用的托管表單,加載方便,安全性高,但是用戶定制程度不高,只能稍微改改表單樣式,可以使用自己設計的表單,調用做安全性校驗和數據發送接收。 PCI 標準是為了最大限度保護持卡人數據的一套標準。要求很多,可以看 PCI標準 站點了解。對于程序猿來說,要保證的是用戶的任何支付信息,都不走自己的服務器,不保...

    baukh789 評論0 收藏0
  • Composer安裝說明

    摘要:安裝常用方法總結未包含獨立安裝教程聲明依賴的第三方擴展的文件加載該文件需要安裝是的一個類庫依賴管理機制類似的運行需要以上版本并且確定擴展可用為了獲取,我們需要做兩件事。安裝更多的安裝選項可以通過查看。指令執行完后,跟就安裝好了。 Composer安裝常用方法總結(未包含Windows) 獨立安裝Composer教程 composer.json 聲明PHP依賴的第三方擴展的文件 加...

    Yangder 評論0 收藏0
  • PHP cURL請求詳解

    摘要:不支持多進程,如果需要異步請求,非阻塞的方式,請選擇。時會發送請求,類型為,是表單提交時最常見的一種。允許函數執行的最長秒數。設定請求中部分的內容。常規的使用來請求,功能強大,使用方便,按需配置。 在PHP后端的開發過程中,除了獲取數據庫的數據和處理數據的內部邏輯,往往還需要請求其他服務器接口的數據,我們一般有3種方式來獲取數據,分別是: file_get_contents fsoc...

    paney129 評論0 收藏0
  • 支付開發填坑記之支付寶

    摘要:原文地址支付支付步驟為獲取支付寶的配置信息。將得到的數據請求支付寶客戶端進行支付。端將拼接好的字符串拿去請求支付寶客戶端即可調起支付寶進行支付。向支付寶申請新訂單,獲取支付。成功請求回來后,就可以向支付寶發出一次支付請求。 支付寶在所有支付方式中最好開發的了,因為文檔比較清晰,而且開發起來也比較簡單。因此,支付寶的坑是相對較少的。原文地址 APP支付 APP支付步驟為: 獲取支付寶的...

    chanjarster 評論0 收藏0

發表評論

0條評論

SexySix

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<