ホームページ >バックエンド開発 >PHPチュートリアル >PHPでcurlを使う方法
PHP の CURL 関数ライブラリ (クライアント URL ライブラリ関数)
curl_close ? Curl セッションを閉じるcurl_copy_handle ? 現在のエラー情報を含む数値を返すsession
curl_error ? 現在のセッションのエラー情報を含む文字列を返します
curl_exec ?curl 接続リソース ハンドルに関する情報を取得します
curl_init ?curl バッチに単一のcurlを追加しますsession リソースを処理します
curl_multi_close ? バッチ ハンドル リソースを閉じます
curl_multi_getcontent ? 取得した出力のテキスト ストリームを返します
curl_multi_info_read ?curl バッチを初期化しますハンドル リソース
curl_multi_remove_handle ?curl バッチ ハンドル リソース内のハンドル リソースを削除します
curl_multi_select?cURL 拡張子に関連付けられているすべてのソケットを取得し、「選択」できます
curl_setopt_array を配列の形式で設定しますパラメータ
curl_setopt ?curl のセッションパラメータを設定します
curl_version?curl 関連のバージョン情報を取得します
curl_init() 関数の唯一のパラメータは、curl セッションを初期化することです。 URL アドレス。
curl_exec() 関数は、curl セッションを実行するために使用されます。唯一のパラメーターは、curl_init() 関数によって返されるハンドルです。
curl_close() 関数は、curl セッションを閉じるために使用されます。唯一のパラメータは、curl_init() 関数によって返されるハンドルです。
$ch =curl_init ( " http://www.baidu.com/ " ) ;
curl_version( ) 関数は、curl 関連のバージョン情報を取得するためのものです。
print_r (curl_version ())
?>
$ ch =curl_init ( " http://www.baidu.com/ " ) ;
print_r (curl_getinfo ( $ch )) ;
CURLINFO_HTTP_コード
最後に受信した HTTP コード
CURLINFO_FILETIME
ドキュメントがリモートで取得された時刻 (取得できない場合、戻り値は「-1」)
CURLINFO_TOTAL_TIME
CURLINFO_NAMELOOKUP_ TIME
名前解析に費やした時間
CURLINFO_CONNECT_TIME
CURLINFO_PRETRANSFER_TIME
CURLINFO_STARTTRANSFER_TIME
CURLINFO_トランザクション転送の CT_TIME
CURLINFO_SIZE_UPLOAD
CURLINFO_SIZE_DOWNLOAD
CURLINFO_SPEED_DOWNLOAD
CURLINFO_SPEED_UPLOAD
CURLINFO_HEADER_SIZE
CURLINFO_HEADER_OUT
CURLINFO_REQUEST_SIZE
CURLINFO_SSL_VERIFYRESULT
CURLINFO_CONTENT_LENGTH_DOWNLOAD
CURLINFO_CONTENT_LENGTH_UPLOAD
CURLINFO_CONTENT_TYPE
curl_setopt() 関数は、curl がセッションパラメータを設定するために使用されます。 curl_setopt_array() 関数は、curl のセッション パラメータを配列形式で設定するために使用されます。
$ch =curl_init() ;
$fp = fopen ( "example_homepage.txt " , " w " ) ; $options = array (
CURLOPT_URL => ' http://www.baidu.com/ ' ,
curl_exec ( $ch ) ; ;
fclose ($fp)
設定できるパラメータは次のとおりです:
CURLOPT_AUTOREFERER
ヘッダーにリファラー情報を自動的に設定します
CURLOPT_BINARYTRANSFER
CURLOPT_RETURNTRANSFER が有効な場合、データが返されます
CURLOPT_COOKIESESSION
有効な場合、curl はセッション Cookie を 1 つだけ渡す、他の Cookie を無視します、デフォルト この場合、curl はすべての Cookie をサーバーに返します。セッション Cookie は、サーバー側のセッションが有効かどうかを判断するために使用される Cookie を指します。
CURLOPT_CRLF
有効にすると、Unix の改行文字が復帰文字と改行文字に変換されます。
CURLOPT_DNS_USE_GLOBAL_CACHE
有効にすると、グローバル DNS キャッシュが有効になり、デフォルトは true になります。
CURLOPT_FAILONERROR
HTTP ステータス コードを表示します。デフォルトの動作では、400 以下の HTTP 情報を無視します
CURLOPT_FILETIME
有効にすると、リモート ドキュメント内の情報の変更が試行されます。結果情報は、curl_getinfo() 関数の CURLINFO_FILETIME オプションを通じて返されます。
CURLOPT_FOLLOWLOCATION
有効にすると、サーバーから返される「Location:」がヘッダーに配置され、再帰的に返される回数を制限するために CURLOPT_MAXREDIRS を使用します。
CURLOPT_FORBID_REUSE
インタラクションの完了後に接続が強制的に切断され、再利用できなくなります。
CURLOPT_FRESH_CONNECT
キャッシュ内の接続を置き換えるために新しい接続を強制的に取得します。
CURLOPT_FTP_USE_EPRT
アクティブな FTP ダウンロードを実行するときに EPRT (および LPRT) を使用するには TRUE。EPRT と LPRT を無効にして PORT のみを使用するには、FALSE を使用します。
PASV に戻す前に FALSE に設定します。 EPSV を無効にします。
CURLOPT_FTPAPPEND
TRUE を指定すると、上書きされずにリモート ファイルに追加されます。
CURLOPT_FTPASCII
CURLOPT_TRANSFERTEXT のエイリアス。 TP ディレクトリ。
CURLOPT_HTTPGET
CURLOPT_HTTPPROXYTUNNEL
CURLOPT_MUTE
CURLOPT_NETRC
CURLOPT_NOBODY
CURLOPT_NOPROGRESS
CURLOPT_NOSIGNAL
CURLOPT_POST
CURLOPT_PUT
CURLOPT_RETURNTRANSFER
CURLOPT_UPLOAD
CURLOPT_VERBOSE
CURLOPT_BUFFERSIZE
CURLOPT_CLOSEPOLICY
CURLOPT_CONNECTTIMEOUT
CURLOPT_DNS_CACHE_TIMEOUT
CURLOPT_FTPSSLAUTH
CURLOPT_HTTP_VERSION
curl で使用される HTTP プロトコルを設定します、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_BASIC | CURLAUTH_GSSNEGOTIATE | CURLAUTH_ANY と同等です。 URLAUTH_NTLM、CURLAUTH_ANYSAFE、 etc. CURLAUTH_DIGEST | Curlauth_GSSSNEGotia | Curlauth_ntlm
Curlopt_infilesize
アップロードファイルのサイズを設定します
送信速度が Curlopt_low_limit_limit 未満の場合、PHP は Curlopt_low_speed_time に従って送信をキャンセルするかどうかを決定します。
PHP が転送が遅すぎるとみなして中止するために、転送が CURLOPT_LOW_SPEED_LIMIT を下回る秒数である必要があります。
転送速度が CURLOPT_LOW_SPEED_LIMIT 未満の場合、PHP は CURLOPT_LOW_SPEED_TIME を使用して、速すぎるため転送をキャンセルするかどうかを決定します。遅い。
許可される接続の最大数を超えた場合、CURLOPT_CLOSEPOLICY を使用してどの接続を停止するかを決定します。
HTTP リダイレクトの最大数を指定します。このオプションは CURLOPT_FOLLOWLOCATION と一緒に使用されます。
接続ポートの指定に使用されるオプションの数量
プロキシ接続に使用する HTTP 認証方法。プロキシ認証には、現在 CURLAUTH_BASIC と CURLAUTH_NTLM のみが使用されます。
接続するプロキシのポート番号。
転送を再開するときに CURLPROXY_HTTP (デフォルト) または CURLPROXY_SOCKS5 を渡します。のために転送を再開しました)
1 は SSL ピア証明書内の共通名の存在を確認します。
2 は共通名の存在を確認し、それが指定されたホスト名と一致することも確認します
CURLOPT_SSLVERSION
SSL バージョン ( 2 または 3) を使用します。デフォルトでは、PHP はこれを自身で決定しようとしますが、場合によってはこれを手動で設定する必要があります。
CURLOPT_TIMEVALUE で指定された時間が経過した後に、それが編集されている場合は、CURL_TIMECOND_IFMODSINCE を使用します。ページが変更されておらず、CURLOPT_HEADER が true の場合、「304 Not Modified」ヘッダーが返されます。CURLOPT_HEADER が false の場合、デフォルト値は CURL_TIMECOND_IFMODSINCE です。
CURLOPT_TIMEOUT
CURLOPT_TIMEVALUE
CURLOPT_CAINFO
と組み合わせて使用する場合にのみ意味を持ちます。複数の CA 証明書を保持するディレクトリ。このオプションを CURLOPT_SSL_VERIFYPEER と併用します。
HTTP リクエストの「Set-Cookie:」部分の内容を設定します。
Cookie 情報を含むファイルの名前は、Netscape 形式または HTTP スタイルのヘッダー情報です。
接続が閉じられた後に Cookie 情報を保存するファイルの名前
HTTP リクエストを実行するときに「GET」または「HEAD」の代わりに使用するカスタム リクエスト メソッド。これは「DELETE」を実行する場合に便利です。有効な値は、「GET」、「POST」、「CONNECT」などです。たとえば、「GET /index」と入力しないでください。 .html HTTP/1.0rnrn ” は正しくありません。
注:
CURLOPT_EGSOCKET
エントロピー収集デーモン ソケットへのファイル名を除いて、CURLOPT_RANDOM_FILE と同様です。 CURLOPT_ENCODING
CURLOPT_FTPPORT
FTP の「POST」命令に使用する IP アドレスを取得するために使用される値。「POST」命令はリモート サーバーに次のことを指示します。指定した IP アドレスに接続します。文字列は、プレーンな IP アドレス、ホスト名、ネットワーク インターフェイス名 (Unix の場合)、またはシステムのデフォルトの IP アドレスを使用するための単なる '-' です。
CURLOPT_INTERFACE
外部ネットワーク インターフェイスで使用される名前。インターフェイス名、IP、またはホスト名にすることができます。
CURLOPT_KRB4LEVEL
KRB4 (Kerberos 4) セキュリティ レベル設定は、「clear」、「safe」、「confidential」、「private」のいずれかの値です。デフォルト値は「private」です。null に設定すると、KRB4 セキュリティが FTP 送信でのみ使用できるようになります。
CURLOPT_POSTFIELDS
HTTP の「POST」操作。ファイルを転送する場合は、@で始まるファイル名が必要です
CURLOPT_PROXY
渡すHTTPプロキシサーバーを設定します
CURLOPT_PROXYUSERPWD
接続するためのユーザー名とパスワードを「[ユーザー名]:[パスワード]」の形式で設定しますプロキシサーバーに。
CURLOPT_RANDOM_FILE
SSLで使用する乱数シードを格納するファイル名を設定します
CURLOPT_RANGE
HTTP送信範囲を設定します HTTP送信が複数ある場合は、カンマを使用して送信範囲を設定できます。倍数を区切るには、「X-Y,N-M」という形式の値を使用します。
CURLOPT_REFERER
ヘッダーの「Referer:」部分の値を設定します。
CURLOPT_SSL_CIPHER_LIST
SSL に使用する暗号のリスト。たとえば、RC4-SHA と TLSv1 は有効な暗号リストです。
CURLOPT_SSLCERT
証明書を含む文字列を PEM 形式で渡します。
CURLOPT_SSLCERTPASSWD
CURLOPT_SSLCERT 証明書を使用するために必要なパスワードを含むパスを渡します。
CURLOPT_SSLCERTTYPE
サポートされている形式は、「PEM」(デフォルト)、「DER」、および「ENG」です。
CURLOPT_SSLENGINE
CURLOPT_SSLKEY で指定された暗号化エンジンの識別子。 CURLOPT_SSLENGINE_DEFAULT
CURLOPT_SSLKEY
CURLOPT_SSLKEYPASSWD
CURLOPT_SSLKEYTYPE
CURLOPT_SSLKEY で指定される秘密 SSL キーのキー タイプは、「PEM」 (デフォルト)、「DER」です。
取得するURLアドレスはPHPのcurl_init()関数でも設定できます。
HTTP リクエスト内の「user-agent」ヘッダーを含む文字列。
接続に必要なユーザー名とパスワードを「[ユーザー名]:[パスワード]」の形式で渡します。
エラーの形式で HTTP 200 応答を処理しないように設定します。形式は配列です。
ヘッダーに送信内容の配列を設定します。
FTP リクエストの実行後にサーバー上で実行される FTP コマンドの配列。値はリソース タイプで、デフォルトは STDOUT (ブラウザー) です。
ファイルをアップロードするときに読み取る必要があるファイルアドレス。値はリソースタイプです。
エラー出力アドレスを設定します。値はリソースタイプであり、デフォルトの STDERR を置き換えます。
ヘッダー部分が書き込まれるファイルアドレスを設定します。値はリソースタイプです。
この関数には 2 つのパラメータがあります。1 つ目は、curl のリソース ハンドルで、2 つ目は出力ヘッダー データです。ヘッダー データの出力は、書き込まれたデータのサイズを返すこの関数に依存する必要があります。
3 つのパラメーターを使用してコールバック関数を設定します。最初のパラメーターは、curl リソース ハンドル、2 番目はパスワード プロンプト、3 番目のパラメーターは、許可されるパスワードの最大長です。パスワードの値を返します。
2 つのパラメータを持つコールバック関数を設定します。1 つ目は、curl のリソース ハンドルで、2 つ目は、読み取りデータです。データの読み取りはこの関数に依存する必要があります。 0 または EOF など、読み取りデータのサイズを返します。
2 つのパラメータを使用してコールバック関数を設定します。1 つ目は、curl のリソース ハンドルで、2 つ目は、書き込まれたデータです。データの書き込みはこの関数に依存する必要があります。書き込まれたデータの正確なサイズを返します
Curl_close ( $another ) ;
?>
curl_error() 関数の機能は、現在のセッションのエラー情報を含む文字列を返すことです。
curl_errno() 関数の機能は、現在のセッションのエラー情報を含む数値を返すことです。
curl_multi_init() 関数は、curl バッチ ハンドル リソースを初期化するために使用されます。
curl_multi_add_handle() 関数は、個々の CURL ハンドル リソースを CURL バッチ セッションに追加するために使用されます。 curl_multi_add_handle() 関数には 2 つのパラメータがあります。最初のパラメータは CURL バッチ ハンドル リソースを表し、2 番目のパラメータは別の CURL ハンドル リソースを表します。
curl_multi_exec() 関数は、curl バッチ ハンドルを解析するために使用されます。curl_multi_exec() 関数には 2 つのパラメーターがあり、最初のパラメーターはバッチ ハンドル リソースを表し、2 番目のパラメーターは残りが必要であることを示します。処理された個々のカール ハンドル リソースの数。
curl_multi_remove_handle() 関数は、curl バッチ ハンドル リソース内のハンドル リソースの削除を表します。curl_multi_remove_handle() 関数には 2 つのパラメータがあり、2 番目のパラメータは別の Curl ハンドル リソースを表します。 。
curl_multi_close() 関数は、バッチ ハンドル リソースを閉じるために使用されます。
$ch1=curl_init() ;
curl_setopt ($ch1 , CURLOPT_URL , " http://www.baidu.com/ " ) ; , CURLOPT_HEADER , 0 ) ;
curl_setopt ( $ch2 , CURLOPT_URL , " http://www.google.com/ " ) ;
$mh =curl_multi_init() ; ( $mh , $ch1 ) ;
curl_multi_add_handle ( $mh , $ch2 ) ;
do {
curl_multi_exec ( $mh , $flag )
} while ( $flag > 0 ) ; ;
curl_multi_remove_handle ( $mh , $ch2 ) ;
curl_multi_close ( $mh ) ;
?>
curl_multi_getcontent() 関数の機能は、CURLOPT_RETURNTRANSFER が設定されている場合に取得された出力のテキスト ストリームを返すことです。
curl_multi_info_read() 関数は、現在解析されているcurlの関連する送信情報を取得するために使用されます。
curl_multi_select()
cURL 拡張機能に関連付けられたすべてのソケットを取得し、「選択」することができます