質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.52%

  • Python

    7922questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

  • Heroku

    864questions

    HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

  • Flask

    208questions

    FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

flask heroku を使用してアプリテスト

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 453

Jose

score 6

pythonを独学で勉強しています。flaskでアプリを開発中です。
ログインしたのち、出勤パターン(30分、60分、90分)を選択して、終了予定時間
を出力するという流れです。

ローカル(127.0.0.1)ではうまくいきましたが、
herokuでの動作がうまくいきません。

デプロイはできるのですが、最初のログインページを表示できず、Application Errorとでます。

修正方法ご教示いただければ幸いです。

# -*- coding: utf-8 -*-
import sqlite3
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash
from contextlib import closing
import datetime

# 各種設定
DATABASE = 'flaskr.db' # <- チュートリアルと異なる
DEBUG = True
SECRET_KEY = 'development key'
USERNAME = 'admin'
PASSWORD = 'default'
COURSE30 = '30'
COURSE60 = '60'
COURSE90 = '90'
MODORU = 1

minutes = 30

# アプリ生成
app = Flask(__name__)
app.config.from_object(__name__)
app.config.from_envvar('FLASKR_SETTINGS', silent=True)


# DB接続
def connect_db():
    return sqlite3.connect(app.config['DATABASE'])


def init_db():
    with closing(connect_db()) as db:
        with app.open_resource('schema.sql', mode='r') as f:
            db.cursor().executescript(f.read())
        db.commit()

@app.before_request
def before_request():
    g.db = connect_db()

@app.teardown_request
def teardown_request(exception):
    db = getattr(g, 'db', None)
    if db is not None:
        db.close()


#ユーザのログインとログアウトを行うためのページ
@app.route('/login', methods=['GET', 'POST'])
def login():
    error = None
    if request.method == 'POST':
        if request.form['username'] != app.config['USERNAME']:
            error = u'ユーザ名が間違っています'
        elif request.form['password'] != app.config['PASSWORD']:
            error = u'パスワードが間違っています'
        else:
            session['logged_in'] = True
            flash(u'ログインしました')
            return redirect(url_for('show_entries'))
    return render_template('login.html', error=error)


@app.route('/logout')
def logout():
    session.pop('logged_in', None)
    flash(u'ログアウトしました')
    return redirect(url_for('login'))


#データベースに保存されている全てのエントリーの一覧のページ
@app.route('/show_entries', methods=['GET', 'POST'])
def show_entries():
    error = None
    if request.method == 'POST':
        if request.form['comp_select'] == app.config['COURSE30']:
            time = datetime.datetime.now()
            time1 = time + datetime.timedelta(minutes=30)
            time1 = time1.strftime("%H:%M")
            # return redirect(url_for('course30'))
            return render_template('course30.html', time1=time1)
        elif request.form['comp_select'] == app.config['COURSE60']:
            time = datetime.datetime.now()
            time1 = time + datetime.timedelta(minutes=60)
            time1 = time1.strftime("%H:%M")
            # return redirect(url_for('course30'))
            return render_template('course30.html', time1=time1)
        elif request.form['comp_select'] == app.config['COURSE90']:
            time = datetime.datetime.now()
            time1 = time + datetime.timedelta(minutes=90)
            time1 = time1.strftime("%H:%M")
            # return redirect(url_for('course30'))
            return render_template('course30.html', time1=time1)
        elif request.form['comp_select'] == app.config['MODORU']:
            return render_template('show_entries.html', modoru=modoru)
    return render_template('show_entries.html', error=error)

@app.route("/course30" , methods=['GET', 'POST'])
def course30():
    return render_template('course30.html', time1=time1)

if __name__ == '__main__':
    app.run()
<!doctype html>
<link rel=stylesheet type=text/css href="{{ url_for('static', filename='style.css') }}">
<div class="page">
  <div class="metanav">
  {% if not session.logged_in %}
    <a href="{{ url_for('login') }}">ログイン</a>
  {% else %}
    <a href="{{ url_for('logout') }}">ログアウト</a>
  {% endif %}
  </div>
  {% block body1 %}{% endblock %}
</div>
{% extends "layout.html" %}
{% block body1 %}
  {% if error %}<p class="error"><strong>エラー:</strong> {{ error }}{% endif %}
  <form action="{{ url_for('login') }}" method="post">
    <dl>
      <dt>ユーザ名:
      <dd><input type="text" name="username">
      <dt>パスワード:
      <dd><input type="password" name="password">
      <dd><input type="submit" value="ログイン">
    </dl>
  </form>
{% endblock %}
{% extends "layout.html" %}
{% block body1 %}
    {% if error %}<p class="error"><strong>エラー:</strong> {{ error }}{% endif %}
    <form action="{{ url_for('show_entries') }}" method="post">
      <dl>
        <dt>コースを選んでください:
      </dl>
      <dl>
        <select class="form-group" id="comp_select" name="comp_select">
          <option value="30">30分</option>
          <option value="60">60分</option>
          <option value="90">90分</option>
        </select>
      </dl>
      <div class="form-group">
        <button type="submit" value="Go!" >決定</button>
      </div>
    </form>
{% endblock %}
{% extends "layout.html" %}
{% block body1 %}
  {% if session.logged_in %}
      <strong>終了時間:</strong> {{ time1 }}
      <div class="form-group">
        <button type="submit" value="Go!" onclick="location.href='http://127.0.0.1:5000/show_entries'">戻る</button>
      </div>
  {% endif %}
{% endblock %}
#エラーログとなります
2018-05-13T10:46:00.756011+00:00 heroku[web.1]: Starting process with command `python flaskr.py`
2018-05-13T10:46:03.494552+00:00 app[web.1]: * Serving Flask app "flaskr" (lazy loading)
2018-05-13T10:46:03.494672+00:00 app[web.1]: * Environment: production
2018-05-13T10:46:03.494773+00:00 app[web.1]: WARNING: Do not use the development server in a production environment.
2018-05-13T10:46:03.494844+00:00 app[web.1]: Use a production WSGI server instead.
2018-05-13T10:46:03.494934+00:00 app[web.1]: * Debug mode: on
2018-05-13T10:46:03.516227+00:00 app[web.1]: * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
2018-05-13T10:46:03.517431+00:00 app[web.1]: * Restarting with stat
2018-05-13T10:46:03.931812+00:00 app[web.1]: * Debugger is active!
2018-05-13T10:46:03.933293+00:00 app[web.1]: * Debugger PIN: 930-711-696
2018-05-13T10:47:01.073754+00:00 heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
2018-05-13T10:47:01.073998+00:00 heroku[web.1]: Stopping process with SIGKILL
2018-05-13T10:47:01.161020+00:00 heroku[web.1]: State changed from starting to crashed
2018-05-13T10:47:01.163257+00:00 heroku[web.1]: State changed from crashed to starting
2018-05-13T10:47:01.145341+00:00 heroku[web.1]: Process exited with status 137
2018-05-13T10:47:03.889944+00:00 heroku[web.1]: Starting process with command `python flaskr.py`
2018-05-13T10:47:05.549637+00:00 app[web.1]: * Serving Flask app "flaskr" (lazy loading)
2018-05-13T10:47:05.549656+00:00 app[web.1]: * Environment: production
2018-05-13T10:47:05.549690+00:00 app[web.1]: WARNING: Do not use the development server in a production environment.
2018-05-13T10:47:05.549725+00:00 app[web.1]: Use a production WSGI server instead.
2018-05-13T10:47:05.549754+00:00 app[web.1]: * Debug mode: on
2018-05-13T10:47:05.566177+00:00 app[web.1]: * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
2018-05-13T10:47:05.566970+00:00 app[web.1]: * Restarting with stat
2018-05-13T10:47:05.811050+00:00 app[web.1]: * Debugger PIN: 142-137-009
2018-05-13T10:47:05.809616+00:00 app[web.1]: * Debugger is active!
2018-05-13T10:48:04.080389+00:00 heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
2018-05-13T10:48:04.080451+00:00 heroku[web.1]: Stopping process with SIGKILL
2018-05-13T10:48:04.149952+00:00 heroku[web.1]: Process exited with status 137
2018-05-13T10:48:04.167841+00:00 heroku[web.1]: State changed from starting to crashed
2018-05-13T10:58:26.029485+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=dry-meadow-50578.herokuapp.com request_id=e48f6816-575e-4a8b-bc3f-4cee3ae72343 fwd="126.87.104.45" dyno= connect= service= status=503 bytes= protocol=https
2018-05-13T10:58:27.120667+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=dry-meadow-50578.herokuapp.com request_id=4faa11fd-8c8b-4de6-af99-b25068d34f91 fwd="126.87.104.45" dyno= connect= service= status=503 bytes= protocol=https
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Lulucom

    2018/05/13 16:13

    Herokuのログを確認してエラーの詳細を追記ください(質問文の中に追記ください)。

    キャンセル

  • Jose

    2018/05/13 20:02

    エラーログ追記しました。Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launchという部分があやしいと思いますが、いかがでしょうか?よろしくお願いいたします

    キャンセル

回答 1

checkベストアンサー

0

app.run()呼出しを少し変更する必要があるようです。

    port = int(os.environ.get("PORT", 5000))
    app.run(host="0.0.0.0", port=port)

参考: http://shkh.hatenablog.com/entry/2013/01/01/192857

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/14 23:15

    無事動作しました。ご回答ありがとうございます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Python

    7922questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

  • Heroku

    864questions

    HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

  • Flask

    208questions

    FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。