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

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

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

Mozilla Foundationによって作られた無料、オープンソース、クロスプラットフォームなウェブブラウザ

PHP

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

Q&A

解決済

1回答

7460閲覧

Firefoxのみ、PHP側で $_SERVER["HTTP_REFERER"] が取得できない

chibi_kuma

総合スコア85

Firefox

Mozilla Foundationによって作られた無料、オープンソース、クロスプラットフォームなウェブブラウザ

PHP

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

0グッド

1クリップ

投稿2022/02/18 06:17

編集2022/02/22 00:41

https://XXX.XXXXX.co.jp/test.html から
https://XXX.XXXXX.co.jp/XXX/test.php

にアクセスした時、
Chromeや、Edgeの場合は、
PHP側で、$_SERVER["HTTP_REFERER"] が取得できますが、
Firefoxの場合は、取得できません。

Firefox(Windows)のバージョンは、現時点での最新 97.0.1 です。
(リファラーポリシー:strict-origin-when-cross-origin(規定値))

SSLは有効になっており、上記URLの画面遷移なら、同一オリジンとなるハズですので、
リファラーポリシーが「strict-origin-when-cross-origin」でも、
$_SERVER["HTTP_REFERER"] が取得できるハズだと思うのですが。
(実際、Chrome では取得できますし…。)

PHP側で、$_SERVER の以下の値を確認すると、
以下のようになっていました。(特に問題がある様には見えない)

Sec-Fetch-Dest: document
Sec-Fetch-Mode: navigate
Sec-Fetch-Site: same-origin
Sec-Fetch-User: ?1

Firefoxでのみ、$_SERVER["HTTP_REFERER"] が取得できないのは、
何が原因と考えられますでしょうか?

開発環境は、以下の通りです。
CentOS 7
Apache 2.4.34
PHP 7.4.25

アクセスに使用したブラウザは、すべてWindows10環境のもの

よろしくお願い申し上げます。

CHERRY さんからの修正依頼に対する回答

https://www.iphiroba.jp/env.php 等のWebサイトで、HTTP_REFERER を表示しても同じでしょうか。
表示されないのはご自身のWebサイトだけでしょうか。

お問合せありがとうございます。
さっそく、IP広場 環境変数チェックページをブラウザで表示させ、確認してみました。
「直前のURL(どこからきたか?)HTTP_REFERER」を確認してみました。
Chromeでは、URLが表示されますが、
Firefoxでは、「-」と表示されておりました。

Y.H. さんからの修正依頼に対する回答

Addonなどインストール済みの場合は全て無効にして検証されてますか?

はい、全て無効にして検証しています。

arcxor さんからの質問に対する回答

ちなみにこれはどうやって Firefox のリファラポリシーを確認したのでしょうか。

Firefoxの公式ブログが以下の様に書いていました。
「Firefox 87以降、デフォルトのリファラーポリシーを「strict-origin-when-cross-origin」に設定」と紹介しています。

公式ブログ
https://blog.mozilla.org/security/2021/03/22/firefox-87-trims-http-referrers-by-default-to-protect-user-privacy/

また、Firefox開発者ツール > ネットワークタブ でも、
「strict-origin-when-cross-origin」になっている事を確認していました。

解決しました。

arcxor さんからいただいた回答の通り、about:config で referer と検索して出てくる項目のうち、
network.http.sendRefererHeader が 0 になっていました。
規定値の2に戻したところ、無事、リファラーが送信されるようになりました。

ありがとうございました。

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

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

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

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

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

CHERRY

2022/02/18 07:20 編集

https://www.iphiroba.jp/env.php 等のWebサイトで、HTTP_REFERER を表示しても同じでしょうか。 表示されないのはご自身のWebサイトだけでしょうか。
Y.H.

2022/02/18 10:54

Addonなどインストール済みの場合は全て無効にして検証されてますか?
guest

回答1

0

ベストアンサー

Firefoxでのみ、$_SERVER["HTTP_REFERER"] が取得できないのは、
何が原因と考えられますでしょうか?

可能性として考えられるのは、Firefox のブラウザ設定です。

about:config で referer と検索して出てくる項目を、デフォルト値(既定値)から変更している項目はないでしょうか。

network.http.referer.defaultPolicy.pbmode0 にしたり、network.http.sendRefererHeader0 にするとリファラが送信されなくなります。


Firefox(Windows)のバージョンは、現時点での最新 97.0.1 です。
(リファラーポリシー:strict-origin-when-cross-origin(規定値))

SSLは有効になっており、上記URLの画面遷移なら、同一オリジンとなるハズですので、
リファラーポリシーが「strict-origin-when-cross-origin」でも、
$_SERVER["HTTP_REFERER"] が取得できるハズだと思うのですが。

ちなみにこれはどうやって Firefox のリファラポリシーを確認したのでしょうか。

投稿2022/02/18 16:24

arcxor

総合スコア2857

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

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

chibi_kuma

2022/02/22 00:38

arcxor さん、ありがとうございました! >network.http.sendRefererHeader を 0 にするとリファラが送信されなくなります。 正にコレでした…い、いつの間に… 自分で変えた覚えは無いので、過去に入れていたアドオンなどが影響していたのか… ずっと悩んでいたので、スッキリしました。 本当にありがとうございました!
chibi_kuma

2022/02/22 00:39

リファラを確認した方法は、質問文を編集する形で追記しております。 (画像をのせたかったので…)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問