admin.phpの変数
phpcms 開発者は、phpcms がテンプレートで呼び出すための多数の組み込み変数を提供していることを知っているはずです。たとえば、{$position} {$title} は現在の位置と記事のタイトルを表します。それぞれ。使用すると便利ですが、なぜこれらの変数を使用できるのかと疑問に思わずにはいられません。これらの変数はどのような状況で意味をなすのでしょうか?
実際、これらの問題は phpcms での HTML ファイルの生成プロセスに原因があると考えられます。すべては admin.php から始まります。バックグラウンドで実行するさまざまな操作 (ファイル、画像などの生成など) により、admin.php にさまざまなファイルが含まれます。インクルードされたオブジェクトには、渡されたパラメーターに従ってさまざまなファイルがインクルードされ、テンプレートが呼び出されるまでずっとインクルードされます。途中で渡されたファイルと admin.php 自体が最終的な admin.php を形成します。呼び出すことができる変数は、これらのファイルに含まれる変数です。これは、変数が使用可能かどうかを判断する基準でもあります。これを理解するのは難しくありません。なぜなら、テンプレート ファイルは最終的に admin.php に含まれており、それが呼び出す変数は元々 admin.php に含まれていなかった可能性がありますが、現在は含まれているからです。以下にテンプレート内のカスタムラベルで翻訳する方法を説明します。このタグは「前の記事 次の記事」の機能を実装しており、ラベル名は{tag_前の記事 次の記事}となります。クリックして記事を生成した後のリンクは次のとおりです: http://127.0.0.1/phpcms2007_sp6_gbk/phpcms/admin.php?mod=article&file=createhtml&action=create_show&channelid=1&referer=****タグ コードは次のとおりです:
1 php
2 定義済み (' IN_PHPCMS ' ) または終了 (' アクセスが拒否されました ' ); 4 php
5 グローバル $articleid , $db ; * FROM phpcms_article_1 where 記事 ID< ;' $articleid ' 記事 ID の順に並べ替えます " ;
7 $sqlaft = " SELECT * FROM phpcms_article_1 where 記事 ID>' ' 記事 ID の順に並べ替えます " ;
8 $preart = $db -> get_one( $sqlpre );
9 $afar = $db -> get_one( $sqlaft );
10 if ( ! $preart [ ' title ' ])
11 $preart = $db -> from phpcms_article_1 記事 ID による順序 desc " );
12 if ( ! $afart [ ' title ' ])
13 $afart = $db -> get_one( " SELECT * FROM phpcms_article_1 where Articleid=1 " );
14 $preurl = $preart [ ' リンク URL ' ];
15 $afurl = $afart [ ' リンク URL ' ];
16 $pretitle = $preart [ ' タイトル ' ]; 18 $url = $PHP_SCHEME . PHPCMS_PATH;
19 echo "
20 echo " < ;li>次の記事: $aftitle " ;
21 ?> 原則は非常に重要です。現在のページに従って単純です。インデックス ($articleid) は、データベース ($db) を通じて前後の記事をクエリし、最後に印刷されたページをエコーします。しかし、$articleid、$db の存在はどうやってわかるのでしょうか?これには、「記事を生成」をクリックした後にバックグラウンドで何が行われるかを理解する必要があります。分析によると、このコマンドを実行した後のメッセージ ルーティングは次のようになります:
admin . php -> phpcms " module "article " admin.inc.php->phpcms " module " category " admin " createhtml.inc.php (case 'create_show':)->golbal.func.php(createhtml)->phpcms " module "article " include " createhtm " show . php
メッセージは、
ob_start () を介してこのファイルにルーティングされます。 ; include template( $mod , $templateid );
$data = ob_get_contents ();
file_put_contents($filename, $data); HTML ファイルの作成と書き込みが完了します。さらに詳しく調べると、template() が template_refresh() を呼び出し、template_refresh() が template_parse() を呼び出して、phpcms のタグを解釈して純粋な PHP を変換していることがわかります。
その後、template() 関数が戻り、ブラウザのバッファ (ob_start() によって開かれる) に出力され、ファイルに埋め込まれた PHP は HTML 形式に変換されます。カスタムタグの場合、template_parse() によって に変換されるため、出力中に phpcms_mytag() 関数が呼び出されます。この関数には、最終的なカスタム ラベル ファイルが含まれます。このようにして、カスタム ラベルのファイルが $articleid と $db を含むファイルと結合されるため、この時点でこれら 2 つの変数をカスタム ラベル ファイルで使用できるようになります。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。
