スクリプトのお勉強

SimpleHTTPSAuthUploadServer というPython用モジュールを書いた

投稿日:

書いた動機

リモート開発になっているので、遠くのホストにあるファイルをお手軽に見たい、取ってきたいor編集したい、というニーズが、私の中であります。

ftpなんか使わず、全部ブラウザでやりたいわけです。

ということで、相手先のホストにPython3が入ってる前提で、

$ python -m http.server 18888

とかよくやります。でも、これだと、httpなので筒抜けだったり、誰でもアクセスできてしまったり、アップロードしたいときはこれだと対応できない、とかあるわけです。

ということで、それらを解消するライブラリ(コマンド)を作ってみました。

機能

以下の機能があります。

  • SSL機能(–https)
    • 秘密鍵/SSL証明書は起動したディレクトリの.sslディレクトリに自動生成
  • Basic認証
    • 引数で、ユーザ名/パスワードを指定する
  • ファイルアップロード
    • 選択したファイルを対象ディレクトリに保存する

インストール

インストールは以下で行えます。

$ pip install "git+https://github.com/KenichiTanino/SimpleHTTPSAuthUploadServer.git@master"

起動方法

以下のように起動します。以下だと、ポート8000番で起動し、httpsでのみアクセスでき、認証はユーザ名aa/パスワードaaになります。
カレントディレクトリのファイルを公開することになります。

$ SimpleHTTPSAuthUploadServer --https --auth 'aa:aa'
### あるいは以下
$ python3 -m python3 -m SimpleHTTPSAuthUploadServer --https --auth 'aa:aa'

画面

上記のように起動し、https://192.168.132.129:8000(ローカルで起動しているVM)にアクセスすると、以下の感じになります。まぁ自己署名証明書なので仕方ない。

その次はBasic認証が出てきます。これにaa/aaを入れれば次に進みます。

以下が対象ディレクトリの内容です。クリックすれば内容を表示します。

アップロードしたい場合は、ファイルを選択をクリックすれば、ファイル選択ダイヤログが出てきて、「upload」すると選択したファイルをアップロードします。

こうなったら成功です。

SSLについて

SSLについては、自らで、.sslディレクトリに自己署名証明書を生成して格納してあります。存在していたら、そのまま使用するので、置き換えることも(一応)可能です。

TODO

ちょっと変な所(アップロードのURL等)を修正したら、Pypiに上げたい。。

参考

https://gist.github.com/csaki/9b482f45710470ed58723d224ef9112c
https://dev.classmethod.jp/articles/create-x-509-v3-cert-python/
https://qiita.com/kinpira/items/0a4e7c78fc5dd28bd695

-スクリプトのお勉強

執筆者:

関連記事

Vue.jsをbetter jQueryとして使う!FastAPI+Vue.jsと生成AIで作る住所録アプリ

昔あるところに。。 昔、jquery全盛で、Vue.jsが出てきたすぐに「これはjqueryを駆逐できるかも」と思ってjqueryの実装をVue.jsに変えようとしたことがあります。 結局全部を変えた …

gradleのcommandLineでリダイレクト

gradleというビルドツールがあります。なぜかRPMを作成するのに使ってます。Ansibleも使ってるんですがね。。 それはともかく、ここの通りなのですが、例えばls -lRの出力を、プロジェクトデ …

Djangoアプリサンプル – 画像ファイルアップロード + 顔モザイク(画像アップロード編)

仕事で使用している、Djangoについて、サンプルを作成してみようと思います。ここでは、画像ファイルのアップロードと顔モザイクを行うwebアプリを作成してみようと思います。 この記事ではファイルアップ …

Markdown to HTML(grip)

1.はじめに 最近の文書はほとんどMarkdownで書くのですが、それをHTMLに変換する方法を調べました。 ただし、私がMarkdownと思っている文法は「github-flavored-markd …

svelteのUIライブラリを使用してみる(TreeView)

前回の続きで、まずは、TreeViewを実現してみます。 Carbon Components Svelte svelteのUIライブラリにCarbon Components Svelteを使用してみま …

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