ホームページ > バックエンド開発 > PHPチュートリアル > Escape とはどういう意味ですか?

Escape とはどういう意味ですか?

PHP中文网
リリース: 2016-07-29 08:43:28
オリジナル
1430 人が閲覧しました

JavaScript では、escape/unescape() 関数と eval_r() 関数を使用して単純なトランスコーディングを行うと、通常の URL が奇妙に見えるようになり、迷惑な検索クローラーが非表示にしたいリソースを識別できなくなります。

ここでは、通常、通常の文字列を JavaScript unescape() 関数で解釈できる形式に事前にエンコードする必要があります。PHP を例に挙げると、次の関数を使用してエスケープと同じ機能を実現できます。 Javascript の () 関数:

コードは次のとおりです:

<?php 
function escapeToHex($string, $encoding = UTF-8) { 
$return = ; 
for ($x = 0; $x < mb_strlen($string, $encoding); $x ++) { 
$str = mb_substr($string, $x, 1, $encoding); 
if (strlen($str) > 1) { // 多字节字符 
$return .= %u . strtoupper(bin2hex(mb_convert_encoding($str, UCS-2, $encoding))); 
} else { 
$return .= % . strtoupper(bin2hex($str)); 
} 
} 
return $return; 
} 
?>
ログイン後にコピー


次のアドレスを非表示にしたいとします: http://www.php.cn/
これを実現するには、次のスクリプトを使用できます:

コードは次のとおりです:

<?php 
// 请自行包含 escapeToHex() 函数定义 
$test = document.write(\<a href="http://www.dirk.sh/assets/uploaded/thisistest.pdf">test</a>\); 
echo <script Language="Javascript">eval_r(unescape(" . escapeToHex($test) . "))</script>; 
?>
ログイン後にコピー


ページのソース コードを表示すると、次のことがわかります (長すぎるため、行は手動で分割されており、実際の実行結果は完全な行になるはずです):

コードは次のとおりです:

<script Language="Javascript">eval_r(unescape("%64%6F%63%75%6D%65%6E%74%2E%77 \ 
%72%69%74%65%28%27%3C%61%20%68%72%65%66%3D%22%68%74%74%70%3A%2F%2F%77%77%77 \ 
%2E%64%69%72%6B%79%65%2E%6E%65%74%2F%75%70%6C%6F%61%64%65%64%2F%74%68%69%73 \ 
%69%73%74%65%73%74%2E%70%64%66%22%3E%74%65%73%74%3C%2F%61%3E%27%29"))</script>
ログイン後にコピー


ブラウザに表示されるページは通常の HTML と変わりません。
注:
1.escapeToHex() 関数の 2 番目のパラメーター ($encoding) は、渡す文字列のエンコーディングを示します。他のエンコーディングを使用する場合は、関数を呼び出すときにそれを明確に指定する必要があります。関数;
2. ECMAScript v3 仕様では、unescape() の使用が反対されています。仕様では、新しい代替関数 decodeURIComponent() の使用が推奨されています。しかし、テストの結果、decodeURIComponent() 関数にはマルチバイトの問題があることがわかりました。文字(中国語)処理のため、unescape() 関数が引き続き使用されます。
3. 原則として、上記の方法は、秘密にしておく必要があると思われるリソース アドレスを検索クローラーが取得するのを防ぐためのものです。JavaScript をサポートするブラウザーでページを閲覧すると、この保護メカニズムが適用されている場合とまったく同じ表示が表示されます。有効になっていません。 。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
PHP 拡張子 intl
から 1970-01-01 08:00:00
0
0
0
phpのデータ取得?
から 1970-01-01 08:00:00
0
0
0
phpを上手に学ぶ方法
から 1970-01-01 08:00:00
0
0
0
PHP GET エラー レポート
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート