phpcurlカプセル化クラスの使用例、phpcurlカプセル化の例
この記事の例では、PHP CURL カプセル化クラスの 2 つの使用例を説明します。これらの 2 つの関数を使用すると、PHP CURL 関連の関数を非常に便利に使用できます。参考のためにみんなで共有してください。詳細は以下の通りです
関数を使用する前に、PHP Curl モジュール (libeay32.dll、ssleay32.dll、php5ts.dll、php_curl.dll) を開く必要があります
PHP CURL関数ライブラリを有効にする手順
1) Windows/php.ini ファイル内の ;extension=php_curl.dll を削除します。 /*echo phpinfo() を使用して php.ini*/
のパスを確認します。
2) php5/libeay32.dll と ssleay32.dll をシステム ディレクトリ windows/
にコピーします。
3).Apacheを再起動します
コードは次のとおりです:
$aa =新しいカール('');
$curlOptions = array(
CURLOPT_URL => "http://www.xx.com/addTicket.jsp", //URLにアクセスします
CURLOPT_RETURTRANSFER => true, //結果を取得し、文字列として返します
CURLOPT_REFERER => "ww.ww.ww/zw2",
CURLOPT_HTTPHEADER => array('X-FORWARDED-FOR:139.197.14.19', 'CLIENT-IP:127.0.0.1','プロキシ-クライアント-IP:139.197.14.19','WL-プロキシ-クライアント-IP:139.197 .14.19' )、
CURLOPT_HEADER => 1, //リターンヘッダー情報を取得します
//CURLOPT_SSL_VERIFYPEER => false, //SSL暗号化をサポート
CURLOPT_POST => true, //POSTパラメータを付けて送信
CURLOPT_POSTFIELDS => 'ids=897&Submit=%E6%8A%95%E7%A5%A8', //リクエストされたPOSTパラメータ文字列
CURLOPT_TIMEOUT => $aa->timeout //応答を待つ時間
);
echo $aa->getResponseText($curlOptions);
カル処理カテゴリ:
{
パブリック $cookieFile;
パブリック $timeout = 160;
パブリック関数 __construct($dir){
$this->cookieFile = $this->getTemporaryCookieFileName($dir);
}
/**
* CURLパラメータを設定し、リクエストを送信して応答コンテンツを取得します
* @アクセス非公開
* @param $curlOptions 配列 Curl 設定パラメータ配列
* @return string|false アクセスが成功した場合は取得した情報を文字列形式で返します、それ以外の場合は false を返します
*/
パブリック関数 getResponseText($curlOptions) {
/* CURLOPT_RETURNTRANSFER を true に設定します */
if(!isset($curlOptions[CURLOPT_RETURNTRANSFER]) || $curlOptions[CURLOPT_RETURNTRANSFER] == false) {
$curlOptions[CURLOPT_RETURNTRANSFER] = true;
}
/*カールモジュールを初期化します*/
$curl =curl_init();
/* カール オプションを設定します */
curl_setopt_array($curl, $curlOptions);
/* リクエストを送信し、応答情報を取得します */
$responseText = '';
試してみてください{
$responseText =curl_exec($curl);
if(($errno =curl_errno($curl)) != CURLM_OK) {
$errmsg =curl_error($curl);
新しい例外をスローします($errmsg, $errno);
}
} catch (例外 $e) {
//例外DisposeFunction($e);
//print_r($e);
$responseText = false;
}
/*カールモジュールを閉じる*/
curl_close($curl);
/* 結果を返します */
$responseText を返します;
}
/**
* Unicode文字列(u0000)をutf-8文字列に変換するツール関数
* @アクセス非公開
* @静的
* @param $string string Unicode 文字列
* @return 文字列 utf-8 文字列
*/
パブリック関数 unicodeToUtf8($string) {
$string = str_replace('u', '', strto lower($string));
$length = strlen($string) / 4;
$stringResult = '';
for($i = 0; $i $charUnicodeHex = substr($string, $i * 4, 4);
$unicodeCode = hexdec($charUnicodeHex);
$utf8Code = '';
if($unicodeCode $utf8Code = chr($unicodeCode);
} else if($unicodeCode $utf8Code .= chr(192 + (($unicodeCode - ($unicodeCode % 64)) / 64));
$utf8Code .= chr(128 + ($unicodeCode % 64));
} その他 {
$utf8Code .= chr(224 + (($unicodeCode - ($unicodeCode % 4096)) / 4096));
$utf8Code .= chr(128 + ((($unicodeCode % 4096) - ($unicodeCode % 64)) / 64));
$utf8Code .= chr(128 + ($unicodeCode % 64));
}
$stringResult .= $utf8Code;
}
$stringResult を返します;
}
プライベート関数 getTemporaryCookieFileName($dir='.') {
return (str_replace("", '/', tempnam($dir, 'tmp')));
}
}
例 2
クラスカール
{
関数 Curl(){
true を返します;
}
functionexecute($method, $url, $fields='', $userAgent='', $httpHeaders='', $username='', $password=''){
$ch = Curl::create();
if(false === $ch){
false を返します;
}
if(is_string($url) && strlen($url)){
$ret =curl_setopt($ch, CURLOPT_URL, $url);
}その他{
false を返します;
}
// 否か表示头部情報
curl_setopt($ch, CURLOPT_HEADER, false);
//
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
if($ユーザー名 != ''){
curl_setopt($ch, CURLOPT_USERPWD, $username . ':' . $password);
}
$method = strto lower($method);
if('post' == $method){
curl_setopt($ch, CURLOPT_POST, true);
if(is_array($fields)){
$sets = array();
foreach ($fields AS $key => $val){
$sets[] = $key 。 '=' 。 urlencode($val);
}
$fields = implode('&',$sets);
}
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);
}else if('put' == $method){
curl_setopt($ch, CURLOPT_PUT, true);
}
//curl_setopt($ch, CURLOPT_PROGRESS, true);
//curl_setopt($ch, CURLOPT_VERBOSE, true);
//curl_setopt($ch, CURLOPT_MUTE, false);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);//curl超時間秒数を設定します
if(strlen($userAgent)){
curl_setopt($ch, CURLOPT_USERAGENT, $userAgent);
}
if(is_array($httpHeaders)){
curl_setopt($ch, CURLOPT_HTTPHEADER, $httpHeaders);
}
$ret =curl_exec($ch);
if(curl_errno($ch)){
curl_close($ch);
return array(curl_error($ch),curl_errno($ch));
}その他{
curl_close($ch);
if(!is_string($ret) || !strlen($ret)){
false を返します;
}
$ret を返します;
}
}
function post($url, $fields, $userAgent = '', $httpHeaders = '', $username = '', $password = ''){
$ret = Curl::execute('POST', $url, $fields, $userAgent, $httpHeaders, $username, $password);
if(false === $ret){
false を返します;
}
if(is_array($ret)){
false を返します;
}
$ret を返します;
}
関数 get($url, $userAgent = '', $httpHeaders = '', $username = '', $password = ''){
$ret = Curl::execute('GET', $url, '', $userAgent, $httpHeaders, $username, $password);
if(false === $ret){
false を返します;
}
if(is_array($ret)){
false を返します;
}
$ret を返します;
}
関数 create(){
$ch = null;
if(!function_exists('curl_init')){
false を返します;
}
$ch =curl_init();
if(!is_resource($ch)){
false を返します;
}
$ch を返します;
}
}
?>
用法
入手方法:
$curl->get('http://www.bkjia.com/');
投稿用法:
$curl->get('http://www.bkjia.com/', 'p=1&time=0');
ここで説明されている大規模な PHP プログラムの設計が役立つことを望みます。
phpカール封装成関数问题
変数名が間違って書かれているためです。変数名②は変数名③と等しくありませんが、変数名①と等しくないためです。
$output①=curl_exec($ch); //結果を返す;
curl_close($ch) //通信を閉じる;
if($output==''){
$outptu② = 3;
}
$dataapi = $outptu③;
return $dataapi;
}

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。

データベースストレージセッションを使用することの主な利点には、持続性、スケーラビリティ、セキュリティが含まれます。 1。永続性:サーバーが再起動しても、セッションデータは変更されないままになります。 2。スケーラビリティ:分散システムに適用され、セッションデータが複数のサーバー間で同期されるようにします。 3。セキュリティ:データベースは、機密情報を保護するための暗号化されたストレージを提供します。

PHPでのカスタムセッション処理の実装は、SessionHandlerInterfaceインターフェイスを実装することで実行できます。具体的な手順には、次のものが含まれます。1)CussentsessionHandlerなどのSessionHandlerInterfaceを実装するクラスの作成。 2)セッションデータのライフサイクルとストレージ方法を定義するためのインターフェイス(オープン、クローズ、読み取り、書き込み、破壊、GCなど)の書き換え方法。 3)PHPスクリプトでカスタムセッションプロセッサを登録し、セッションを開始します。これにより、データをMySQLやRedisなどのメディアに保存して、パフォーマンス、セキュリティ、スケーラビリティを改善できます。

SessionIDは、ユーザーセッションのステータスを追跡するためにWebアプリケーションで使用されるメカニズムです。 1.ユーザーとサーバー間の複数のインタラクション中にユーザーのID情報を維持するために使用されるランダムに生成された文字列です。 2。サーバーは、ユーザーの複数のリクエストでこれらの要求を識別および関連付けるのに役立つCookieまたはURLパラメーターを介してクライアントに生成および送信します。 3.生成は通常、ランダムアルゴリズムを使用して、一意性と予測不可能性を確保します。 4.実際の開発では、Redisなどのメモリ内データベースを使用してセッションデータを保存してパフォーマンスとセキュリティを改善できます。

APIなどのステートレス環境でのセッションの管理は、JWTまたはCookieを使用して達成できます。 1。JWTは、無国籍とスケーラビリティに適していますが、ビッグデータに関してはサイズが大きいです。 2.cookiesはより伝統的で実装が簡単ですが、セキュリティを確保するために慎重に構成する必要があります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 中国語版
中国語版、とても使いやすい

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ホットトピック









