スクリプトのお勉強 技術

Python Falconによる REST APIの作成

投稿日:

1.はじめに

最近、仕事では、あまり技術的なことをしてませんで。。
今回は、pythonのFalconというWebアプリケーションフレームワークを使用し、REST APIを作成します。

前回は、Djangoで作成しましたが、あまり簡単とは言えませんでした。
今回は、REST APIだけを速攻で作ることが目的です。

1.1 Falconの特徴

Falconの特徴は以下です。

  • 直感的なルーティング
  • 直感的なリクエスト、及び、レスポンスオブジェクト

「直感的な」というのは、「こう実装したいな」というのがそのまま書ける、という意味だと思ってますが、そういうのは意外と少ないので、そこらへんがいいかなと思います。

2.環境

環境は以下で作成しました。

  • OS:Ubuntu 18.04
  • Python 3.6
  • Falcon 2.0

2.1 作成準備

$ pipenv install falcon
$ pipenv install uwsgi

3. API作成/起動

APIを作成し、uwsgiで起動する手順を示します。

3.1 API作成

APIの中身は以下にしてあります。

import json

import falcon


class Resource:

    def on_get(self, req, resp):
        data = {
            'route': [
                {
                    'host': '192.168.1.1'
                }
            ]
        }

        resp.body = json.dumps(data, ensure_ascii=False)

        resp.status = falcon.HTTP_200


api = application = falcon.API()

resource = Resource()

api.add_route('/data', resource)


if __name__ == "__main__":
    from wsgiref import simple_server

    httpd = simple_server.make_server("127.0.0.1", 8000, api)
    httpd.serve_forever()

Resourceというクラスに、REST API的な”data”というリソースを割り付ける感じです。
なかなか直感的ですね。

3.2 uwgsiで起動

api.yamlというファイルを作成し、起動してみます。

以下がapi.yamlです。chdirは起動するカレントディレクトリを指定します。

uwsgi:
  chdir: /home/tanino/script-plactice/practice_the_script/python/falcon
  wsgi-file: /home/tanino/script-plactice/practice_the_script/python/falcon/api.py
  callable: api
  http: 0.0.0.0:8099

callable、というのは、呼び出しクラスを指定します。上記では以下のように設定したので、”api”と指定しています。

api = application = falcon.API()

httpにて、ポート8099番でアクセスを受ける設定にしています。
本番であれば、nginxか何かに接続するのにsocketを使用したほうがいいと思います。

起動方法は以下です。

$ pipenv run uwsgi --yaml api.yaml

思ったより、uwsgiで起動するのが苦労したという。。
上記yamlファイルで''で囲むと失敗しました。。

3.3 APIアクセス

以下のようにアクセスできます。

$ curl http://localhost:8099/data
{"route": [{"host": "192.168.1.1"}]}

4. おわりに

ちょっと苦労しましたが、API自体はとても簡単です。簡単なAPIには使っていきたいと思います。

-スクリプトのお勉強, 技術

執筆者:

関連記事

CSSで注釈を自動ナンバリングする

お仕事で、注釈をつける事がありました。 一瞬で回答できなかったので、ブログネタとして調べてみました。 注釈、とは この意味の注釈とは 「難しい単語]※1 ※1 こういう意味です で「※1」にリンクが張 …

言語別ログイン機能パスワード保存処理方針

ちょっと前に、ログイン機能を作成した際、パスワードを暗号化するか、という議論を目にしたことがありました。 昔だと、「パスワードを暗号化しない」方で実装していましたが、最近はセキュリティが当たり前になっ …

小ネタ: JavaScriptにてBase64エンコード/デコードする方法

小ネタです。JavaScriptにてBase64エンコード/デコードをしようとして、意外と詰まったので、メモ的に方法を書いておきます。 結論: js-base64ライブラリを使用する これだけです。。 …

Python3/ある日付から日付までの月/日/時間ごとの時刻を算出する

小ネタです。 要するに、時刻A と 時刻B を指定したときの、各時間間隔での時刻取得したかったです。 当初はdateutilを使う方法でなく、自前で実装しようと思ったのですが、面倒なことに気づきました …

VMware player(workstation) から WSL2に乗り換える

いままで、VMware player(今のVMWare Workstation Player)上で、作って確認していたけど、いちいち起動するのがだるいです。 ついでにやたらとリソースを使用するので、こ …

google オプトアウト Click here to opt-out.