PHP_PHP チュートリアルにおける一重引用符と二重引用符の違いの詳細な紹介
この記事では、PHP におけるシングルクォーテーションとダブルクォーテーションの違いについて詳しく紹介しています。詳しく知りたい学生は参照してください。
1.文字列を定義します
PHP では、一重引用符または二重引用符を使用して文字列を定義できます。ただし、文字列を定義するには同じ一重引用符または二重引用符を使用する必要があります。たとえば、「Hello」と「Hello」は無効な文字列定義です。
文字列を定義する場合、一重引用符または二重引用符の 1 種類の引用符のみが区切り文字とみなされます。したがって、文字列が二重引用符で始まる場合は、二重引用符のみがパーサーによって解析されます。このようにして、二重引用符で囲まれた文字列内に他の文字 (一重引用符も含む) を含めることができます。次の引用符文字列はすべて有効です:
PHPコード
$s = "私は二重引用符文字列内の「一重引用符文字列」です";
$s = '私は一重引用符文字列内の「二重引用符文字列」です';
$s = "私は二重引用符文字列内の「一重引用符文字列」です";
$s = '私は一重引用符文字列内の「二重引用符文字列」です';
「なぜ「これ」は機能しないのですか?」という文字列は 3 つの段落に分割されます。この文字列で二重引用符を表現したい場合は、エスケープ文字「" (バックスラッシュ) を使用して、「なぜ "this" は機能しないのですか?」 のようにすることができます。2. 文字列変数内の単一引用符と二重引用符
PHP では、二重引用符で囲まれた文字列に文字列変数を直接含めることができます。次の 2 つの文字列の処理結果が同じであることがわかります。
$full_name = $first_name . $last_name;
$full_name = "$first_name $last_name"
一重引用符文字列と二重引用符文字列は、PHP では異なる方法で処理されます。二重引用符で囲まれた文字列の内容は解釈して置換できますが、一重引用符で囲まれた文字列の内容は常に通常の文字とみなされます。例:
PHPコード
$foo = 2;
echo "foo is $foo"; // 結果を出力: foo は 2
echo 'foo is $foo'; // 結果を出力: foo は $foo
echo "foo is $foon"; // 出力結果: foo は 2 (改行あり)
echo 'foo is $foon'; // 結果を出力: foo は $foon
$foo = 2;
echo "foo is $foo"; // 結果を出力: foo は 2
echo 'foo is $foo'; // 結果を出力: foo は $foo
echo "foo is $foon"; // 出力結果: foo は 2 (改行あり)
echo 'foo is $foon'; // 結果を出力: foo は $foon
ご覧のとおり、一重引用符文字列では、バックスラッシュでさえその拡張された意味を失います (挿入されたバックスラッシュと挿入された一重引用符 ' を除く)。したがって、変数置換を実行し、文字列に n (改行) などのエスケープ シーケンスを含める場合は、二重引用符を使用する必要があります。一重引用符文字列は他の場所でも使用できます。スクリプト内で一重引用符文字列を使用すると、処理速度が速くなります。これは、PHP パーサーが一重引用符文字列を比較的単純な方法で処理する一方で、二重引用符の処理には文字列内の解析も必要となるためです。したがって、より複雑になり、処理が若干遅くなります。
文字列内の変数の複雑な組み合わせを参照するときにいくつかの問題が発生する可能性がありますが、次のコードは正常に機能します:
PHPコード
エコー "値 = $foo";
エコー "値 = $a[$i]";
エコー "値 = $foo";
エコー "値 = $a[$i]"
次のコードでは、必要な結果が得られません:
echo "value = $a[$i][$j]"; //二次元配列 $a の要素を出力したい。
これらの文字列の使用における潜在的な問題を回避するために、通常は次のように複雑な変数を文字列から分離します: echo 'value = ' . $a[$i][$j];//文字 接続にはドット (.) を使用します。文字列
もう 1 つの方法は、構文アナライザーがそれらを正しく識別できるように、複雑な変数を中括弧で囲むことです。
echo "value = {$a[$i][$j]}" //二次元配列$aの要素を出力する
このようにして、新たな問題が発生します。文字列内で中括弧文字自体を引用したい場合は、エスケープ文字を使用することを忘れないでください:
PHPコード
$var = 3;
echo "value = {$var}" // 結果を出力 "value = 3"
echo "value = {$var}" // 結果を出力 "value = {3}"
$var = 3;
echo "value = {$var}" // 結果を出力 "value = 3"
echo "value = {$var}" // 結果を出力 "value = {3}"
3. SQL ステートメント内
これはよく発生する問題で、データベースに挿入される SQL ステートメントでは文字列の定義に一重引用符が使用されており、一重引用符を含む文字列をデータベースに挿入すると、SQL ステートメントが間違ってしまいます。
例: $sql="insert into userinfo (username,password) Values('O'Kefee','123456')"
このとき、SQL文にエスケープ文字のバックスラッシュを追加する方法もあります
つまり:...Values('O'Kefee',...
もちろん、addslashes() 関数を使用することもできます。この関数の機能はエスケープ文字を追加することです。
つまり: $s =addslashes("O'Kefee") ……Values('".$s."',…… )
もう 1 つの方法は、php.ini で Magic-quotes オプションを設定することです。このオプションがオンになっている場合、フォームから送信された情報に一重引用符が含まれている場合、エスケープ文字が自動的に追加されます。したがって、他の機能を使用する必要はありません。
補足: これは二重引用符と一重引用符の役割から始まります。二重引用符で囲まれたフィールドはコンパイラによって解釈されて HTML コードとして出力されますが、一重引用符で囲まれたフィールドは解釈する必要がなく、直接出力されます。 。
例:
$abc='愛しています';
echo $abc //結果は次のとおりです: 愛しています
echo '$abc' //結果は次のようになります: $abc
echo "$abc" //結果は次のようになります: 愛しています
そのため、データベース内の SQL ステートメントに値を割り当てるときは、二重引用符を使用する必要があります。 SQL="select a,b,c from..." ただし、フィールド名を引用するために SQL ステートメント内に一重引用符が含まれます。
例: select * from table where user='abc';
ここでの SQL ステートメントは SQL="select * from table where user='abc'" として直接書くことができます
しかし、次のような場合:
$user='abc';
SQL1="select * from table where user=' ".$user." ' "; 比較してください
SQL2="select * from table where user=' abc ' "一重引用符と二重引用符の間にもう少しスペースを追加しました。より明確に見えることを願っています。
つまり、「abc」を「.$user.」にすべて一重引用符で囲んで置き換えます。 SQL 文字列全体を分割するだけです。 SQL1 は次の 3 つの部分に分類できます
1: "user=' のテーブルから * を選択します
2:$user
3:「」
文字列を接続するには . を使用します

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









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

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

H5。ミニプログラムとアプリの主な違いは次のとおりです。技術アーキテクチャ:H5はWebテクノロジーに基づいており、ミニプログラムとアプリは独立したアプリケーションです。経験と機能:H5は軽量で使いやすく、機能が限られています。ミニプログラムは軽量で、インタラクティブが良好です。アプリは強力で、スムーズな経験があります。互換性:H5はクロスプラットフォーム互換性があり、アプレットとアプリはプラットフォームによって制限されています。開発コスト:H5には、開発コストが低く、中程度のミニプログラム、最高のアプリがあります。適用可能なシナリオ:H5は情報表示に適しており、アプレットは軽量アプリケーションに適しており、アプリは複雑な機能に適しています。

PHPでは、予測不可能なトークンを使用して、CSRF攻撃を効果的に防ぐことができます。特定の方法には次のものが含まれます。1。フォームのCSRFトークンを生成および埋め込みます。 2.リクエストを処理するときにトークンの有効性を確認します。

JavaScriptのDOMノードの下でのXpath検索方法の詳細な説明、XPath式に基づいてDOMツリーから特定のノードを見つける必要があることがよくあります。あなたがする必要があるなら...

PHPでは、最終的なキーワードを使用して、クラスが継承されないようにし、メソッドが上書きされます。 1)クラスを決勝としてマークする場合、クラスを継承することはできません。 2)メソッドを最終的にマークする場合、メソッドはサブクラスによって書き換えられません。最終的なキーワードを使用すると、コードの安定性とセキュリティが保証されます。

Photoshopでパスワードで保護されたPDFをエクスポート:画像ファイルを開きます。 [ファイル]&gtをクリックします。 「エクスポート」> 「PDFとしてのエクスポート」。 「セキュリティ」オプションを設定し、同じパスワードを2回入力します。 [エクスポート]をクリックして、PDFファイルを生成します。

Vueアプリケーションを開発するときに、ルーターフォルダーの下にindex.jsファイルにvuerouterを登録する必要性があるため、ルーティング構成で問題が発生することがよくあります。特別...
