Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 亚洲精品国产成人99久久,国产一区二区三区电影,午夜视频在线观看福利视频

          整合營銷服務(wù)商

          電腦端+手機端+微信端=數(shù)據(jù)同步管理

          免費咨詢熱線:

          PHP中使用cURL實現(xiàn)Get和Post請求的方法(

          PHP中使用cURL實現(xiàn)Get和Post請求的方法(最全)

          .cURL介紹

          cURL 是一個利用URL語法規(guī)定來傳輸文件和數(shù)據(jù)的工具,支持很多協(xié)議,如HTTP、FTP、TELNET等。最爽的是,PHP也支持 cURL 庫。本文將介紹 cURL 的一些高級特性,以及在PHP中如何運用它。

          2.基本結(jié)構(gòu)

          在學(xué)習(xí)更為復(fù)雜的功能之前,先來看一下在PHP中建立cURL請求的基本步驟:

          (1)初始化

          curl_init()

          (2)設(shè)置變量

          curl_setopt() 。最為重要,一切玄妙均在此。有一長串cURL參數(shù)可供設(shè)置,它們能指定URL請求的各個細(xì)節(jié)。要一次性全部看完并理解可能比較困難,所以今天我們只試一下那些更常用也更有用的選項。

          (3)執(zhí)行并獲取結(jié)果

          curl_exec()

          (4)釋放cURL句柄

          curl_close()

          3.cURL實現(xiàn)Get和Post

          3.1 Get方式實現(xiàn)

          //初始化

          3.2 Post方式實現(xiàn)

           $url="http://localhost/web_services.php";

          以上方式獲取到的數(shù)據(jù)是json格式的,使用json_decode函數(shù)解釋成數(shù)組。

          $output_array=json_decode($output,true);

          如果使用json_decode($output)解析的話,將會得到object類型的數(shù)據(jù)。

          PHP CURL CURLOPT參數(shù)說明(curl_setopt)

          CURLOPT_RETURNTRANSFER 選項:

          curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);

          如果成功只將結(jié)果返回,不自動輸出任何內(nèi)容。

          如果失敗返回FALSE

          curl_setopt($ch, CURLOPT_RETURNTRANSFER,0); 或著不使用這個選項:

          如果成功只返回TRUE,自動輸出返回的內(nèi)容。

          如果失敗返回FALSE

          PHP中CURL方法curl_setopt()函數(shù)的一些參數(shù) .

          bool curl_setopt (int ch, string option, mixed value)

          curl_setopt()函數(shù)將為一個CURL會話設(shè)置選項。option參數(shù)是你想要的設(shè)置,value是這個選項給定的值。

          下列選項的值將被作為長整形使用(在option參數(shù)中指定):

          ? CURLOPT_INFILESIZE : 當(dāng)你上傳一個文件到遠(yuǎn)程站點,這個選項告訴PHP你上傳文件的大小。

          ? CURLOPT_VERBOSE : 如果你想CURL報告每一件意外的事情,設(shè)置這個選項為一個非零值。

          ? CURLOPT_HEADER : 如果你想把一個頭包含在輸出中,設(shè)置這個選項為一個非零值。

          ? CURLOPT_NOPROGRESS: 如果你不會PHP為CURL傳輸顯示一個進(jìn)程條,設(shè)置這個選項為一個非零值。注意:PHP自動設(shè)置這個選項為非零值,你應(yīng)該僅僅為了調(diào)試的目的來改變這個選項。

          ? CURLOPT_NOBODY : 如果你不想在輸出中包含body部分,設(shè)置這個選項為一個非零值。

          ? CURLOPT_FAILONERROR : 如果你想讓PHP在發(fā)生錯誤(HTTP代碼返回大于等于300)時,不顯示,設(shè)置這個選項為一人非零值。默認(rèn)行為是返回一個正常頁,忽略代碼。

          ? CURLOPT_UPLOAD: 如果你想讓PHP為上傳做準(zhǔn)備,設(shè)置這個選項為一個非零值。

          ? CURLOPT_POST : 如果你想PHP去做一個正規(guī)的HTTP POST,設(shè)置這個選項為一個非零值。這個POST是普通的 application/x-www-from-urlencoded 類型,多數(shù)被HTML表單使用。

          ? CURLOPT_FTPLISTONLY : 設(shè)置這個選項為非零值,PHP將列出FTP的目錄名列表。

          ? CURLOPT_FTPAPPEND : 設(shè)置這個選項為一個非零值,PHP將應(yīng)用遠(yuǎn)程文件代替覆蓋它。

          ? CURLOPT_NETRC : 設(shè)置這個選項為一個非零值,PHP將在你的 ~./netrc 文件中查找你要建立連接的遠(yuǎn)程站點的用戶名及密碼。

          ? CURLOPT_FOLLOWLOCATION : 設(shè)置這個選項為一個非零值(象 “Location: “)的頭,服務(wù)器會把它當(dāng)做HTTP頭的一部分發(fā)送(注意這是遞歸的,PHP將發(fā)送形如 “Location: “的頭)。

          ? CURLOPT_PUT : 設(shè)置這個選項為一個非零值去用HTTP上傳一個文件。要上傳這個文件必須設(shè)置CURLOPT_INFILE和CURLOPT_INFILESIZE選項.

          ? CURLOPT_MUTE : 設(shè)置這個選項為一個非零值,PHP對于CURL函數(shù)將完全沉默。

          ? CURLOPT_TIMEOUT : 設(shè)置一個長整形數(shù),作為最大延續(xù)多少秒。

          ? CURLOPT_LOW_SPEED_LIMIT: 設(shè)置一個長整形數(shù),控制傳送多少字節(jié)。

          ? CURLOPT_LOW_SPEED_TIME : 設(shè)置一個長整形數(shù),控制多少秒傳送CURLOPT_LOW_SPEED_LIMIT規(guī)定的字節(jié)數(shù)。

          ? CURLOPT_RESUME_FROM : 傳遞一個包含字節(jié)偏移地址的長整形參數(shù),(你想轉(zhuǎn)移到的開始表單)。

          ? CURLOPT_SSLVERSION: 傳遞一個包含SSL版本的長參數(shù)。默認(rèn)PHP將被它自己努力的確定,在更多的安全中你必須手工設(shè)置。

          ? CURLOPT_TIMECONDITION : 傳遞一個長參數(shù),指定怎么處理CURLOPT_TIMEVALUE參數(shù)。你可以設(shè)置這個參數(shù)為TIMECOND_IFMODSINCE 或 TIMECOND_ISUNMODSINCE。這僅用于HTTP。

          ? CURLOPT_TIMEVALUE : 傳遞一個從1970-1-1開始到現(xiàn)在的秒數(shù)。這個時間將被CURLOPT_TIMEVALUE選項作為指定值使用,或被默認(rèn)TIMECOND_IFMODSINCE使用。

          下列選項的值將被作為字符串:

          ? CURLOPT_URL: 這是你想用PHP取回的URL地址。你也可以在用curl_init()函數(shù)初始化時設(shè)置這個選項。

          ? CURLOPT_USERPWD : 傳遞一個形如[username]:[password]風(fēng)格的字符串,作用PHP去連接。

          ? CURLOPT_PROXYUSERPWD : 傳遞一個形如[username]:[password] 格式的字符串去連接HTTP代理。

          ? CURLOPT_RANGE : 傳遞一個你想指定的范圍。它應(yīng)該是”X-Y”格式,X或Y是被除外的。HTTP傳送同樣支持幾個間隔,用逗句來分隔(X-Y,N-M)。

          ? CURLOPT_POSTFIELDS : 傳遞一個作為HTTP “POST”操作的所有數(shù)據(jù)的字符串。

          ? CURLOPT_REFERER: 在HTTP請求中包含一個”referer”頭的字符串。

          ? CURLOPT_USERAGENT : 在HTTP請求中包含一個”user-agent”頭的字符串。

          ? CURLOPT_FTPPORT: 傳遞一個包含被ftp “POST”指令使用的IP地址。這個POST指令告訴遠(yuǎn)程服務(wù)器去連接我們指定的IP地址。這個字符串可以是一個IP地址,一個主機名,一個網(wǎng)絡(luò)界面名(在UNIX下),或是‘-'(使用系統(tǒng)默認(rèn)IP地址)。

          ? CURLOPT_COOKIE : 傳遞一個包含HTTP cookie的頭連接。

          ? CURLOPT_SSLCERT : 傳遞一個包含PEM格式證書的字符串。

          ? CURLOPT_SSLCERTPASSWD : 傳遞一個包含使用CURLOPT_SSLCERT證書必需的密碼。

          ? CURLOPT_COOKIEFILE : 傳遞一個包含cookie數(shù)據(jù)的文件的名字的字符串。這個cookie文件可以是Netscape格式,或是堆存在文件中的HTTP風(fēng)格的頭。

          ? CURLOPT_CUSTOMREQUEST : 當(dāng)進(jìn)行HTTP請求時,傳遞一個字符被GET或HEAD使用。為進(jìn)行DELETE或其它操作是有益的,更Pass a string to be used instead of GET or HEAD when doing an HTTP request. This is useful for doing or another, more obscure, HTTP request. 注意: 在確認(rèn)你的服務(wù)器支持命令先不要去這樣做。下列的選項要求一個文件描述(通過使用fopen()函數(shù)獲得):

          ? CURLOPT_FILE: 這個文件將是你放置傳送的輸出文件,默認(rèn)是STDOUT.

          ? CURLOPT_INFILE : 這個文件是你傳送過來的輸入文件。

          ? CURLOPT_WRITEHEADER : 這個文件寫有你輸出的頭部分。

          ? CURLOPT_STDERR : 這個文件寫有錯誤而不是stderr。用來獲取需要登錄的頁面的例子,當(dāng)前做法是每次或許都登錄一次,有需要的人再做改進(jìn)了.

          例一:

          $cookie_jar=tempnam('./tmp','cookie');

          例二:

          $ch2=curl_init();

          例三:

          set_time_limit(0);

          刷論壇代碼:

          1、抓cookies程序:

          $URL="http://www.yoururl.com/bbs/login.asp?action=chk";

          2、刷樓了:

          set_time_limit(0);

          curl_close — 關(guān)閉一個curl會話

          curl_copy_handle — 拷貝一個curl連接資源的所有內(nèi)容和參數(shù)

          curl_errno — 返回一個包含當(dāng)前會話錯誤信息的數(shù)字編號

          curl_error — 返回一個包含當(dāng)前會話錯誤信息的字符串

          curl_exec — 執(zhí)行一個curl會話

          curl_getinfo — 獲取一個curl連接資源句柄的信息

          curl_init — 初始化一個curl會話

          curl_multi_add_handle — 向curl批處理會話中添加單獨的curl句柄資源

          curl_multi_close — 關(guān)閉一個批處理句柄資源

          curl_multi_exec — 解析一個curl批處理句柄

          curl_multi_getcontent — 返回獲取的輸出的文本流

          curl_multi_info_read — 獲取當(dāng)前解析的curl的相關(guān)傳輸信息

          curl_multi_init — 初始化一個curl批處理句柄資源

          curl_multi_remove_handle — 移除curl批處理句柄資源中的某個句柄資源

          curl_multi_select — Get all the sockets associated with the cURL extension, which can then be "selected"

          curl_setopt_array — 以數(shù)組的形式為一個curl設(shè)置會話參數(shù)

          curl_setopt — 為一個curl設(shè)置會話參數(shù)

          curl_version — 獲取curl相關(guān)的版本信息

          curl_init()函數(shù)的作用初始化一個curl會話,curl_init()函數(shù)唯一的一個參數(shù)是可選的,表示一個url地址。

          curl_exec()函數(shù)的作用是執(zhí)行一個curl會話,唯一的參數(shù)是curl_init()函數(shù)返回的句柄。

          curl_close()函數(shù)的作用是關(guān)閉一個curl會話,唯一的參數(shù)是curl_init()函數(shù)返回的句柄。

          $ch=curl_init("http://www.baidu.com/");

          curl_exec($ch);

          curl_close($ch);

          curl_version()函數(shù)的作用是獲取curl相關(guān)的版本信息,curl_version()函數(shù)有一個參數(shù),不清楚是做什么的

          print_r(curl_version())

          curl_getinfo()函數(shù)的作用是獲取一個curl連接資源句柄的信息,curl_getinfo()函數(shù)有兩個參數(shù),第一個參數(shù)是curl的資源句柄,第二個參數(shù)是下面一些常量:

          $ch=curl_init("http://www.baidu.com/");

          print_r(curl_getinfo($ch));

          可選的常量包括:

          CURLINFO_EFFECTIVE_URL

          最后一個有效的url地址

          CURLINFO_HTTP_CODE

          最后一個收到的HTTP代碼

          CURLINFO_FILETIME

          遠(yuǎn)程獲取文檔的時間,如果無法獲取,則返回值為“-1”

          CURLINFO_TOTAL_TIME

          最后一次傳輸所消耗的時間

          CURLINFO_NAMELOOKUP_TIME

          名稱解析所消耗的時間

          CURLINFO_CONNECT_TIME

          建立連接所消耗的時間

          CURLINFO_PRETRANSFER_TIME

          從建立連接到準(zhǔn)備傳輸所使用的時間

          CURLINFO_STARTTRANSFER_TIME

          從建立連接到傳輸開始所使用的時間

          CURLINFO_REDIRECT_TIME

          在事務(wù)傳輸開始前重定向所使用的時間

          CURLINFO_SIZE_UPLOAD

          上傳數(shù)據(jù)量的總值

          CURLINFO_SIZE_DOWNLOAD

          下載數(shù)據(jù)量的總值

          CURLINFO_SPEED_DOWNLOAD

          平均下載速度

          CURLINFO_SPEED_UPLOAD

          平均上傳速度

          CURLINFO_HEADER_SIZE

          header部分的大小

          CURLINFO_HEADER_OUT

          發(fā)送請求的字符串

          CURLINFO_REQUEST_SIZE

          在HTTP請求中有問題的請求的大小

          CURLINFO_SSL_VERIFYRESULT

          Result of SSL certification verification requested by setting CURLOPT_SSL_VERIFYPEER

          CURLINFO_CONTENT_LENGTH_DOWNLOAD

          從Content-Length: field中讀取的下載內(nèi)容長度

          CURLINFO_CONTENT_LENGTH_UPLOAD

          上傳內(nèi)容大小的說明

          CURLINFO_CONTENT_TYPE

          下載內(nèi)容的“Content-type”值,NULL表示服務(wù)器沒有發(fā)送有效的“Content-Type: header”

          curl_setopt()函數(shù)的作用是為一個curl設(shè)置會話參數(shù)。curl_setopt_array()函數(shù)的作用是以數(shù)組的形式為一個curl設(shè)置會話參數(shù)。

          $ch=curl_init();

          可設(shè)置的參數(shù)有:

          CURLOPT_AUTOREFERER

          自動設(shè)置header中的referer信息

          CURLOPT_BINARYTRANSFER

          在啟用CURLOPT_RETURNTRANSFER時候?qū)@取數(shù)據(jù)返回

          CURLOPT_COOKIESESSION

          啟用時curl會僅僅傳遞一個session cookie,忽略其他的cookie,默認(rèn)狀況下curl會將所有的cookie返回給服務(wù)端。session cookie是指那些用來判斷服務(wù)器端的session是否有效而存在的cookie。

          CURLOPT_CRLF

          啟用時將Unix的換行符轉(zhuǎn)換成回車換行符。

          CURLOPT_DNS_USE_GLOBAL_CACHE

          啟用時會啟用一個全局的DNS緩存,此項為線程安全的,并且默認(rèn)為true。

          CURLOPT_FAILONERROR

          顯示HTTP狀態(tài)碼,默認(rèn)行為是忽略編號小于等于400的HTTP信息

          CURLOPT_FILETIME

          啟用時會嘗試修改遠(yuǎn)程文檔中的信息。結(jié)果信息會通過curl_getinfo()函數(shù)的CURLINFO_FILETIME選項返回。

          CURLOPT_FOLLOWLOCATION

          啟用時會將服務(wù)器服務(wù)器返回的“Location:”放在header中遞歸的返回給服務(wù)器,使用CURLOPT_MAXREDIRS可以限定遞歸返回的數(shù)量。

          CURLOPT_FORBID_REUSE

          在完成交互以后強迫斷開連接,不能重用。

          CURLOPT_FRESH_CONNECT

          強制獲取一個新的連接,替代緩存中的連接。

          CURLOPT_FTP_USE_EPRT

          TRUE to use EPRT (and LPRT) when doing active FTP downloads. Use FALSE to disable EPRT and LPRT and use PORT only.

          Added in PHP 5.0.0.

          CURLOPT_FTP_USE_EPSV

          TRUE to first try an EPSV command for FTP transfers before reverting back to PASV. Set to FALSE to disable EPSV.

          CURLOPT_FTPAPPEND

          TRUE to append to the remote file instead of overwriting it.

          CURLOPT_FTPASCII

          An alias of CURLOPT_TRANSFERTEXT. Use that instead.

          CURLOPT_FTPLISTONLY

          TRUE to only list the names of an FTP directory.

          CURLOPT_HEADER

          啟用時會將頭文件的信息作為數(shù)據(jù)流輸出。

          CURLOPT_HTTPGET

          啟用時會設(shè)置HTTP的method為GET,因為GET是默認(rèn)是,所以只在被修改的情況下使用。

          CURLOPT_HTTPPROXYTUNNEL

          啟用時會通過HTTP代理來傳輸。

          CURLOPT_MUTE

          講curl函數(shù)中所有修改過的參數(shù)恢復(fù)默認(rèn)值。

          CURLOPT_NETRC

          在連接建立以后,訪問~/.netrc文件獲取用戶名和密碼信息連接遠(yuǎn)程站點。

          CURLOPT_NOBODY

          啟用時將不對HTML中的body部分進(jìn)行輸出。

          CURLOPT_NOPROGRESS

          啟用時關(guān)閉curl傳輸?shù)倪M(jìn)度條,此項的默認(rèn)設(shè)置為true

          CURLOPT_NOSIGNAL

          啟用時忽略所有的curl傳遞給php進(jìn)行的信號。在SAPI多線程傳輸時此項被默認(rèn)打開。

          CURLOPT_POST

          啟用時會發(fā)送一個常規(guī)的POST請求,類型為:application/x-www-form-urlencoded,就像表單提交的一樣。

          CURLOPT_PUT

          啟用時允許HTTP發(fā)送文件,必須同時設(shè)置CURLOPT_INFILE和CURLOPT_INFILESIZE

          CURLOPT_RETURNTRANSFER

          講curl_exec()獲取的信息以文件流的形式返回,而不是直接輸出。

          CURLOPT_SSL_VERIFYPEER

          FALSE to stop cURL from verifying the peer's certificate. Alternate certificates to verify against can be specified with the CURLOPT_CAINFO option or a certificate directory can be specified with the CURLOPT_CAPATH option. CURLOPT_SSL_VERIFYHOST may also need to be TRUE or FALSE if CURLOPT_SSL_VERIFYPEER is disabled (it defaults to 2). TRUE by default as of cURL 7.10. Default bundle installed as of cURL 7.10.

          CURLOPT_TRANSFERTEXT

          TRUE to use ASCII mode for FTP transfers. For LDAP, it retrieves data in plain text instead of HTML. On Windows systems, it will not set STDOUT to binary mode.

          CURLOPT_UNRESTRICTED_AUTH

          在使用CURLOPT_FOLLOWLOCATION產(chǎn)生的header中的多個locations中持續(xù)追加用戶名和密碼信息,即使域名已發(fā)生改變。

          CURLOPT_UPLOAD

          啟用時允許文件傳輸

          CURLOPT_VERBOSE

          啟用時會匯報所有的信息,存放在STDERR或指定的CURLOPT_STDERR中

          CURLOPT_BUFFERSIZE

          每次獲取的數(shù)據(jù)中讀入緩存的大小,這個值每次都會被填滿。

          CURLOPT_CLOSEPOLICY

          不是CURLCLOSEPOLICY_LEAST_RECENTLY_USED就是CURLCLOSEPOLICY_OLDEST,還存在另外三個,但是curl暫時還不支持。.

          CURLOPT_CONNECTTIMEOUT

          在發(fā)起連接前等待的時間,如果設(shè)置為0,則不等待。

          CURLOPT_DNS_CACHE_TIMEOUT

          設(shè)置在內(nèi)存中保存DNS信息的時間,默認(rèn)為120秒。

          CURLOPT_FTPSSLAUTH

          The FTP authentication method (when is activated): CURLFTPAUTH_SSL (try SSL first), CURLFTPAUTH_TLS (try TLS first), or CURLFTPAUTH_DEFAULT (let cURL decide).

          CURLOPT_HTTP_VERSION

          設(shè)置curl使用的HTTP協(xié)議,CURL_HTTP_VERSION_NONE(讓curl自己判斷),CURL_HTTP_VERSION_1_0(HTTP/1.0),CURL_HTTP_VERSION_1_1(HTTP/1.1)

          CURLOPT_HTTPAUTH

          使用的HTTP驗證方法,可選的值 有:CURLAUTH_BASIC,CURLAUTH_DIGEST,CURLAUTH_GSSNEGOTIATE,CURLAUTH_NTLM,CURLAUTH_ANY,CURLAUTH_ANYSAFE, 可以使用“|”操作符分隔多個值,curl讓服務(wù)器選擇一個支持最好的值,CURLAUTH_ANY等價于CURLAUTH_BASIC | CURLAUTH_DIGEST | CURLAUTH_GSSNEGOTIATE | CURLAUTH_NTLM,CURLAUTH_ANYSAFE等價于CURLAUTH_DIGEST | CURLAUTH_GSSNEGOTIATE | CURLAUTH_NTLM

          CURLOPT_INFILESIZE

          設(shè)定上傳文件的大小

          CURLOPT_LOW_SPEED_LIMIT

          當(dāng)傳輸速度小于CURLOPT_LOW_SPEED_LIMIT時,PHP會根據(jù)CURLOPT_LOW_SPEED_TIME來判斷是否因太慢而取消傳輸。

          CURLOPT_LOW_SPEED_TIME

          The number of seconds the transfer should be below CURLOPT_LOW_SPEED_LIMIT for PHP to consider the transfer too slow and abort.

          當(dāng)傳輸速度小于CURLOPT_LOW_SPEED_LIMIT時,PHP會根據(jù)CURLOPT_LOW_SPEED_TIME來判斷是否因太慢而取消傳輸。

          CURLOPT_MAXCONNECTS

          允許的最大連接數(shù)量,超過是會通過CURLOPT_CLOSEPOLICY決定應(yīng)該停止哪些連接

          CURLOPT_MAXREDIRS

          指定最多的HTTP重定向的數(shù)量,這個選項是和CURLOPT_FOLLOWLOCATION一起使用的。

          CURLOPT_PORT

          一個可選的用來指定連接端口的量

          CURLOPT_PROXYAUTH

          The HTTP authentication method(s) to use for the proxy connection. Use the same bitmasks as described in CURLOPT_HTTPAUTH. For proxy authentication, only CURLAUTH_BASIC and CURLAUTH_NTLM are currently supported.

          CURLOPT_PROXYPORT

          The port number of the proxy to connect to. This port number can also be set in CURLOPT_PROXY.

          CURLOPT_PROXYTYPE

          Either CURLPROXY_HTTP (default) or CURLPROXY_SOCKS5.

          CURLOPT_RESUME_FROM

          在恢復(fù)傳輸時傳遞一個字節(jié)偏移量(用來斷點續(xù)傳)

          CURLOPT_SSL_VERIFYHOST

          1 to check the existence of a common name in the SSL peer certificate.

          2 to check the existence of a common name and also verify that it matches the hostname provided.

          CURLOPT_SSLVERSION

          The SSL version (2 or 3) to use. By default PHP will try to determine this itself, although in some cases this must be set manually.

          CURLOPT_TIMECONDITION

          如果在CURLOPT_TIMEVALUE指定的某個時間以后被編輯過,則使用CURL_TIMECOND_IFMODSINCE返回頁面,如果沒有被修 改過,并且CURLOPT_HEADER為true,則返回一個"304 Not Modified"的header,CURLOPT_HEADER為false,則使用CURL_TIMECOND_ISUNMODSINCE,默認(rèn)值為 CURL_TIMECOND_IFMODSINCE

          CURLOPT_TIMEOUT

          設(shè)置curl允許執(zhí)行的最長秒數(shù)

          CURLOPT_TIMEVALUE

          設(shè)置一個CURLOPT_TIMECONDITION使用的時間戳,在默認(rèn)狀態(tài)下使用的是CURL_TIMECOND_IFMODSINCE

          CURLOPT_CAINFO

          The name of a file holding one or more certificates to verify the peer with. This only makes sense when used in combination with CURLOPT_SSL_VERIFYPEER.

          CURLOPT_CAPATH

          A directory that holds multiple CA certificates. Use this option alongside CURLOPT_SSL_VERIFYPEER.

          CURLOPT_COOKIE

          設(shè)定HTTP請求中“Set-Cookie:”部分的內(nèi)容。

          CURLOPT_COOKIEFILE

          包含cookie信息的文件名稱,這個cookie文件可以是Netscape格式或者HTTP風(fēng)格的header信息。

          CURLOPT_COOKIEJAR

          連接關(guān)閉以后,存放cookie信息的文件名稱

          CURLOPT_CUSTOMREQUEST

          A custom request method to use instead of "GET" or "HEAD" when doing a HTTP request. This is useful for doing "DELETE" or other, more obscure HTTP requests. Valid values are things like "GET", "POST", "CONNECT" and so on; i.e. Do not enter a whole HTTP request line here. For instance, entering "GET /index.html HTTP/1.0\r\n\r\n" would be incorrect.

          Note: Don't do this without making sure the server supports the custom request method first.

          CURLOPT_EGBSOCKET

          Like CURLOPT_RANDOM_FILE, except a filename to an Entropy Gathering Daemon socket.

          CURLOPT_ENCODING

          header中“Accept-Encoding: ”部分的內(nèi)容,支持的編碼格式為:"identity","deflate","gzip"。如果設(shè)置為空字符串,則表示支持所有的編碼格式

          CURLOPT_FTPPORT

          The value which will be used to get the IP address to use for the FTP "POST" instruction. The "POST" instruction tells the remote server to connect to our specified IP address. The string may be a plain IP address, a hostname, a network interface name (under Unix), or just a plain '-' to use the systems default IP address.

          CURLOPT_INTERFACE

          在外部網(wǎng)絡(luò)接口中使用的名稱,可以是一個接口名,IP或者主機名。

          CURLOPT_KRB4LEVEL

          KRB4(Kerberos 4)安全級別的設(shè)置,可以是一下幾個值之一:"clear","safe","confidential","private"。默認(rèn)的值 為"private",設(shè)置為null的時候表示禁用KRB4,現(xiàn)在KRB4安全僅能在FTP傳輸中使用。

          CURLOPT_POSTFIELDS

          在HTTP中的“POST”操作。如果要傳送一個文件,需要一個@開頭的文件名

          CURLOPT_PROXY

          設(shè)置通過的HTTP代理服務(wù)器

          CURLOPT_PROXYUSERPWD

          連接到代理服務(wù)器的,格式為“[username]:[password]”的用戶名和密碼。

          CURLOPT_RANDOM_FILE

          設(shè)定存放SSL用到的隨機數(shù)種子的文件名稱

          CURLOPT_RANGE

          設(shè)置HTTP傳輸范圍,可以用“X-Y”的形式設(shè)置一個傳輸區(qū)間,如果有多個HTTP傳輸,則使用逗號分隔多個值,形如:"X-Y,N-M"。

          CURLOPT_REFERER

          設(shè)置header中"Referer: " 部分的值。

          CURLOPT_SSL_CIPHER_LIST

          A list of ciphers to use for SSL. For example, RC4-SHA and TLSv1 are valid cipher lists.

          CURLOPT_SSLCERT

          傳遞一個包含PEM格式證書的字符串。

          CURLOPT_SSLCERTPASSWD

          傳遞一個包含使用CURLOPT_SSLCERT證書必需的密碼。

          CURLOPT_SSLCERTTYPE

          The format of the certificate. Supported formats are "PEM" (default), "DER", and "ENG".

          CURLOPT_SSLENGINE

          The identifier for the crypto engine of the private SSL key specified in CURLOPT_SSLKEY.

          CURLOPT_SSLENGINE_DEFAULT

          The identifier for the crypto engine used for asymmetric crypto operations.

          CURLOPT_SSLKEY

          The name of a file containing a private SSL key.

          CURLOPT_SSLKEYPASSWD

          The secret password needed to use the private SSL key specified in CURLOPT_SSLKEY.

          Note: Since this option contains a sensitive password, remember to keep the PHP script it is contained within safe.

          CURLOPT_SSLKEYTYPE

          The key type of the private SSL key specified in CURLOPT_SSLKEY. Supported key types are "PEM" (default), "DER", and "ENG".

          CURLOPT_URL

          需要獲取的URL地址,也可以在PHP的curl_init()函數(shù)中設(shè)置。

          CURLOPT_USERAGENT

          在HTTP請求中包含一個”user-agent”頭的字符串。

          CURLOPT_USERPWD

          傳遞一個連接中需要的用戶名和密碼,格式為:“[username]:[password]”。

          CURLOPT_HTTP200ALIASES

          設(shè)置不再以error的形式來處理HTTP 200的響應(yīng),格式為一個數(shù)組。

          CURLOPT_HTTPHEADER

          設(shè)置一個header中傳輸內(nèi)容的數(shù)組。

          CURLOPT_POSTQUOTE

          An array of FTP commands to execute on the server after the FTP request has been performed.

          CURLOPT_QUOTE

          An array of FTP commands to execute on the server prior to the FTP request.

          CURLOPT_FILE

          設(shè)置輸出文件的位置,值是一個資源類型,默認(rèn)為STDOUT (瀏覽器)。

          CURLOPT_INFILE

          在上傳文件的時候需要讀取的文件地址,值是一個資源類型。

          CURLOPT_STDERR

          設(shè)置一個錯誤輸出地址,值是一個資源類型,取代默認(rèn)的STDERR。

          CURLOPT_WRITEHEADER

          設(shè)置header部分內(nèi)容的寫入的文件地址,值是一個資源類型。

          CURLOPT_HEADERFUNCTION

          設(shè)置一個回調(diào)函數(shù),這個函數(shù)有兩個參數(shù),第一個是curl的資源句柄,第二個是輸出的header數(shù)據(jù)。header數(shù)據(jù)的輸出必須依賴這個函數(shù),返回已寫入的數(shù)據(jù)大小。

          CURLOPT_PASSWDFUNCTION

          設(shè)置一個回調(diào)函數(shù),有三個參數(shù),第一個是curl的資源句柄,第二個是一個密碼提示符,第三個參數(shù)是密碼長度允許的最大值。返回密碼的值。

          CURLOPT_READFUNCTION

          設(shè)置一個回調(diào)函數(shù),有兩個參數(shù),第一個是curl的資源句柄,第二個是讀取到的數(shù)據(jù)。數(shù)據(jù)讀取必須依賴這個函數(shù)。返回讀取數(shù)據(jù)的大小,比如0或者EOF。

          CURLOPT_WRITEFUNCTION

          設(shè)置一個回調(diào)函數(shù),有兩個參數(shù),第一個是curl的資源句柄,第二個是寫入的數(shù)據(jù)。數(shù)據(jù)寫入必須依賴這個函數(shù)。返回精確的已寫入數(shù)據(jù)的大小

          curl_copy_handle()函數(shù)的作用是拷貝一個curl連接資源的所有內(nèi)容和參數(shù)

          $ch=curl_init("http://www.baidu.com/");

          $another=curl_copy_handle($ch);

          curl_exec($another);

          curl_close($another);

          curl_error()函數(shù)的作用是返回一個包含當(dāng)前會話錯誤信息的字符串。

          curl_errno()函數(shù)的作用是返回一個包含當(dāng)前會話錯誤信息的數(shù)字編號。

          curl_multi_init()函數(shù)的作用是初始化一個curl批處理句柄資源。

          curl_multi_add_handle()函數(shù)的作用是向curl批處理會話中添加單獨的curl句柄資源。curl_multi_add_handle()函數(shù)有兩個參數(shù),第一個參數(shù)表示一個curl批處理句柄資源,第二個參數(shù)表示一個單獨的curl句柄資源。

          curl_multi_exec()函數(shù)的作用是解析一個curl批處理句柄,curl_multi_exec()函數(shù)有兩個參數(shù),第一個參數(shù)表示一個批處理句柄資源,第二個參數(shù)是一個引用值的參數(shù),表示剩余需要處理的單個的curl句柄資源數(shù)量。

          curl_multi_remove_handle()函數(shù)表示移除curl批處理句柄資源中的某個句柄資源,curl_multi_remove_handle()函數(shù)有兩個參數(shù),第一個參數(shù)表示一個curl批處理句柄資源,第二個參數(shù)表示一個單獨的curl句柄資源。

          curl_multi_close()函數(shù)的作用是關(guān)閉一個批處理句柄資源。

          $ch1=curl_init();

          $ch2=curl_init();

          curl_setopt($ch1, CURLOPT_URL, "http://www.baidu.com/");

          curl_setopt($ch1, CURLOPT_HEADER, 0);

          curl_setopt($ch2, CURLOPT_URL, "http://www.google.com/");

          curl_setopt($ch2, CURLOPT_HEADER, 0);

          $mh=curl_multi_init();

          curl_multi_add_handle($mh,$ch1);

          curl_multi_add_handle($mh,$ch2);

          do {

          curl_multi_exec($mh,$flag);

          } while ($flag > 0);

          curl_multi_remove_handle($mh,$ch1);

          curl_multi_remove_handle($mh,$ch2);

          curl_multi_close($mh);

          curl_multi_getcontent()函數(shù)的作用是在設(shè)置了CURLOPT_RETURNTRANSFER的情況下,返回獲取的輸出的文本流。

          curl_multi_info_read()函數(shù)的作用是獲取當(dāng)前解析的curl的相關(guān)傳輸信息。

          curl_multi_select()

          Get all the sockets associated with the cURL extension, which can then be "selected"

          本文為一訊原創(chuàng)文章,轉(zhuǎn)載無需和我聯(lián)系,但請注明來自尊氪博客www.zunkr.com

          年人只管利益,小孩子才分對錯。。。

          ---- 網(wǎng)易云熱評

          一、GET請求

          1、get可以理解為一個系統(tǒng)定義好的數(shù)組

          2、通過var_dump看一下GET的類型,瀏覽器訪問網(wǎng)址,后面加上"?aiyou=bucuo",相當(dāng)于數(shù)組名為GET,鍵是aiyou,值是bucuo

          3、一般get請求都是訪問某個文件

          4、通過GET寫文件

          <?php
          $a=$_GET['aiyou'];//取鍵為aiyou的值
          $b=fopen("aiyou.txt", "w+");//打開文件
          fwrite($b, $a);//寫入文件
          ?>

          二、POST請求

          1、新建一個html頁面

          <html>
          <head>
          <meta charset="utf-8">
          <title>web安全工具庫</title>
          </head>
          <body>
          <form action="aiyou.php" method="post">
          名字: <input type="text" name="fname">
          密碼: <input type="text" name="pass">
          <input type="submit" value="提交">
          </form>
          </body>
          </html>

          2、新建一個獲取數(shù)據(jù)的頁面aiyou.php

          <?php
          header("Content-Type:text/html;charset=utf-8");
          echo "歡迎";
          echo $_POST["fname"];
          echo "登錄";
          ?>

          3、瀏覽器提交

          三、兩者區(qū)別

          1、安全性:GET請求中url中可見提交的數(shù)據(jù)、POST不可見

          2、數(shù)據(jù)限制:GET只能傳遞ASCII字符,且最長是2048個字符,POST不受限制

          3、歷史信息:GET參數(shù)能保留在瀏覽器歷史中,POST數(shù)據(jù)不能保存在瀏覽器歷史中


          禁止非法,后果自負(fù)

          php中提供了一個發(fā)送郵件的函數(shù)mail函數(shù),它可以在程序中直接發(fā)送電子郵件,不過它要求服務(wù)器支持sendmail

          或者必須設(shè)置一臺不需要中繼的郵件發(fā)送服務(wù)器,但現(xiàn)在要找到一臺不需要身份驗證的郵件發(fā)送中繼幾乎不可能。

          所以使用mail函數(shù)往往無法成功發(fā)送email.

          自己如果熟悉SMTP協(xié)議,結(jié)合socket功能就可以編寫高效穩(wěn)定的郵件發(fā)送程序,但對一般用戶來說太困難。好在互聯(lián)網(wǎng)上已經(jīng)有很多別人編寫好的郵件發(fā)送模塊,我們只需要下載后簡單調(diào)用即可,十分方便。

          在此我們給用戶推薦一個php下功能十分強大,易用且免費的SMTP類模塊-PHPMailer,

          PHPMailer是一個用于發(fā)送電子郵件的PHP函數(shù)包。它提供的功能包括:

          *.在發(fā)送郵時指定多個收件人,抄送地址,暗送地址和回復(fù)地址

          *.支持多種郵件編碼包括:8bit,base64,binary和quoted-printable

          *.支持SMTP驗證

          *.支持冗余SMTP服務(wù)器

          *.支持帶附件的郵件和Html格式的郵件

          *.自定義郵件頭

          *.支持在郵件中嵌入圖片

          *.調(diào)試靈活

          *.經(jīng)測試兼容的SMTP服務(wù)器包括:Sendmail,qmail,Postfix,Imail,Exchange等

          *.可運行在任何平臺之上

          下載該組件后,按如下示例編寫代碼即可實現(xiàn)php在線發(fā)送郵件。

          一:html程序

          <html>

          <body>

          <h3>phpmailer Unit Test</h3>

          請你輸入<font color="#FF6666">收信</font>的郵箱地址:

          <form name="phpmailer" action="send.php" method="post">

          <input type="hidden" name="submitted" value="1"/>

          郵箱地址: <input type="text" size="50" name="address" />

          <br/>

          <input type="submit" value="發(fā)送"/>

          </form>

          </body>

          </html>

          二:PHP程序

          <?php

          require("class.phpmailer.php"); //下載的文件必須放在該文件所在目錄

          $mail=new PHPMailer(); //建立郵件發(fā)送類

          $address=$_POST['address'];

          $mail->IsSMTP(); // 使用SMTP方式發(fā)送

          $mail->Host="mail.xxxxx.com"; // 您的企業(yè)郵局域名

          $mail->SMTPAuth=true; // 啟用SMTP驗證功能

          $mail->Username="user@xxxx.com"; // 郵局用戶名(請?zhí)顚懲暾膃mail地址)

          $mail->Password="******"; // 郵局密碼

          $mail->From="user@xxxx.com"; //郵件發(fā)送者email地址

          $mail->FromName="您的名稱";

          $mail->AddAddress("$address", "");//收件人地址,可以替換成任何想要接收郵件的email信箱,格式是AddAddress("收件人email","收件人姓名")

          //$mail->AddReplyTo("", "");

          //$mail->AddAttachment("/var/tmp/file.tar.gz"); // 添加附件

          //$mail->IsHTML(true); // set email format to HTML //是否使用HTML格式

          $mail->Subject="PHPMailer測試郵件"; //郵件標(biāo)題

          $mail->Body="Hello,這是測試郵件"; //郵件內(nèi)容

          $mail->AltBody="This is the body in plain text for non-HTML mail clients"; //附加信息,可以省略 (PS:^_^不錯的php開發(fā)交流群304224365,驗證:ttf,謝謝!)

          if(!$mail->Send())

          {

          echo "郵件發(fā)送失敗。 <p>";

          echo "錯誤原因: " . $mail->ErrorInfo;

          exit;

          }

          echo "郵件發(fā)送成功"


          主站蜘蛛池模板: 亚洲一区二区三区免费观看 | 精品日韩亚洲AV无码一区二区三区| 中文字幕VA一区二区三区| 精品国产一区二区三区久久| 精彩视频一区二区三区| 搡老熟女老女人一区二区| 久久国产精品免费一区二区三区 | 日韩精品一区二区三区影院| 国产福利91精品一区二区| 性色AV一区二区三区| 亚洲av片一区二区三区| 精彩视频一区二区三区| 国产福利一区视频| 国产一区二区成人| 91精品一区二区三区久久久久| 中文字幕一精品亚洲无线一区| 福利在线一区二区| 美女AV一区二区三区| 国产一区二区三区免费视频 | 一区二区精品久久| 福利电影一区二区| 国产高清在线精品一区小说| 免费在线视频一区| 男人的天堂精品国产一区| 国产一区二区三区不卡在线看| 无码人妻啪啪一区二区| 欧美日韩综合一区二区三区| 一区二区传媒有限公司| 手机福利视频一区二区| 亚洲日韩中文字幕无码一区| 中文字幕av人妻少妇一区二区| 亚洲av无码一区二区三区在线播放| 精品欧洲AV无码一区二区男男| 无码一区二区三区| 亚洲日韩中文字幕无码一区| AV天堂午夜精品一区二区三区| 国产第一区二区三区在线观看| 一区二区三区中文字幕| 日产一区日产2区| 麻豆一区二区99久久久久| 日本在线视频一区二区|