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

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

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

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CORS

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

API

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

Q&A

解決済

1回答

1731閲覧

axiosのCORSエラーの対象方法を教えてください

wakita_minaho

総合スコア9

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CORS

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

API

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

0グッド

1クリップ

投稿2020/08/04 03:11

前提・実現したいこと

JavaScriptのaxiosを使ってAPIを叩こうとしているのですが、うまくいかず以下のようなエラーが発生します。

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

Access to XMLHttpRequest at 'https://zipcloud.ibsnet.co.jp/api/search' from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

該当のソースコード

addressHtml

1<!DOCTYPE html> 2<html lang="ja" dir="ltr"> 3 <head> 4 <meta charset="utf-8"> 5 <link rel="stylesheet" href="style.css"> 6 <title></title> 7 </head> 8 <body> 9 <div id="address"> 10 <input type="text" name="" :value="zipcode" placeholder="000-0000" @input="inputNumber"></input> 11 <button type="button" name="button" @click="getAddress">検索</button> 12 <p>{{ result }}</p> 13 </div> 14 15 <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> 16 <script src="./script.js"></script> 17 <script src="https://cdnjs.cloudflare.com/ajax/libs/axios/0.19.2/axios.min.js"></script> 18 <!--http://zipcloud.ibsnet.co.jp/doc/api--> 19 </body> 20</html> 21

AddressJs

1const URL_API = "https://zipcloud.ibsnet.co.jp/api/search"; 2 3const address = new Vue({ 4 el:"#address", 5 data(){ 6 return{ 7 result:"", 8 zipcode:"" 9 }; 10 }, 11 methods:{ 12 inputNumber(e){ 13 this.zipcode = e.target.value; 14 }, 15 16 getAddress(){ 17 const param = this.zipcode; 18 axios.get(URL_API,param) 19 .then(res =>{ 20 this.result = res.data.status === 200 ? res.date.data.fullAddress: 21 res.data.message; 22 }); 23 24 } 25 } 26 27}) 28

試したこと

CORSがオリジン間リソース共有であることは、わかりました。

オリジンがないから、はじかれているのかなと考えていますが、
オリジンの作り方?というか明記の方法が分かりません。

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

参考にしているサイト
https://webkikaku.co.jp/homepage/blog/hpseisaku/javascript/vuejs/

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

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

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

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

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

guest

回答1

0

ベストアンサー

オリジンの作り方?というか明記の方法が分かりません。

APIのマニュアルなどに対応法がないか確認してください。

CORSに対応するヘッダを制御できるのは、zipcloud.ibsnet.co.jpサーバ側です。ブラウザ内のJavaScriptだけでどうこうできるものではありません。

投稿2020/08/04 03:13

maisumakun

総合スコア146018

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問