Axios and Mocoon

Axios で Mockoon に接続できなかった話

個人開発しているサービス「日本の地震情報」での話です。

このサービスでは、P2P地震情報 JSON API v2 から地震データを取得しています。開発していく中で、やはりAPI のモックが必要になり、いろいろ調べてみたところ Mockoon というツールの存在を知りました。

何よりデスクトップアプリケーションで UI がわかりやすいところに惹かれました。

インストールして、API root を設定し、レスポンス用のデータを登録、そして mock サーバー を起動します。ブラウザでAPI root にアクセスすれば、問題なくJSON が返却されているのがわかります。とても簡単ですね。

しかしアプリから mock API に接続できない

さっそくプログラムのデータフェッチURLを書き換えて試してみます。

import { RequestParams, ResponseData } from '../common/Types'
import axios, { AxiosResponse } from 'axios'

export const fetchQuake = (props?: RequestParams) => {
  
  //const baseUrl = 'https://api.p2pquake.net/v2/jma/quake'
  const baseUrl = 'http://localhost:3001/quake'
  
  const params: RequestParams = {
    limit: 100,
    min_scale: 10,
    quake_type: 'DetailScale',
    order: -1,
    ...props,
  }

  // 地震データ取得
 return axios
    .get(baseUrl, { params })
    .then((res: AxiosResponse<ResponseData[]>) => res.data)
    .catch((err) => console.log('error: ', err.message)) 
}

しかし、何故かうまく画面が表示されません。トップページでは取得した地震情報の一覧と、震央がマッピングされた leaflet の日本地図が表示されるのはずなのですが…

(ここで API のレスポンスが得られなかった場合のエラー処理が完全に欠落していることに気がつきました😱)

Mockoon のチュートリアルには Next.js の事例もありますが、axios ではなく、fetch を使っています。

ちなみにこのアプリのトップページは、 Next.js 12 の ISR でデータを取得しています。

yarn dev したターミナルのコーンソールをよく見てみると、確かにエラーが表示されています。

解決

「axios mockoon」で検索してもよくわからなかったのですが、このエラーメッセージを含めて検索してみると、一発で回答が見つかりました!

こちらの Qitta の投稿です👇

下のように修正して問題なく mock api に接続できるようになりました。

// const baseUrl = 'http://localhost:3001/quake'

const baseUrl = 'http://127.0.0.1:3001/quake'

この現象が起きる理由は、こちらの issue で議論されていたようです。

ほとんど理解できていなのですが、

  • 「localhost」を解決する IPアドレスが IPv4では「127.0.01」、IPv6では「::1」
  • 今回はIPv6として解決されているのでエラーとなる
  • なので「localhost」ではなく、 IPアドレスを直接指定すればOKとなる

正確な内容は上記の issue を参照ください。

怪我(エラー)の功名?

今回のエラーのおかげで、API からデータが取得できなかった場合の処理を追加することができました🙂

最近の投稿です

Thumbnail of new posts 025

: 野菜

麻婆大根

下記はこれまでにつくってきた麻婆シリーズです。 麻婆【茄子】 麻婆【白菜】 麻婆 ...
Thumbnail of new posts 153

: パスタ

カニカマと椎茸のペペロンチーノ

使う食材を選ばずに、手軽においしくできるのがパスタの利点です。 今回はカニカマを ...
Thumbnail of new posts 153

: 麺類

カレー辛ラーメンブラック

辛ラーメンのカレーアレンジがおいしいであろうことは容易に察しが付きました。 ラー ...
Thumbnail of new posts 138

: 野菜

シャトルシェフでつくる豚バラと白菜の旨くて辛い鍋

シャトルシェフを使って、みんな大好き「ほったらかし」調理でつくる簡単なお鍋です。 ...
Thumbnail of new posts 179

: パスタ

コンビーフとキャベツのパスタ

コンビーフとキャベツを使った定番のパスタです。 コンビーフを使ったレシピは、どれ ...

このブログへのアクセスについて

  • 300今日の閲覧数:
  • 163今日の訪問者数:
  • 439昨日の閲覧数:
  • 225昨日の訪問者数:
  • 10784今月の閲覧数:
  • 4現在オンライン中の人数:

767ビュー

Tec系Tec

Posted by movinow