摘要:七夕啦,作為開發(fā),妹子沒得撩就撩下服務器吧,妹子有得撩的同學那就左擁妹子右抱服務器吧,況且妹子是要禮物的,服務器又不用。下面我們來看一些常用的情景,我們需要如何打扮自己配置參數(shù)才能正確撩妹正確撩到服務器。
0. curl是個什么東西七夕啦,作為開發(fā),妹子沒得撩就“撩”下服務器吧,妹子有得撩的同學那就左擁妹子右抱服務器吧,況且妹子是要禮物的,服務器又不用。好啦,長話短說再長說,祭出今天的工具——CURL(Client URL Library),當然今天以PHP的方式來使用這件工具。
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和許多不同種的服務器進行勾搭、搭訕和深入交流,并且還支持許多協(xié)議。并且人家還說了curl可以支持https認證、http post、ftp上傳、代理、cookies、簡單口令認證等等功能啦。
說了那么多其實沒什么感覺吧,在應用中才有感覺,我起初也是需要在服務器端向另一個服務器發(fā)起一個POST請求才開始接觸curl的,然后才有了感覺。
在正式講怎么用之前啊,先提一句,你得先在你的PHP環(huán)境中安裝和啟用curl模塊,具體方式我就不講了,不同系統(tǒng)不同安裝方式,可以google查一下,或者查閱PHP官方的文檔,還挺簡單的。
1. 拿來先試試手工具到手,先要把玩,試試順不順手,不然一拿來就用,把你自己的代碼搞得烏煙瘴氣還怎么去撩服務器呢?
比如我們以著名的“測試網(wǎng)絡(luò)是否連接”的網(wǎng)站——百度為例,來嘗試下curl
當你在本地環(huán)境瀏覽器打開這個php文件時,頁面出現(xiàn)的是百度的首頁,特么我剛才輸入的“l(fā)ocalhost”呢?
上面的代碼和注釋已經(jīng)充分說明了這段代碼在干啥。
$ch = curl_init(),創(chuàng)建了一個curl會話資源,成功返回一個句柄;
curl_setopt($ch, CURLOPT_URL, "baidu.com"),設(shè)置URL,不用說;
上面兩句可以合起來變一句$ch = curl_init("baidu.com");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0)這是設(shè)置是否將響應結(jié)果存入變量,1是存入,0是直接echo出;
$output = curl_exec($ch)執(zhí)行,然后將響應結(jié)果存入$output變量,供下面echo;
curl_close($ch)關(guān)閉這個curl會話資源。
PHP中使用curl大致就是這么一個形式,其中第二步,通過curl_setopt方法來設(shè)置參數(shù)是最復雜也是最重要的,感興趣可以去看官方的關(guān)于可設(shè)置參數(shù)的詳細參考,長地讓你看得想吐,還是根據(jù)需要熟能生巧吧。
小結(jié)一下,php中curl用法就是:創(chuàng)建curl會話 -> 配置參數(shù) -> 執(zhí)行 -> 關(guān)閉會話。
下面我們來看一些常用的情景,我們需要如何“打扮自己”(配置參數(shù))才能正確“撩妹”(正確撩到服務器)。
2. 打個招呼——GET和POST請求以及HTTPS協(xié)議處理2.1 GET請求先和服務器打個招呼吧,給服務器發(fā)個Hello看她怎么回,這里最方便的方式就是向服務器發(fā)出GET請求,當然POST這種小紙條也OK咯。
我們以“在某著名同性交友網(wǎng)站github中搜索關(guān)鍵詞”為例
//通過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.
即,除非用了非法或者自制的證書,這大多數(shù)出現(xiàn)在開發(fā)環(huán)境中,你才將這兩行設(shè)置為false以避開ssl證書檢查,否者不需要這么做,這么做是不安全的做法。
2.2 POST請求那如何進行POST請求呢?為了測試,先在某個測試服務器傳了一個接收POST的腳本:
//testRespond.php發(fā)送普通數(shù)據(jù)
然后在本地寫一個請求:
"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); ?>
瀏覽器運行結(jié)果是:
name=Lei&msg=Are you OK?
這里我們是構(gòu)造了一個數(shù)組作為POST數(shù)據(jù)傳給服務器:
curl_setopt($ch, CURLOPT_POST, 1)表明是POST請求;
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60)設(shè)置一個最長的可忍受的連接時間,秒為單位,總不能一直等下去變成木乃伊吧;
curl_setopt($ch, CURLOPT_POSTFIELDS , http_build_query($data))設(shè)置POST的數(shù)據(jù)域,因為這里是數(shù)組數(shù)據(jù)形式的(等會來講json格式),所以用http_build_query處理一下。
對于json數(shù)據(jù)呢,又怎么進行POST請求呢?瀏覽器執(zhí)行,顯示:
{"name":"Lei","msg":"Are you OK?"}3. 如何上傳和下載文件
3.1 傳一張自己的照片過去表表誠意 —— POST上傳文件已經(jīng)和服務器勾搭上了,這時候得要個照片來看一看了吧,你也得把自己的照片發(fā)上去讓人看一看了,雖然兩個人在一起外貌不重要,但是男俊女靚總是最棒的。
同樣遠程服務器端我們先傳好一個接收腳本,接收圖片并且保存到本地,注意文件和文件夾權(quán)限問題,需要有寫入權(quán)限:
然后我們再來寫我們本地服務器的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圖片最常見的代碼,這是因為我現(xiàn)在用的是PHP5.6以上版本,@符號在PHP5.6之后就棄用了,PHP5.3依舊可以用,所以有些同學發(fā)現(xiàn)能執(zhí)行啊,有些發(fā)現(xiàn)不能執(zhí)行,大抵是因為PHP版本的不同,而且curl在這兩版本中實現(xiàn)是不兼容的,上面是PHP5.3的實現(xiàn)。
下面來講PHP5.6及以后的實現(xiàn),:
"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對象進行實現(xiàn),關(guān)于此的具體可查閱文檔進行了解。這時候再去遠程服務器目錄下看看,發(fā)現(xiàn)有了一張圖片了,而且確實是我們剛才上傳的圖片。
3.2 獲取遠程服務器妹子的照片 —— 抓取圖片服務器妹子也挺實誠的,看了照騙覺得我長得挺慈眉善目的,就大方得拿出了她自己的照片,但是有點害羞的是,她不愿意主動拿過來,得我們自己去取。
遠程服務器在她自己的目錄下存放了一個圖片叫girl.jpg,地址是她的web服務器根目錄/girl.jpg,現(xiàn)在我要去獲取這張照片。
現(xiàn)在,在我們當前目錄下就有了一張剛拿到的照片啦,是不是很激動呢!
這里值得一說的是curl_getinfo方法,這是一個獲取本次請求相關(guān)信息的方法,對于調(diào)試很有幫助,要善用。
4. HTTP認證怎么搞這個時候呢,服務器的家長說這個我們女兒還太小,不能找對象,就將她女兒關(guān)了起來,并且上了一個密碼鎖,所謂的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 這個方法可以通過數(shù)組一次性地設(shè)置多個參數(shù),防止有些需要多處設(shè)置的出現(xiàn)密密麻麻的curl_setopt方法。
這時你成功見到了服務器妹子,想帶她私奔,但是無奈沒有盤纏走不遠,服務器妹子說,她媽服務器上有金庫,可以登陸上去搞一點下來。
首先我們先來分析一下,這個事情分兩步,一是去登陸界面通過賬號密碼登陸,然后獲取cookie,二是去利用cookie模擬登陸到信息頁面獲取信息,大致的框架是這樣的。
"賬戶", "pwd" => "密碼" ); //登錄地址 $url = "登陸地址"; //設(shè)置cookie保存路徑 $cookie = dirname(__FILE__) . "/cookie.txt"; //登錄后要獲取信息的地址 $url2 = "登陸后要獲取信息的地址"; //模擬登錄 login_post($url, $cookie, $post); //獲取登錄頁的信息 $content = get_content($url2, $cookie); //刪除cookie文件 @ unlink($cookie); var_dump($content); ?>
然后我們思考下下面兩個方法的實現(xiàn):
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); }
//登錄成功后獲取數(shù)據(jù) 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開發(fā)中最常用的幾種場景做一個整理和歸納。最后一句話,具體問題具體分析。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21870.html
摘要:背景最近有需求下載頭像到本地,以文件形式上傳到第三方,遇坑就填第一版將獲取的信息以字符串返回,而不是直接輸出因為要寫文件啟用時會將頭文件的信息作為數(shù)據(jù)流輸出適合調(diào)試配置手冊文檔地址配置項需要什么翻著找找遇到幾個問題部分圖片所在主站防盜鏈機制 背景 最近有需求下載頭像到本地,以文件形式上傳到第三方,遇坑就填 curl 第一版 $ch = curl_init(); curl_setopt_...
摘要:標準是為了最大限度保護持卡人數(shù)據(jù)的一套標準。實現(xiàn)符合標準的支付,有兩種方式加載的托管表單使用的托管表單,加載方便,安全性高,但是用戶定制程度不高,只能稍微改改表單樣式,可以使用自己設(shè)計的表單,調(diào)用做安全性校驗和數(shù)據(jù)發(fā)送接收。 PCI 標準是為了最大限度保護持卡人數(shù)據(jù)的一套標準。要求很多,可以看 PCI標準 站點了解。對于程序猿來說,要保證的是用戶的任何支付信息,都不走自己的服務器,不保...
摘要:安裝常用方法總結(jié)未包含獨立安裝教程聲明依賴的第三方擴展的文件加載該文件需要安裝是的一個類庫依賴管理機制類似的運行需要以上版本并且確定擴展可用為了獲取,我們需要做兩件事。安裝更多的安裝選項可以通過查看。指令執(zhí)行完后,跟就安裝好了。 Composer安裝常用方法總結(jié)(未包含Windows) 獨立安裝Composer教程 composer.json 聲明PHP依賴的第三方擴展的文件 加...
摘要:不支持多進程,如果需要異步請求,非阻塞的方式,請選擇。時會發(fā)送請求,類型為,是表單提交時最常見的一種。允許函數(shù)執(zhí)行的最長秒數(shù)。設(shè)定請求中部分的內(nèi)容。常規(guī)的使用來請求,功能強大,使用方便,按需配置。 在PHP后端的開發(fā)過程中,除了獲取數(shù)據(jù)庫的數(shù)據(jù)和處理數(shù)據(jù)的內(nèi)部邏輯,往往還需要請求其他服務器接口的數(shù)據(jù),我們一般有3種方式來獲取數(shù)據(jù),分別是: file_get_contents fsoc...
摘要:原文地址支付支付步驟為獲取支付寶的配置信息。將得到的數(shù)據(jù)請求支付寶客戶端進行支付。端將拼接好的字符串拿去請求支付寶客戶端即可調(diào)起支付寶進行支付。向支付寶申請新訂單,獲取支付。成功請求回來后,就可以向支付寶發(fā)出一次支付請求。 支付寶在所有支付方式中最好開發(fā)的了,因為文檔比較清晰,而且開發(fā)起來也比較簡單。因此,支付寶的坑是相對較少的。原文地址 APP支付 APP支付步驟為: 獲取支付寶的...
閱讀 1538·2023-04-26 02:03
閱讀 4729·2021-11-22 13:53
閱讀 4633·2021-09-09 11:40
閱讀 3801·2021-09-09 09:34
閱讀 2136·2019-08-30 13:18
閱讀 3511·2019-08-30 11:25
閱讀 3305·2019-08-26 14:06
閱讀 2554·2019-08-26 13:52