Zend Framework アプリケーションのコンテンツを XML プラグインに変換する_PHP チュートリアル
このブログ投稿では、Thijs Feryn が Zend_Controller_Plugin_Abstract のフック メソッドを実装して、元のプログラムのコンテキスト スイッチング コントローラー アシスタントを使用せずに、返されたコンテンツ応答を特定の XML 形式に変換します。 /2009/05/converting-your-zend-framework-mvc-application-into-an-xml-webservice-using-one-single-plugin/
コード:
クリップボードにコピー引用コンテンツ: [www.bkjia.com]
/*** My_Plugin_Xml コンポーネント
* Zend Framework MVC Web サイトを XML Web サービスに変換します
* Liehuo.Net からのファイル
*/
/**
* My_Plugin_Xml クラス
*
* @author Thijs Feryn
*/
class My_Plugin_Xml は Zend_Controller_Plugin_Abstract を拡張します
{
/**
* フロントコントローラーを保存します
*
* @var Zend_Controller_Front
*/
private $_front
/**
* XML 出力を DOMDocument 形式で保存します
*
* @var DOMDocument
; */
プライベート $_xml;
/**
* クラスコンストラクター
*/
パブリック関数 __construct()
{
$this->_front = Zend_Controller_Front::getInstance();
$layout = Zend_Layout::getMvcInstance();
$layout->disableLayout();
}
/**
* DOMDocument を構築して出力を XML に変換します
*
* @parammixed $return
* @param Exception $Exception
* @return string
*/
プライベート関数 _getXML($return = null,Exception $例外 = null)
{
$this->_xml = new DOMDocument( '1.0', 'UTF-8');
$this->xml->formatOutput = true;
$responseNode = $this->xml->createElement('response'); = $this->xml->createElement('例外');
if(null !== $例外 && $例外インスタンスオブ例外 ){
$例外ノード->appendChild(
$this->_xml-> ;createElement('メッセージ',
$例外->getMessage()
)
);
$例外ノード->appendChild(
$this->_xml->createElement('コード',
$例外->) ;getCode()
)
);
$ExceptionNode->appendChild(
$this->_xml->createElement('type',
get_class($Exception)
)
}
$responseNode ->appendChild($ExceptionNode);
if(null !== $return){
$responseNode->appendChild(
$this->serialize('return',$return)
);
$responseNode->appendChild(
$this->xml->createElement('return')
);
$this->xml->appendChild($responseNode); ->xml->saveXML();
}
/**
* HTTP 応答オブジェクトを変更します
* HTML 本文を削除し、XML に置き換えて、コンテンツ タイプを変更します
*
* @parammixed $return
* @param Exception $Exception
*/
プライベート関数 _setResponse($return = false,Exception $例外 = null)
{
$this->getResponse()- >setHeader('Content-Type','text/xml; charset=UTF-8');
$this->getResponse()->clearBody(); ;setBody(
$this->_getXML($return,$Exception)
);
/**
* 混合値を DOMElement 形式で XML にシリアル化します
* このメソッドはオブジェクトと配列の場合に再帰的に使用できます
*
* @param string $name
* @parammixed $value
* @return DOMElement
*/
プライベート関数 _serialize($name,$value)
{
if(is_array($) value)){
$element = $this->xml->createElement($name);
foreach ($value as $k=>$v){
if(is_numeric($k)){
$ k = 'アイテム';
$element->appendChild($this->_serialize($k,$v));
}
} elseif(is_object($value)){
$element = $this ->xml->createElement($name);
$reflection = new ReflectionObject($value);
$properties = $reflection->getProperties();
foreach ($property として){
if( $property->isPublic()){
$element->appendChild(
$this->_serialize(
$property->getName(),
$property->getValue($value)
)
);
}
}
}else{
$element = $this->xml->createElement(
$name,
(string)$value
);
return $element
/* *
* アプリケーションで例外がスローされたかどうかを取得する preDispatch フック
* 例外がスローされた場合、例外は XML 出力の例外部分に渡され、スクリプトの実行が終了します
*
* @param Zend_Controller_Request_Abstract $request
*/
public function preDispatch(Zend_Controller_Request_Abstract $request)
{
if( $this->getResponse()->isException()){
$exArray = $this->getResponse()->getException();
$this->setResponse(null,$exArray[0]) );
$this->getResponse()->sendResponse();
exit()
}
/**
* HTTP 応答を変更してビュー オブジェクトを XML にシリアル化する postDispatch フック
* 例外がスローされなかった場合、スクリプトの実行は続行され、postDispatch メソッドが呼び出されます
*
* @param Zend_Controller_Request_Abstract $request
*/
{
$view = Zend_Controller_Action_HelperBroker::getExistingHelper('ViewRenderer')->view;
}
}
_getXML() は特定の XML 構造を生成します
_setResponse() は応答の XML コンテンツを設定します
_serialize() は返されたオブジェクトを (再帰を使用して) XML にシリアル化します
preDispatch() は例外があるかどうかを判断し、例外がある場合は、例外とスクリプト実行の終了
postDispatch() は応答を返します
$this->front->registerPlugin(new My_Plugin_Xml()); を使用して
http://www.bkjia.com/PHPjc/364543.html
www.bkjia.com
true

PHP多次元アレイの要素の総数を計算することは、再帰的または反復的な方法を使用して行うことができます。 1.再帰的な方法は、アレイを通過し、ネストされた配列を再帰的に処理することによりカウントされます。 2。反復法は、スタックを使用して再帰をシミュレートして深さの問題を回避します。 3. array_walk_recursive関数も実装できますが、手動でカウントする必要があります。

PHPでは、ループの特性は、ループ本体が少なくとも1回実行されることを確認し、条件に基づいてループを続行するかどうかを決定することです。 1)条件付きチェックの前にループ本体を実行します。これは、ユーザー入力検証やメニューシステムなど、操作を少なくとも1回実行する必要があるシナリオに適しています。 2)ただし、do-whileループの構文は、初心者間の混乱を引き起こす可能性があり、不要なパフォーマンスオーバーヘッドを追加する可能性があります。

PHPの効率的なハッシュ文字列は、次の方法を使用できます。1。MD5関数を使用して高速ハッシュを使用しますが、パスワードストレージには適していません。 2。SHA256関数を使用して、セキュリティを改善します。 3. password_hash関数を使用してパスワードを処理して、最高のセキュリティと利便性を提供します。

PHPに配列スライディングウィンドウを実装することは、slidewindowとslidewindowaverage関数によって実行できます。 1. SlideWindow関数を使用して、配列を固定サイズのサブアレイに分割します。 2。各ウィンドウの平均値を計算するには、SlideWindowaverage関数を使用します。 3.リアルタイムのデータストリームの場合、非同期処理と外れ値検出を使用して使用できます。

PHPの__Cloneメソッドは、オブジェクトクローン時にカスタム操作を実行するために使用されます。クローンキーワードを使用してオブジェクトをクローニングする場合、オブジェクトに__クローンメソッドがある場合、メソッドが自動的に呼び出され、クローン型属性をリセットしてクローンオブジェクトの独立性を確保するなど、クローンプロセス中にカスタマイズされた処理を許可します。

PHPでは、GOTOステートメントは、プログラムの特定のタグに無条件にジャンプするために使用されます。 1)複雑なネストされたループまたは条件付きステートメントの処理を簡素化することができますが、2)GOTOを使用すると、コードの理解と維持が困難になる場合があります。3)構造化された制御ステートメントの使用を優先することをお勧めします。全体として、gotoは注意して使用する必要があり、コードの読みやすさと保守性を確保するために、ベストプラクティスに従う必要があります。

PHPでは、組み込み関数、カスタム関数、およびサードパーティライブラリを使用してデータ統計を実現できます。 1)array_sum()やcount()などの組み込み関数を使用して、基本統計を実行します。 2)カスタム関数を記述して、中央値などの複雑な統計を計算します。 3)PHP-MLライブラリを使用して、高度な統計分析を実行します。これらの方法により、データ統計を効率的に実行できます。

はい、PHPの匿名関数は、名前のない関数を参照します。これらは、他の関数へのパラメーターとして、および関数の返品値として渡すことができ、コードをより柔軟で効率的にします。匿名関数を使用する場合、範囲とパフォーマンスの問題に注意を払う必要があります。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

Dreamweaver Mac版
ビジュアル Web 開発ツール
