##Postmonとは
HTTPのメソッドを通して行なったリクエストの結果を、簡単に確認できるようにするツール。
APIを構築する時、ブラウザからHTTPリクエストをサーバーに出すことになる。Postmanを使うと、HTTPのリクエストを確認し、REST APIが機能しているかを、簡単にチェックすることができる。
##インストール方法
「Download Postman for Mac」https://www.postman.com/downloads/
上記のページよりダウンロードする。
アカウントを作成し、Sign inする必要がある(googleアカウントでもサインイン可能)
##APIからのリクエストを確認する
###テストのためのファイルを作成
<作成方法1>
・「+New」をクリックし、「Request」を作成data:image/s3,"s3://crabby-images/02547/02547f6089c8fafa7840959efb14b9b80e67d7f9" alt="スクリーンショット 2020-06-21 10.14.42.png"
・リクエストに名前をつける。HTTPの動作を確認する「Collections」を作成
data:image/s3,"s3://crabby-images/350f9/350f9b41cdb2608524ac913aa8492c1d908bf049" alt="スクリーンショット 2020-06-21 10.23.12.png"
・request name: テストしたい、APIのHTTPリクエスト名
(例:GETをテストしたいのか、DELETEをテストしたいのか、など)
・create folder: テストのためのフォルダーを作成。Postman上の既存のフォルダーに付け加えることもできる
・「Save to APIアプリ名」で保存
<作成方法2>
・「+New collection」 ・「Name」にコレクション名(テストしたいアプリ名)をつけて「Create」data:image/s3,"s3://crabby-images/98b89/98b898914ed4673df0bc0f312e83049788accf91" alt="スクリーンショット 2020-06-21 10.19.19.png"
・「...」をクリックし「Add request」を選択
data:image/s3,"s3://crabby-images/38e63/38e639a0ed1b67675fde59773e1e9bc8775ca4fd" alt="スクリーンショット 2020-06-21 10.20.24.png"
・request name(テストしたいHTTPリクエストの名前)をつける。
・「save to コレクション名」をクリックし保存
data:image/s3,"s3://crabby-images/58e02/58e02b9b3f32ea22bbff9e91dbcf8a7fd17f0dd8" alt="スクリーンショット 2020-06-21 10.21.09.png"
###使ってみよう
①データをgetする
data:image/s3,"s3://crabby-images/40dd5/40dd58a17e6529f54cc82c9c178b489cdc11f075" alt="スクリーンショット 2020-06-21 10.29.59.png"
・テストしたいAPIのURLを入力
・テストしたいHTTPメソッドを選択(今回はGET)
・「send」をクリック
↓
「Body」にHTTPのレスポンスが表示される
②データをpostする
data:image/s3,"s3://crabby-images/50bfc/50bfc1008bb580604682298f982d2d27e79fe08d" alt="スクリーンショット 2020-06-21 10.28.46.png"
・テストしたいAPIのURLを入力
・テストしたいHTTPメソッドを選択(今回はPOST)
・POSTしたいデータをPostman上から入力する
「Body」>「raw」>「JSON」を選択し、POSTしたいデータをJOSN形式で書き込む。
・「send」を押してデータをPOST
↓
「Body」にHTTPのレスポンスが表示されるので、データがPOSTできているか確認する
<参考>今回のアプリで使用したコード
const express = require('express');
require('./db/mongoose')
const User = require('./models/user')
const Task = require('./models/task')
const app = express()
const port = process.env.PORT || 3000
//postしたデータを受け取る処理
app.use(express.json())
app.post('/users', (req, res)=> {
const user = new User(req.body)
//.save()でPromiseオブジェクトを作成し、インスタンスをデータベースに保存
user.save().then(() => {
res.send(user)
}).catch((e) => { //.catchでエラー時の処理を分岐させる
res.send(e)
})
})
##HTTPステータスを操作する
①返ってくるHTTPステータスの確認
data:image/s3,"s3://crabby-images/f5d4e/f5d4e426a67d0f6b0f998876d3abb404dd4751ba" alt="スクリーンショット 2020-06-21 10.31.10.png"
「Body」に表示されるHTTPのレスポンスの「status」を確認。
ここに表示されているのが、返ってくるHTTPステータス
②返ってくるHTTPステータスの変更
app.post('/users', (req, res)=> {
const user = new User(req.body)
//.save()でPromiseオブジェクトを作成し、インスタンスをデータベースに保存
user.save().then(() => {
res.status(201).send(user)
}).catch((e) => {
res.status(400).send(e)
})
})
返ってくるHTTPステータスは「.status()」で設定できる。
Postmanでレスポンスを確認する際はstatus欄も確認する。