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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

Q&A

解決済

3回答

5350閲覧

[Django]アップロードした画像をフロント側で表示する際に404エラーになる

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

0グッド

1クリップ

投稿2020/06/17 16:35

聞きたいこと

  • Django Rest Framework
  • Vue

を使用して、Webアプリ開発をしているのですが、ローカル環境でサーバーにアップロードした画像をフロントエンド側で表示する際にエラーとなってしまいます。

下の設定ファイルにて設定したMEDIA_ROOT内に画像ファイルが存在していることまでは確認できています。

以下が主に設定したファイルと設定内容です。

  • settings.py
: MEDIA_ROOT = 'media' MEDIA_URL = '/'
  • urls.py
: if settings.DEBUG: urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

エラー内容

GET http://localhost:3000/media/sample.png 404 (Not Found)

** 備考 **

バックエンドはlocalhost:8000で可動していて、フロントエンドはlocalhost:3000で可動しています。

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

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

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

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

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

guest

回答3

0

ベストアンサー

下のようにバックエンドのポートに変更したところ、問題なく画像が表示できました。
http://localhost:8000/media/sample.png

投稿2020/06/23 01:40

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

もしかして、

─media │ └─img │ └─sample.png ````img`とかのフォルダに入っていたら、 [http://localhost:3000/media/img/sample.png](http://localhost:3000/media/img/sample.png)にしないといけませんが。

投稿2020/06/17 23:54

ForestSeo

総合スコア2722

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

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

退会済みユーザー

退会済みユーザー

2020/06/18 00:44

ご回答ありがとうございます。指定していただいたURLを自分のサイトに置き換えてアクセスしてみましたが、404エラーでした。 (補足) 自分のプロジェクトだと、プロジェクトルート直下の/media/img/sample.png の中に画像が存在していて、DBのImageFieldにはimg/sample.png が保存されている状態です。
guest

0

はずしているかもしれませんが。

settings.py を

MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

等に変更してもダメでしょうか?

参考: Django mediaファイルとAWS S3 - Qiita

投稿2020/06/17 18:53

Yasumichi

総合スコア1773

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問