🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

CORS

CORSとはCross-Origin Resource Sharingの頭文字をとったもので、ブラウザがオリジン以外のサーバからデータを取得するシステムのことです。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

3077閲覧

github pagesのcorsを解消したい(Vue CLI)

sohh

総合スコア6

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

CORS

CORSとはCross-Origin Resource Sharingの頭文字をとったもので、ブラウザがオリジン以外のサーバからデータを取得するシステムのことです。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

1クリップ

投稿2021/02/09 06:45

前提・実現したいこと

github pagesのcorsを解消したい
公開したアプリケーションは、Vue cliで作成し、axiosで天気予報apiから値を取得するものです。
この場合、どんな解決策が考えられますか?

発生している問題・エラーメッセージ

下記APIを利用し、天気を取得・表示するものを制作しました。
https://www.metaweather.com/api/

開発環境では、chromeの拡張機能を使って、CORSのエラーを無視することで、使うことが出来ました。
しかし、github pagesに公開すると

Access to XMLHttpRequest at 'https://www.metaweather.com/api/location/1118370' from origin 'https://******.github.io' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. Weather.vue:61

これが、コンソールで確認できるエラーです。

試したこと

下記のように、URLをつなげる方法を試したが、失敗
'https://****.github.io/https://www.metaweather.com/api/location/15015370/'

参考URL
https://medium.com/@deepak13245/using-react-hooks-to-handle-api-calls-d6bb4ae91188

補足情報(FW/ツールのバージョンなど)

  • vue cli 4.5

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

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

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

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

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

hoshi-takanori

2021/02/09 06:57

metaweather は CORS をサポートしてないようです。で、開発環境に拡張機能を入れて CORS を無視するというのは、あくまで開発環境であり、自分だけしかアクセスしないから許されることで、github pages で世界中に公開するのはどうかと思います。
sohh

2021/02/09 07:17

なるほど。 APIの利用を始めたばかりで、理解がたりませんでした。指摘いただきありがとうございます。
guest

回答1

0

ベストアンサー

hoshi-takanori さんから既にコメントがありますが、metaweatherはCORS対応しておらず、JSONPにも対応していないようです。なのでブラウザから呼び出すのは不可能です。このAPIをサーバーから呼び出して利用する方法しかないように思えます。

(追記)
参考URLの方法は、まさにmetaweatherのAPIを中継してCORS対応にするPROXY(サーバー)を作ったというもので、URLを二段重ねにしたら勝手にPROXYになるわけではありません。

投稿2021/02/09 07:07

編集2021/02/09 07:14
ockeghem

総合スコア11705

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

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

sohh

2021/02/09 07:38

github pagesで公開(サーバー側使用してない)の場合、proxyで対応する手段がある。という理解でよろしいでしょうか? 回答いただきありがとうございます!
ockeghem

2021/02/09 07:42

proxyは自前で用意する必要があります。参照記事では、そのproxyをheroku上に用意しています。
sohh

2021/02/09 07:48

参照記事では、heroku上で自前で用意していたということなんですね。 問題の概要がはっきりしました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問