ホームページ >バックエンド開発 >PHPチュートリアル >くそー、バグを修正してください。このバグを修正する方法を教えてください。

くそー、バグを修正してください。このバグを修正する方法を教えてください。

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-06-23 14:27:331347ブラウズ

2 つの php ファイルがあります
1.php
echo '1';

2.php
echo '2'
;
http://localhost/1.php/2.php

と入力すると 1

が出力されます。トラブルを避けるために、アドレスが不正であることをブラウザに直接通知したいのですが、どうすればよいでしょうか。



ディスカッション (解決策) への返信


しかし、http://localhost/1.php/2.php は違法ではないのに、なぜ違法であるというメッセージが表示されるのでしょうか?

/2.php は $_SERVER['PATH_INFO'] 変数に保存されます

しかし、http://localhost/1.php/2.php は違法ではないのに、なぜ違法であるというメッセージが表示されるのでしょうか?
/2.php は $_SERVER['PATH_INFO'] 変数に保存されます

海外のオンライン ストア システムで作業しているため、セキュリティ リスクがあり、同様のバグによりログインがバイパスされる可能性があります

http://www .crehelp .com/cre-loaded-vulnerability-check-you-are-affected-pg-7.html
注文ステータスを直接確認します。
まだ修正方法がわかりません

上記の通り、違法ではありません。ただし、実装は非常に簡単で、入力 URL を取得し、ファイル名をインターセプトし、単純な判断を行います

  $url = "http://localhost/1.php/2.php";  $filename = basename($url);  if($filename != "1.php"){      echo "<script>alert('地址非法');</script>";  }

上記のように、違法ではありません。ただし、実装は非常に簡単で、入力 URL を取得し、ファイル名をインターセプトして、単純な判断を行う

  $url = "http://localhost/1.php/2.php";  $filename = basename($url);  if($filename != "1.php"){      echo "<script>alert('地址非法');</script>";  }

という方法がありますが、ファイル サイズが大きすぎるため、バックグラウンド ファイルが多すぎる場合はバイパスできます。各ファイルの情報を見てログインしてみます


何を使えばいいのかわかりませんが、ジャンプ防止の壁を作って入り口のみを使用することをお勧めします

PS: スコアもそうです。低い


How to verify if website is vulnerable?If, for example, you use http://www.example.com/admin/ URL to access store admin, try to open http://www.example.com/admin/orders.php/login.php. If you will not see login screen you are in danger!
は Web サイトが脆弱であることをどのように確認しますか?

たとえば、URL http://www.example.com/admin/ を使用してストレージ管理にアクセスする場合は、http://www.example.com/admin/orders.php/login.php を開いてみてください。ログイン画面が表示されない場合は危険です。


そして私が見ているのは

私は危険にさらされていますか?
冗談です!

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