整合營銷服務商

          電腦端+手機端+微信端=數(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.基本結構

          在學習更為復雜的功能之前,先來看一下在PHP中建立cURL請求的基本步驟:

          (1)初始化

          curl_init()

          (2)設置變量

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

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

          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);

          如果成功只將結果返回,不自動輸出任何內容。

          如果失敗返回FALSE

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

          如果成功只返回TRUE,自動輸出返回的內容。

          如果失敗返回FALSE

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

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

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

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

          ? CURLOPT_INFILESIZE : 當你上傳一個文件到遠程站點,這個選項告訴PHP你上傳文件的大小。

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

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

          ? CURLOPT_NOPROGRESS: 如果你不會PHP為CURL傳輸顯示一個進程條,設置這個選項為一個非零值。注意:PHP自動設置這個選項為非零值,你應該僅僅為了調試的目的來改變這個選項。

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

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

          ? CURLOPT_UPLOAD: 如果你想讓PHP為上傳做準備,設置這個選項為一個非零值。

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

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

          ? CURLOPT_FTPAPPEND : 設置這個選項為一個非零值,PHP將應用遠程文件代替覆蓋它。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

          ? CURLOPT_RANGE : 傳遞一個你想指定的范圍。它應該是”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指令告訴遠程服務器去連接我們指定的IP地址。這個字符串可以是一個IP地址,一個主機名,一個網(wǎng)絡界面名(在UNIX下),或是‘-'(使用系統(tǒng)默認IP地址)。

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

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

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

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

          ? CURLOPT_CUSTOMREQUEST : 當進行HTTP請求時,傳遞一個字符被GET或HEAD使用。為進行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. 注意: 在確認你的服務器支持命令先不要去這樣做。下列的選項要求一個文件描述(通過使用fopen()函數(shù)獲得):

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

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

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

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

          例一:

          $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 — 關閉一個curl會話

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

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

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

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

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

          curl_init — 初始化一個curl會話

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

          curl_multi_close — 關閉一個批處理句柄資源

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

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

          curl_multi_info_read — 獲取當前解析的curl的相關傳輸信息

          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ù)

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

          curl_version — 獲取curl相關的版本信息

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

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

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

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

          curl_exec($ch);

          curl_close($ch);

          curl_version()函數(shù)的作用是獲取curl相關的版本信息,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

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

          CURLINFO_TOTAL_TIME

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

          CURLINFO_NAMELOOKUP_TIME

          名稱解析所消耗的時間

          CURLINFO_CONNECT_TIME

          建立連接所消耗的時間

          CURLINFO_PRETRANSFER_TIME

          從建立連接到準備傳輸所使用的時間

          CURLINFO_STARTTRANSFER_TIME

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

          CURLINFO_REDIRECT_TIME

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

          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中讀取的下載內容長度

          CURLINFO_CONTENT_LENGTH_UPLOAD

          上傳內容大小的說明

          CURLINFO_CONTENT_TYPE

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

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

          $ch=curl_init();

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

          CURLOPT_AUTOREFERER

          自動設置header中的referer信息

          CURLOPT_BINARYTRANSFER

          在啟用CURLOPT_RETURNTRANSFER時候將獲取數(shù)據(jù)返回

          CURLOPT_COOKIESESSION

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

          CURLOPT_CRLF

          啟用時將Unix的換行符轉換成回車換行符。

          CURLOPT_DNS_USE_GLOBAL_CACHE

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

          CURLOPT_FAILONERROR

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

          CURLOPT_FILETIME

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

          CURLOPT_FOLLOWLOCATION

          啟用時會將服務器服務器返回的“Location:”放在header中遞歸的返回給服務器,使用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

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

          CURLOPT_HTTPPROXYTUNNEL

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

          CURLOPT_MUTE

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

          CURLOPT_NETRC

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

          CURLOPT_NOBODY

          啟用時將不對HTML中的body部分進行輸出。

          CURLOPT_NOPROGRESS

          啟用時關閉curl傳輸?shù)倪M度條,此項的默認設置為true

          CURLOPT_NOSIGNAL

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

          CURLOPT_POST

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

          CURLOPT_PUT

          啟用時允許HTTP發(fā)送文件,必須同時設置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ā)起連接前等待的時間,如果設置為0,則不等待。

          CURLOPT_DNS_CACHE_TIMEOUT

          設置在內存中保存DNS信息的時間,默認為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

          設置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讓服務器選擇一個支持最好的值,CURLAUTH_ANY等價于CURLAUTH_BASIC | CURLAUTH_DIGEST | CURLAUTH_GSSNEGOTIATE | CURLAUTH_NTLM,CURLAUTH_ANYSAFE等價于CURLAUTH_DIGEST | CURLAUTH_GSSNEGOTIATE | CURLAUTH_NTLM

          CURLOPT_INFILESIZE

          設定上傳文件的大小

          CURLOPT_LOW_SPEED_LIMIT

          當傳輸速度小于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.

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

          CURLOPT_MAXCONNECTS

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

          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

          在恢復傳輸時傳遞一個字節(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,默認值為 CURL_TIMECOND_IFMODSINCE

          CURLOPT_TIMEOUT

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

          CURLOPT_TIMEVALUE

          設置一個CURLOPT_TIMECONDITION使用的時間戳,在默認狀態(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

          設定HTTP請求中“Set-Cookie:”部分的內容。

          CURLOPT_COOKIEFILE

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

          CURLOPT_COOKIEJAR

          連接關閉以后,存放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: ”部分的內容,支持的編碼格式為:"identity","deflate","gzip"。如果設置為空字符串,則表示支持所有的編碼格式

          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)絡接口中使用的名稱,可以是一個接口名,IP或者主機名。

          CURLOPT_KRB4LEVEL

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

          CURLOPT_POSTFIELDS

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

          CURLOPT_PROXY

          設置通過的HTTP代理服務器

          CURLOPT_PROXYUSERPWD

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

          CURLOPT_RANDOM_FILE

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

          CURLOPT_RANGE

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

          CURLOPT_REFERER

          設置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ù)中設置。

          CURLOPT_USERAGENT

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

          CURLOPT_USERPWD

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

          CURLOPT_HTTP200ALIASES

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

          CURLOPT_HTTPHEADER

          設置一個header中傳輸內容的數(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

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

          CURLOPT_INFILE

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

          CURLOPT_STDERR

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

          CURLOPT_WRITEHEADER

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

          CURLOPT_HEADERFUNCTION

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

          CURLOPT_PASSWDFUNCTION

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

          CURLOPT_READFUNCTION

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

          CURLOPT_WRITEFUNCTION

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

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

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

          $another=curl_copy_handle($ch);

          curl_exec($another);

          curl_close($another);

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

          curl_errno()函數(shù)的作用是返回一個包含當前會話錯誤信息的數(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ù)的作用是關閉一個批處理句柄資源。

          $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ù)的作用是在設置了CURLOPT_RETURNTRANSFER的情況下,返回獲取的輸出的文本流。

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

          curl_multi_select()

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

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

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

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

          一、GET請求

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

          2、通過var_dump看一下GET的類型,瀏覽器訪問網(wǎng)址,后面加上"?aiyou=bucuo",相當于數(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ù)不能保存在瀏覽器歷史中


          禁止非法,后果自負

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

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

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

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

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

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

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

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

          *.支持SMTP驗證

          *.支持冗余SMTP服務器

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

          *.自定義郵件頭

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

          *.調試靈活

          *.經(jīng)測試兼容的SMTP服務器包括: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測試郵件"; //郵件標題

          $mail->Body="Hello,這是測試郵件"; //郵件內容

          $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ā)送成功"


          主站蜘蛛池模板: 国产成人一区二区三区精品久久| 亚洲色精品aⅴ一区区三区| 国产福利电影一区二区三区,亚洲国模精品一区 | 国产一区二区三区不卡AV| 国产综合精品一区二区| 在线视频亚洲一区| 精品国产区一区二区三区在线观看| 亚洲欧美日韩国产精品一区| 国产日韩一区二区三区| 精品无人区一区二区三区| 精品人妻码一区二区三区| 亚洲Av高清一区二区三区| 精品人妻一区二区三区浪潮在线| 一区二区视频在线| 97精品国产一区二区三区| 亚洲AV无码一区二区三区网址| 在线观看中文字幕一区| 精品一区二区三区在线观看l | 能在线观看的一区二区三区| 免费无码一区二区三区蜜桃大| 国产精品一区二区三区高清在线 | 国产伦理一区二区三区| 波多野结衣电影区一区二区三区| 婷婷国产成人精品一区二| 久久精品无码一区二区日韩AV| 日韩精品在线一区二区| 日本激情一区二区三区| 精品亚洲福利一区二区| 亚洲AV日韩精品一区二区三区| 国内国外日产一区二区| 精品国产a∨无码一区二区三区| 亚洲AV无码一区二区三区久久精品| 国产一区二区精品在线观看| 精品一区二区三区免费观看 | 3d动漫精品啪啪一区二区免费 | 精品日韩在线视频一区二区三区| 亚州日本乱码一区二区三区| 国产福利无码一区在线| 无码人妻一区二区三区在线视频 | av无码人妻一区二区三区牛牛| 狠狠色成人一区二区三区|