wordpressの管理画面にアクセス制限をかけようとして、/wp-adminにBasic認証を設定することはよくあるかと思いますが、そうするとなぜかサイトを見ようとするとトップページやブログページでBasic認証が表示されて、IDとパスワードを求められてしまうという問題が発生しました。
最初は「どうせ何かが/wp-admin以下のファイルを参照してるんだろう」くらいの気分でいたのですが、ソースを開いてもwp-admin以下のファイルを参照しておらず。
むむっ?ミステリーですね、これは。
こういう時はサーバーのアクセスログを見るに限る。
案の定「/wp-admin/images/w-logo-blue.png」というファイルを読み込もうとしている。
ところでなにこのw-logo-blue.png?
と、思って調べたらお前かー犯人は!!!
WordPressのビジュアルモードでurlを書くと勝手にリンクになるあれ(上記のグレーの矩形)です。
Embed機能とかブログカードと呼ばれているらしいですが、そこで表示されるWのワードプレスのロゴマーク この画像がw-logo-blue.pngでした。
なんでwp-adminの下にいるのよ、あなた。
ブログカードのロゴをアクセス制限解除する
というわけで、.htaccessでw-logo-blue.pngをアクセス制限解除をおこないます。
<Files w-logo-blue.png>
Satisfy any
allow from all
</Files>
.htaccessに上のコードを追記すると、Basic認証の表示はなくなりました。