« なかやまがゆくHeroku本社への道 no.3~Herokuコマンドお絵かき~ | メイン | HerokuとGitHubの連携を考える »

2015年6月24日 (水)

Herokuで静的コンテンツをホストしたい

こんにちは、三宅です。
フレクトでは、お客様への提案や短期間でのプロジェクトでは、なるべく早い段階から動くアプリケーションのイメージを持ってもらえるように、HTMLで作った静的コンテンツでデモやモックを作成することが多くあります。
そんな時、変更のたびにファイルをやり取りしているのではスピード感に欠けるため、Herokuにコンテンツをホストしてオンラインで確認してもらえるようにしています。
今回はそんな静的コンテンツを簡単にHerokuにホストするためのアセットの紹介となります。

flect-miyake/node-static-server

node-static-serverは静的リソースをホストすることを目的とした、シンプルなWebサーバです。
静的リソースをディレクトリに配置、コマンド1つでローカル環境にWebサーバを起動し、その動作を確認することができます。
Heroku上で動かすこともできるため、デモ環境の構築や複数のメンバー間でのWebデザインの確認などに用いることも可能です。

Deploy

Herokuへのデプロイ

Herokuボタンをクリックすると、自分のHerokuアカウントにデプロイし、動かすことができます。

ローカル環境での編集

任意のディレクトリに移動し、Herokuに作成されたアプリをローカルにクローンし、編集することができます。

heroku git:clone --app アプリ名

BASIC認証の設定

Herokuに公開の際に、アクセスできる人を制限するためにBASIC認証を設定することができます。
basic-auth-connectを使い、プロダクション環境でユーザ名とパスワードが設定されている時に、BASIC認証が有効になるようにしています。

Herokuの環境変数として

  • BASIC_AUTH_USERNAME
  • BASIC_AUTH_PASSWORD

上記の2つを設定することで、BASIC認証が有効になります。

ローカル環境での利用

ローカル環境へのクローン

$ git clone https://github.com/flect-miyake/node-static-server.git

Gitを用いて、ローカル環境にリポジトリをクローンします。

npmパッケージのインストール

Gitによってクローンされたディレクトリに移動し、npmパッケージのインストールコマンドを実行します。

$ cd node-static-server
$ npm install

node-static-serverはExpress4を用いています。

静的リソースの配置

publicディレクトリに、静的リソースを配置します。
Webサーバ起動時は、publicディレクトリがルートディレクトリとなります。

サーバの起動

リポジトリのルートディレクトリで次のコマンドを入力すると、Webサーバが起動します。

$ npm start

ブラウザからlocalhost:3000にアクセスすることで、publicディレクトリに配置されたコンテツを確認することができます。

Herokuの料金体系が変更となり、無料でWebサイトを公開するサーバとして使うことは難しくなってしまいましたが、デモやモックの共有や開発ではそのスピーディーさや手軽さを存分に生かすことができると思います。


コメント

コメントを投稿

採用情報

株式会社フレクトでは、事業拡大のため、
Salesforce/Force.comのアプリケーション
開発
HerokuやAWSなどのクラウドプラッ
トフォーム上でのWebアプリケーション開発

エンジニア、マネージャーを募集中です。

未経験でも、これからクラウドをやってみた
い方、是非ご応募下さい。

フレクト採用ページへ

会社紹介

株式会社フレクトは、
認定コンサルタント
認定上級デベロッパー
認定デベロッパー
が在籍している、
セールスフォースパートナーです。
heroku partnersにも登録されています。
herokuパートナー
株式会社フレクトのSalesforce/Force.com
導入支援サービス
弊社の認定プロフェッショナルが支援致します。
・Visualforce/Apexによるアプリ開発
・Salesforceと連携するWebアプリ開発
も承っております。
セールスフォースご検討の際は、
お気軽にお問合せください。
Powered by Six Apart