LoginSignup
3
4

More than 1 year has passed since last update.

【個人開発】郵便番号APIサービスを作りました。または個人でクレジット決済導入について。

Last updated at Posted at 2021-08-03

どんなサービスか?

郵便番号が特定の地域に該当するかを判定するAPIです。
おまけとして、よくある郵便番号から住所を取得する機能も付けました。
ですが、一番の目的は地域の判定です。

【サービスURL】 https://api-zipcode.jp/

例えば、ある郵便番号が新宿区内の郵便番号か?を判定できます。

ここでクイズです。
163-8001 は新宿区内でしょうか?
答えは後ほど。

なぜ作ったか

私は仕事でECサイトの開発をしてます。
ある日、同僚から相談を受けました。
配送先の郵便番号から、自動的に自社配送かを判定したいとのことでした。
このECサイトでは、都内23区は自社のドライバーが配送し、そのほかの地域は外部の配送業者に託しています。

そのようなサービスがないか探しましたが見つけられなかったので自分で作りました。

使用技術

PHP7.4
laravel8.x
AWS EC2,ALB など

クイズの答え

先程の163-8001新宿区内か? の答えですが、今回作ったサービスで調べてみます。

1 ユーザー登録

条件の作成が必要なので、まずはユーザー登録をお願いします。
登録は無料でお試しポイントが付与されます。

2  APIトークンの作成

アカウント>APIトークンページで、APIトークンを作成します。
任意のトークン名と使用する機能に応じてアビリティを選択します。
今回は判定:エリアにチェックを入れます。
スクリーンショット 2021-08-03 23.25.34.png

トークンが作成されます。
スクリーンショット 2021-08-03 23.25.46.png

3 検索条件を作成

アカウント>検索条件ページで、条件を作成します。
新規作成を選択してください。
スクリーンショット 2021-08-03 23.24.27.png

都道府県で東京都を選択し、市区町村に新宿区と入力、完全一致を選択してください。
そして、新規作成で保存してください。
スクリーンショット 2021-08-03 23.24.54.png

保存すると、検索条件キーが発行されます。
スクリーンショット 2021-08-03 23.25.21.png

4 APIを叩く

postmanなどで叩いてもいいですが、APIを試すページを作成しました。
API仕様>areaページに移動します。
先程作成したAPIトークンをコピペしてください。
先程の郵便番号を入力し、検索条件1に先程作成した条件を選択してください。
スクリーンショット 2021-08-03 23.26.51.png

実行するとjsonが返ってきます。

{
  "message": "OK",
  "point": 988,
  "is_area": true,
  "zip_code": "1638001",
  "keys": [
    {
      "operator": "add",
      "key": "38iapq4m"
    }
  ]
}

is_areaがtrueなので、163-8001は新宿区内ということがわかりました。
ちなみに、都庁の郵便番号です。

より複雑な判定

次は、新宿区以外の区内かを判定してみます。

検索条件を追加しました。
今回は、都道府県が東京都で、市区町村が後方一致です。
スクリーンショット 2021-08-03 23.58.11.png

先程と同じ都庁の郵便番号を指定しました。
条件1には東京都 区(後方一致)を選び、演算子にマイナスを選択。
条件2には、最初に作成した新宿区の条件を選びます。
スクリーンショット 2021-08-04 0.01.45.png

実行するとjsonが返ってきます。

{
  "message": "OK",
  "point": 979,
  "is_area": false,
  "zip_code": "1638001",
  "keys": [
    {
      "operator": "add",
      "key": "23a2c592"
    },
    {
      "operator": "sub",
      "key": "38iapq4m"
    }
  ]
}

is_areaがfalseなので、163-8001は新宿区以外の区ではないとわかりました。

苦労した点

有名な話ですが、そもそも日本郵便が公開している郵便番号csvのフォーマットがかなりクセがあります。
それを整形してデータベースを作成するのが大変でした。

個人でクレジット決済を導入できるか?

awsのお金も毎月かかります。
せっかく作ったので、やはりマネタイズしたいですよね。

今回のサービスでは月額定額ではなく従量課金にしました。
1リクエストが0.01円〜0.03円です。
月額の場合は使ってなくても課金されるため、個人的には使った分だけの支払いの方が親切かと思いました。
新規ユーザー登録で、1,000ポイントお試しで付与されます。

ポイントの追加にはクレジット決済を導入しました。

そもそも、個人でクレジット決済を導入できるか?という問題がありました。
個人事業主ではなく、ただの個人です。
調べたところPAY.JPが個人でも導入できることがわかりました。
もちろん審査はあります。

使ってみた感想では、ドキュメントやAPIの機能がしっかりしてたので、使いやすかったです。
仕事でStripeや国内のいくつかのクレジット決済サービスのAPIを使ったことがありますが、国内の決済サービスでは一番わかりやすいと思います。
PAY.JPはAPI仕様をwebで確認できました。
管理画面もモダンでした。
どことは言えませんが、他の決済サービスの仕様書はpdfやエクセルデータでした。。

まとめ

個人でもクレジット決済のサービスが作れました。
今回作ったサービスは今のところ赤字ですが、、アイデア次第でマネタイズできるサービスを作れますね。

3
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
4