PHP は 1995 年に誕生して以来、急速に成長してきました。それ以来、PHP は Web アプリケーションで最も人気のあるプログラミング言語になりました。多くの人気のある Web サイトは PHP を利用しており、ほとんどのスクリプトと Web プログラムはこの一般的な言語で書かれています。
PHP の人気により、Web 開発者が PHP の知識を少しでも知らないということはほぼ不可能です。このチュートリアルは、PHP の初期段階を経験したばかりで、すぐに袖をまくり上げて言語に飛び込む準備ができている人を対象としています。以下に挙げるのは、PHP 開発者がプログラミングを行う際に学び、使用する必要がある 10 の優れたテクニックです。これらのエクスペリエンスにより、開発者の習熟度が向上し、コードがより認識しやすく、よりクリーンになり、コード実行がより最適化されます。
1. SQL インジェクション攻撃テーブルを使用する 一般的な SQL インジェクションのリスト SQL インジェクション攻撃は、ハッカーがコードの弱点を悪用してデータベースに侵入することを可能にする悪質な動作です。この記事は MySQL 関連ではありませんが、多くの PHP プログラマーは MySQL データベースを使用しているため、安全なコードを記述したい場合に (SQL インジェクション) を回避する方法を学ぶのは簡単です。
Furruh Mavituna には優れた SQL インジェクション チートシートがあり、PHP と MySQL プログラミングの弱点に関するセクションがあります。このチートシートで指摘されている習慣を避けることができれば、コードはスクリプト攻撃の影響を受けにくくなります。
2. 比較演算子の違いを学ぶ PHP の比較演算子のリスト
比較演算子は PHP の重要な部分を占めていますが、多くのプログラマは比較演算子の違いを十分に理解していません。実際、I/O リーダーの記事では、多くの PHP プログラマーが比較演算子の違いを正確に区別できないことが示されています。チクチク。
これらは非常に便利であり、ほとんどの PHPer は == と === の違いを見分けることができません。本質的に == は等しいことを探し、それによって PHP は通常、データを同様の形式に変換しようとします (例: 1 == ')。 1' (true)、=== は同一性を検索します: 1 === '1' (false)。PHP の 0 は strpos() に似ているため、これらの演算子の有用性はすぐにわかります。 FALSE は、この演算子がなければ、strpos() の結果から、文字列の先頭に何かがあるのか、または strpos() が何も見つけられなかったのかを知る方法がないことを意味します。明らかに、これは、ゼロを返す他の場所で多くの用途があります。 FALSE と同等ではありません。
== は等価を意味し、=== は一貫性を意味することを理解してください。比較演算子のリストは、PHP.net Web サイトで参照できます。
3 else ステートメントを短くするには、項目 3 と 4 の両方により、速度と実行が強調されてコードが読みにくくなるということを明記する必要があります。読みやすさを犠牲にしたくない場合は、これら 2 つの項目をスキップできます。
コードをよりシンプルかつ小さくできるものはすべて、一般に良い実践となります。この記事の目的は、いわば、else ステートメントから「仲介者」を取り除くことです。 Christian Montoya は、短い else ステートメントを使用して文字数を減らす素晴らしい例を示しています。
一般的な else 文
[code language="php"]
if( この条件 )
{
$x = 5;
}
else
{
$x = 10;
}
[/code]
if $ x のデフォルト値は 10 なので、10 に初期化するだけです。わざわざelse部分を入力する必要はありません。
[code language="php"]
$x = 10;
if(この条件)
{
$x = 5;
}
[/code]
コードスペースの節約には大きな違いはないようです, プログラム内に多くの else ステートメントがある場合、これは顕著な違いを生みます。
4. 括弧を削除すると、コード内のスペースと時間を節約できます。else ステートメントを作成する場合と同様に、制御ステートメントの直後にある式内の括弧を省略して、一部の文字を節約することもできます。 Evolt.org には、括弧を省略した構造をリストした簡単な例があります
[code language="php"]
if ($gollum == 'halfling') {
$height --;
}
[/code]
これは以下と同じ:
[code language="php"]
if ($gollum == 'halfling') $height --;
[/code]
複雑な状況でも使用できます
[code language = "php"]
if ($gollum == 'halfling') $height --;
else $height ++;
if ($frodo != 'dead')
echo 'なんてことだ、また転がるサウロン'; foreach ($kill as $count)
echo 'レゴラスが再び攻撃する、それは' . $count . 'for me!';
[/code]
5 ereg_replace の代わりに str_replace を選択し、preg_replaceSpeed テストで str_replace() が表示されることを示します。効率の観点から見ると、str_replace() は文字列の置換において正規表現よりも効率的です。実際、『Making the Web』によると、str_replace() は ereg_replace() や preg_replace() のような正規表現よりも 61% 効率的です。
正規表現を使用している場合、ereg_replace() と preg_replace() は str_replace() よりもはるかに高速になります。
6. 三項演算子の使用 if/else ステートメントを完全に使用する代わりに、三項演算子の使用を検討してください。 PHP Value は、三項演算子が何であるかを示す非常に良い例です
[code http://www.yeeyan.com/articles/tag/php" target=_blank $ Included="null">php
/ /PHP COde Example使用法: 三項演算子
$todo = (empty($_POST['todo'])) ? 'default' : $_POST['todo'];
// 上記は、この if/else ステートメントと同じです
if ( empty($_POST['todo'])) {
$action = 'default';
} else {
$action = $_POST['todo'];
}
?>
[/code ]
三項演算子を使用すると、行スペースが節約され、コードが整理されて読みやすくなります。PHP は、この状況で何をすべきかを常に認識していないため、式ステートメント内で複数の三項演算子を使用しないように注意してください。 7 memcachedMemcached は、PHP で使用できる優れたデータベース キャッシュ システムです。選択できるキャッシュ ソリューションは数多くありますが、PHP を使用する場合、Memcached は最も効率的なデータベース キャッシュ システムの 1 つにランクされます。 Web サイトを構築してデータベースを使用すると、Memcached は Web サイトを確実に高速化できます。Memcached キャッシュ システムは最初にブログ Web サイト LiveJournal 用に構築されました
PHP.net には、プロジェクトに memcached をインストールして使用する方法についての優れたチュートリアルがあります
8. フレームワークを使用する CakePHP は、トップクラスの PHP フレームワークの 1 つです
すべてのプロジェクトで PHP フレームワークを使用できるわけではありませんが、CakePHP、Zend、Symfony、CodeIgniter などのフレームワークを使用すると、ビルドにかかる時間を大幅に短縮できます。フレームワークは、Web アプリケーションや Web サービスの開発のオーバーヘッドを軽減するために使用できるソフトウェアです。 9. エラー抑制演算子 (PHP マニュアルではエラー制御演算子) の正しい使用方法。 @ 記号は、PHP のステートメントの前に置かれると、このステートメントによって生成されたエラーを (オリジナルのテキストでは、元の作成者のタイプミスと推定されます) 表示しないようにプログラムに指示するだけです。この演算子は、値が不明な場合、またはエラーをスローしたくない場合に便利です。
しかし、多くのプログラマはエラー抑制演算子を誤って使用しています。コードを記述するときに効率を念頭に置くと、@ 演算子は実行に非常に時間がかかり、コストが高くなります。
Michel Fortin は、他の方法を使用して @ エラー抑制演算子を回避する方法の例をいくつか紹介しています。これは、isset 関数を使用してエラー出力演算子を置き換える方法です。
[code language="php"]
if (isset($albus)) $albert = $albus;
else $albert = NULL;
[/code]
同等:
[code language="php"]
$albert = @$albus;
[/code]
しかし、2 番目の方法はより体系化されていますが、実行速度が約 2 倍遅くなります。良い解決策は、警告がトリガーされないように参照によって変数を割り当てることです。例:
[code language="php"]
$albert = &$albus;
[/code]
これらの変更には予期しない副作用が生じる可能性があるため、より高い効率が必要な場所で使用する必要があり、影響を受けません。
10. strlen の代わりに isset を使用する strlen に isset を切り替えると、呼び出しが約 5 倍速くなります。
文字列の長さをチェックする場合は、strlen の代わりに isset を使用します。 isset を使用すると、通話が 5 倍高速になります。 isset を使用すると、変数が存在しない場合でも呼び出しが機能することを指摘することが重要です。
D-talk には、isset を strlen に交換する方法の例があります。
少し前に、PHP で文字列の長さを決定する最適な方法について議論しました。明白な方法は、strlen() を使用することです。
ただし、確認する必要があります。最小限の要件の長さのため、strlen を使用するのは実際にはそれほど最適ではありません。以下は実際にははるかに高速です (約 5 倍)
これはほんの小さな変更ですが、今日説明したようなヒントを合計すると、高速かつクリーンになります。コード。
[プログラミングを向上させるための 10 の高度な PHP ヒント経由]