2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Python(Django) x AWS 一人アドベントカレンダーAdvent Calendar 2024

Day 4

【Django】Mixed Contentエラーになったのは「request.scheme」を使っていたのが原因だった

Posted at

概要

Djangoアプリを使用していたらMixed Contentというエラーになりました。
少しイレギュラーな原因でしたが、備忘も兼ねて紹介します。

Mixed Contentエラー

ブラウザのコンソールに表示されたエラーは以下です。

Mixed Content: The page at 'https://xxxxx' was loaded over HTTPS, but requested an insecure stylesheet 'http://xxxxx.css'. This request has been blocked; the content must be served over HTTPS.

image.png

該当と思われるDjangoのHTMLテンプレートを確認すると以下でした。

<img class="icon" src="{{ request.scheme }}://{{ request.META.HTTP_HOST }}/xxx/images/{{ tag.image_name }}">

上記は、現在のリクエストのスキームとホスト名に基づいて、画像の完全なURLを動的に生成するコードです。

{{ request.scheme }}:現在のリクエストのスキーム(httpまたはhttps)を取得
{{ request.META.HTTP_HOST }}:現在のリクエストのホスト名を取得
/xxx/images/:画像ファイルが配置されているディレクトリのパス
{{ tag.image_name }}:tagオブジェクトのimage_name属性を取得

この方法で動的にURLを生成していたのが原因でした。

このアプリはAWSのロードバランサーにより、アプリケーション側がHTTPで返したものをHTTPSに変換するルールが設けられていました。ただ、Djangoアプリケーション自体はHTTPでリクエストを処理しているため、request.schemehttpのままになります。

その結果、HTML内で生成される静的ファイルのリンクがhttpになり、ブラウザ上でMixed Contentエラーが発生していたのです。

ブラウザ上ではHTTPSなのに、Djangoアプリとしては静的ファイルをHTTPで生成しているので、「Mixed Content」となったということですね。

解決方法

Djangoアプリではstaticテンプレートタグの方がメジャーでしょう。

実際私も今までstaticテンプレートタグを利用していましたし、これが一般的に推奨されていると思います。
Djangoのドキュメントもこちらですね。

{% static %} テンプレートタグは、静的ファイルの完全 URL を生成します。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?