質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

7784閲覧

Header may not contain more than a single header, new line detected.について

minoru23

総合スコア23

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/11/02 13:48

サーバーのログをみていたら下記のようなエラーがありました。

PHP Warning: Header may not contain more than a single header, new line detected.

referer: http://www.sample.com/link.php?id=60&url=http%3A//aaaaaaaa%0Awww.bbbb.com%2F%3Fdata%3Duser2%26item%3Dlist

エラー箇所を見てみると

$url = urldecode($_GET[url]);
header("Location: $url");

というものでした。

上記のように当サイトからでない外部のURLでリダイレクトしているようで、そのURLには改行がありました。

たぶん、これがエラーの原因だと思うのですが、外部の人が上記のようにいじることができないようにすることは可能でしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

クエリ文字列でURLを受け渡しする以上、「外部の人が上記のようにいじることができないようにする」ことは不可能です。
セッション変数で受け渡しするか、外部の人がいじることは許容して、URL中に改行がないかチェックするか、くらいです。
また、提示されたスクリプトだとオープンリダイレクトの脆弱性があります。遷移先が、意図したドメインかどうかのチェックを行う必要があります。

ところで、urldecode関数は必要なのでしょうか? $_GETにセットする時点で一度urldecodeされているわけですから、二重にパーセントエンコードすることを想定した形になっているようですが、二重にする必要がありますか?

投稿2017/11/02 14:13

ockeghem

総合スコア11701

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

minoru23

2017/11/02 14:35

アドバイスありがとうございます。 「遷移先が、意図したドメインかどうかのチェックを行う必要」のやり方がわからないのですが、 下記サイトのように「特定ドメインからの訪問者だけに表示する」で対処するのはあまり良くないでしょうか? https://lp.olivesystem.jp/831.html 「二重にする必要がありますか?」おっしゃるとおりです。修正しておきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問