ページが であるとしexample.com/blog/data.php
ます。file_get_contents
別のスクリプト ページでコンテンツを取得するために使用しています。今、私はしたい:
- Google 検索による data.php ページのクロールとインデックス作成を禁止します。
- 訪問者のアクセスを禁止する
これを達成する方法はありますか?
ページが であるとしexample.com/blog/data.php
ます。file_get_contents
別のスクリプト ページでコンテンツを取得するために使用しています。今、私はしたい:
これを達成する方法はありますか?
リクエスト URL が の場合、別のページにリダイレクトできますexample.com/blog/data.php
が、はるかに簡単で論理的な解決策は、ファイルを web-root の外に移動することです。
編集:本当にファイルを web-root 内に保持したい場合は、直接アクセスしたくないスクリプトの上部で次のようなものを使用できます。
if ($_SERVER['REQUEST_URI'] === $_SERVER['SCRIPT_NAME'])
{
header('Location: /'); // redirect to home page
}
file_get_contents
ただし、これはおそらく(これらの行を結果から削除する必要があります) と組み合わせて使用することはできませんinclude
。代わりにファイルを使用することができます。
data.php
Web ルートの下に置かないでください。並列ディレクトリに保管してください。
許可されたユーザーのみにアクセス制限を適用するだけです。url パラメーターをパスワードとして使用してページにアクセスすることにより、最も簡単な方法でそれを行うことができます。
example.com/blog/data.php?secret=someblah
ファイル data.php の最初の部分で、次のようにします。
<?php
if (!isset($_GET['secret']) || $_GET['secret'] != 'someblah')) exit();
?>
ただし、これは安全ではありませんが、基本的な認証原則であるため、公共のコンピューターからこれを使用しないことをお勧めします。
GET 経由でトークンを渡すことができます。全体的にあなたのやり方は少し間違っています。それを呼び出すスクリプトに data.php ロジックを組み込んでみませんか。