検索
ホームページphp教程php手册PHP中我经常容易混淆的三组函数,PHP混淆三组函数

PHP中我经常容易混淆的三组函数,PHP混淆三组函数

原文:http://www.ido321.com/1252.html

一、htmlentities() 和htmlspecialchars()

       1、htmlentities()

             1.1  功能:把字符转换为 HTML 实体。字符包括ASCII实体和ISO 8859-1实体(HTML实体对照表:http://www.w3school.com.cn/tags/html_ref_entities.html)

             1.2  语法:htmlentities(string,quotestyle,character-set)

             1.3  参数:string是必选参数,是需要转换的字符串。其余可选,quotestyle规定如何编码单引号和双引号:ENT_COMPAT – 默认。仅编码双引号;ENT_QUOTES – 编码双引号和单引号;ENT_NOQUOTES – 不编码任何引号。character-set是规定转换用的字符集,常用的有UTF-8/GB-2312/ISO-8859-1(默认)。

             1.4  提示:无法被识别的字符集将被忽略,并由 ISO-8859-1 代替。

<span>$str = <span>"John & 'Adams'"</span>;
<span>echo</span> htmlentities($str);
<span>//在浏览器中输出:John & 'Adams'</span>
//查看源代码:John & <span>'Adams'</span></span>

     2、htmlspecialchars()

           2.1   把一些预定义的字符转换为 HTML 实体。预定义字符都是ASCII 实体,即此函数不能转换ISO 8859-1实体,这是和htmlrntities()的区别

                   预定义的字符是:

  • & (和号) 成为 &
  • ” (双引号) 成为 "
  • ‘ (单引号) 成为 '

          2.2   htmlspecialchars(string,quotestyle,character-set)

          2.3   参数htmlentities()

          2.4   提示:无法被识别的字符集将被忽略,并由 ISO-8859-1 代替。

<span>$str = <span>"John & 'Adams'"</span>;
<span>echo</span> htmlentities($str);
<span>//在浏览器中输出:John & 'Adams'</span>
//查看源代码:John & <span>'Adams'</span></span>

二、html_entity_decode()和htmlspecialchars_decode()

        html_entity_decode(string,quotestyle,character-set) 函数把 HTML 实体转换为字符,是htmlentities()的反函数。

        htmlspecialchars_decode(string,quotestyle)函数把预定义的 HTML 实体转换为字符,是htmlspecialchars()的反函数。

<span>$str = <span>"John & &#039;Adams&#039;"</span>;
<span>echo</span> html_entity_decode($str);
<span>//浏览器输出:John & 'Adams'</span>
//源代码:John & &#039;Adams&#039;</span>

三、addslashes()和addcslashes()

       1、addslashes(string):在指定的预定义字符前添加反斜杠。string是需要检查的字符串。该函数数可用于为存储在数据库中的字符串以及数据库查询语句准备合适的字符串。

             预定义字符是:单引号(’)、双引号(”)、反斜扛(\)和NULL

            ps:默认情况下,PHP 指令 magic_quotes_gpc 为 on,对所有的 GET、POST 和 COOKIE 数据自动运行 addslashes()。不要对已经被 magic_quotes_gpc 转义过的字符串使用 addslashes(),因为这样会导致双层转义。遇到这种情况时可以使用函数 get_magic_quotes_gpc() 进行检测。

<span>$str = <span>"Who's John Adams?"</span>;
<span>echo</span> $str . <span>" This is not safe in a database query.<br />"</span>;
<span>echo</span> addslashes($str) . <span>" This is safe in a database query."</span>;</span>

输出:

<span>Who's John Adams? This is not safe in a database query.
Who\'s John Adams? This is safe in a database query.</span>
<span>   <span>2、addcslashes(</span><em>string</em>,<em>characters</em><span>) 函数在<span>指定的字符</span>前添加反斜杠。stirng必须,第二个可选。规定受 addcslashes() 影响的字符或字符范围。</span></span>
<span>             ps:<strong>在对 0,r,n 和 t 应用 addcslashes() 时要小心。在 PHP 中,\0,\r,\n 和 \t 是预定义的转义序列。此函数可以对任何字符,包括预定义字符进行反斜扛添加,这是和addslashes的区别</strong></span>
<span>//向特定字符添加反斜杠</span><span>
$str = <span>"Hello, my name is John Adams."</span>;
<span>echo</span> $str;
<span>echo</span> addcslashes($str,<span>'m'</span>);
<span>echo</span> addcslashes($str,<span>'J'</span>);</span>

输出:

<span>Hello, my name is John Adams.
Hello, \my na\me is John Ada\ms.
Hello, my name is \John Adams.</span>
<span>//向字符串中的一个范围内的字符添加反斜杠</span><span>
$str = <span>"Hello, my name is John Adams."</span>;
<span>echo</span> $str;
<span>echo</span> addslashes($str);   <span>//使用addslashes</span>
<span>echo</span> addcslashes($str,<span>'A..Z'</span>);
<span>echo</span> addcslashes($str,<span>'a..z'</span>);
<span>echo</span> addcslashes($str,<span>'a..h'</span>);</span>

输出:

Hello, my name is John Adams.

Hello, my name is John Adams.

\Hello, my name is \John \Adams.

H\e\l\l\o, \m\y \n\a\m\e \i\s J\o\h\n A\d\a\m\s.

H\ello, my n\am\e is Jo\hn A\d\ams.

下一篇:Ubuntu下安装XAMPP

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 Mac版

SublimeText3 Mac版

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

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター