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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Flask

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

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

Q&A

解決済

1回答

6509閲覧

Flaskを用いた開発中の404エラー

kou-pen

総合スコア11

Flask

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

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

0グッド

0クリップ

投稿2021/08/17 03:17

編集2021/08/17 05:57

Python+Flask+sqlalchemyでのプログラム作成

現在、上の3つを使ってブログのようなwebアプリを作ろうとしています。
Lolipopを使って運用しようとして、ディレクトリの配置を変えて作成したところ、
突如404エラーで詰まってしまいました。

素人が入門書のプログラムを改造したためこうなったのだと思います。
うまく動くような解決策を提示していただけるとありがたいです。

ソースコードをどこまで貼ればいいのか分からなかったので全部貼らせていただきます。
(順番が滅茶苦茶ですみません)

エラーメッセージ

127.0.0.1 - - [17/Aug/2021 11:53:55] "GET / HTTP/1.1" 404 - 127.0.0.1 - - [17/Aug/2021 11:53:55] "GET /favicon.ico HTTP/1.1" 404 -

ソースコード

python

1#views.py 2from flask import request,redirect,url_for,render_template,flash,session 3from __init__ import app 4from models.entries import Entry ,SESSION 5from sqlalchemy.engine import base 6 7@app.route('/') 8def show_entries(): 9 if not session.get('logged_in'): 10 return redirect(url_for('login')) 11 entrie = SESSION.query(Entry).all() 12 return render_template('home.html',entries = entrie) 13 14@app.route('/login',methods=['GET','POST']) 15def login(): 16 error = None 17 if request.method == 'POST': 18 if request.form['username'] != app.config['USERNAME']: 19 flash('error:username') 20 elif request.form['password'] != app.config['PASSWORD']: 21 flash('error:password') 22 else: 23 session['logged_in']=True 24 flash('logged in') 25 return redirect(url_for('show_entries')) 26 return render_template('login.html') 27 28@app.route('/logout') 29def logout(): 30 session.pop('logged_in',None) 31 flash('logged out') 32 return redirect(url_for('show_entries')) 33 34@app.route('/entries',methods=['POST']) 35def add_entry(): 36 if not session.get('logged_in'): 37 return redirect(url_for('login')) 38 entry = Entry( 39 long = request.form['long'], 40 subject = request.form['subject'], 41 now = request.form['now'], 42 comment = request.form['comment'] 43 ) 44 SESSION.add(entry) 45 SESSION.commit() 46 flash('created') 47 return redirect(url_for('show_entries')) 48 49@app.route('/entries/new') 50def new_entry(): 51 if not session.get('logged_in'): 52 return redirect(url_for('login')) 53 return render_template('new.html') 54 55

python

1#server.py 2from __init__ import app 3 4if __name__ =='__main__': 5 app.run()

python

1#config.py 2DEBUG=True 3USERNAME='admin' 4PASSWORD='admin' 5SECRET_KEY = 'f47wyhdfa8387hadfja3798293uhda83jk' 6SQLALCHEMY_DATABASE_URI = 'sqlite:///coco.db' 7SQLALCHEMY_TRACK_MODIFICATIONS = True

python

1#__init__.py 2from flask import Flask 3 4app=Flask(__name__) 5app.config.from_object('config') 6 7import views

python

1#entries.py 2from sqlalchemy.sql.sqltypes import DateTime, Time 3from sqlalchemy import create_engine 4from sqlalchemy.ext.declarative import declarative_base 5from sqlalchemy import Column, Integer, String 6from sqlalchemy.orm import sessionmaker 7 8engine = create_engine('sqlite:///coco.db', echo=True) 9Base = declarative_base() 10 11class Entry(Base): 12 __tablename__ = 'entries' 13 id = Column(Integer,primary_key=True) 14 long = Column(Time) 15 subject = Column(String) 16 now = Column(DateTime) 17 comment = Column(String(50)) 18 19class User(Base): 20 __tablename__ = 'user' 21 id = Column(Integer, primary_key=True) 22 name = Column(String) 23 password = Column(String) 24 25Session = sessionmaker(bind=engine) 26SESSION = Session() 27 28Base.metadata.create_all(engine) 29

html

1<!--home.html--> 2{% extends "layout.html" %} 3{% block content %} 4<ul class="list-group list-group-flush"> 5 6 {% for entry in entries %} 7 <div class="card"> 8 <div class="card-body"> 9 <h5 class="card-title">{{ entry.subject }}</h5> 10 </div> 11 </div> 12 {% else %} 13 noarticle 14 {% endfor %} 15 16</ul> 17{% endblock %}

html

1<!--layout.html--> 2<!DOCTYPE html> 3<title>coco study</title> 4<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"> 5<script src="https://code.jquery.com/jquery-3.2.1.slim.min.js"></script> 6<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"></script> 7<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"></script> 8 9 10<div class="container"> 11 <nav class="navbar navbar-expand-lg navbar-light bg-light"> 12 <a class="navbar-brand" href="{{url_for('show_entries')}}">Coco study</a> 13 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation"> 14 <span class="navbar-toggler-icon"></span> 15 </button> 16 17 <div class="collapse navbar-collapse" id="navbarNav"> 18 <ul class="nav navbar-nav navbar-right"> 19 {% if not session.logged_in %} 20 <li class="nav-item"> 21 <a class="nav-link" href="{{url_for('login')}}">login</a> 22 </li> 23 {% else %} 24 <li class="nav-item"> 25 <a class="nav-link" href="{{url_for('new_entry')}}">new entry</a> 26 </li> 27 <li class="nav-item"> 28 <a class="nav-link" href="{{url_for('logout')}}">logout</a> 29 </li> 30 {% endif %} 31 </ul> 32 </div> 33 </nav> 34 {% for message in get_flashed_messages() %} 35 <div class="alert alert-info" role="alert"> 36 {{ message }} 37 </div> 38 {% endfor %} 39 40 <div class="blog-body"> 41 {% block content %} 42 {% endblock %} 43 </div> 44 45</div>

html

1<!--login.html--> 2{% extends "layout.html" %} 3{% block content %} 4<form action="/login" method="POST"> 5 <div class="form-group"> 6 <label for="InputTitle">username</label> 7 <input type="text" class="form-control" id="InputTitle" name="username"> 8 </div> 9 10 <div class="form-group"> 11 <label for="InputPassword">password</label> 12 <input type="password" class="form-control" id="InputPassword" name="password"> 13 </div> 14 <button type="submit" class="btn btn-primary">login</button> 15</form> 16{% endblock %}

html

1<!--new.html--> 2{% extends "layout.html" %} 3{% block content %} 4<form action="{{url_for('add_entry')}}" method="POST" class="add-entry"> 5 <div class="form-group"> 6 <label for="InputSubject">Subject</label> 7 <input type="text" class="form-control" id="InputSubject" name="title"> 8 </div> 9 <div class="form-group"> 10 <label for="Inputlong">long</label> 11 <input type="time" class="form-control" id="Inputlong" name="long"> 12 </div> 13 <div class="form-group"> 14 <label for="Inputnow">now</label> 15 <input type="time" class="form-control" id="Inputnow" name="now"> 16 </div> 17 <div class="form-group"> 18 <label for="inputcomment">comment</label> 19 <input type="text" class="form-control" id="Inputcomment" name="comment"> 20 </div> 21 <button type="submit" class="btn btn-primary">create</button> 22</form> 23{% endblock %}

補足1

ディレクトリの構造です

/application| |-/models |-__init__.py(空) |-entries.py |-/templates |-home.html |-layout.html |-login.html |-new.html |-__init__.py |-coco.db |-config.py |-server.py |-views.py

###補足2
まだlolipopでは試さず、ローカルで動かしています

cd application python server.py

https://github.com/chaingng/flask_tutorial

こちらのプログラムを元にしました

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mather

2021/08/17 05:53

Lolipop での flask の起動方法を提示してください。 (flask run コマンドなど) 参考にしたページなどがあれば質問に記載してください。
kou-pen

2021/08/17 05:58

編集させていただきました
guest

回答1

0

ベストアンサー

まず、 通常 __init__.py にはモジュールシステムの解決のための記述を行います。今回はひとまずファイルだけ置いて、中には何も記述しないのが良いと思います。
URLにあるチュートリアルの場合は flask_blog ディレクトリをモジュールとして扱うために __init__.py に記述しています。
参考 : https://qiita.com/msi/items/d91ea3900373ff8b09d7

また、__init__.pyviews.py で循環参照しています。(お互いを import している)
これによってエラーが起こるわけではないですが、あまりよろしくないです。

最小限のコードを書いてみたところ普通に動きました。

python

1# views.py 2from flask import Flask 3 4app = Flask(__name__) 5 6@app.route("/") 7def index(): 8 return "Hello"

python

1# server.py 2from views import app 3 4if __name__ =='__main__': 5 app.run()

python

1# __init__.py (空ファイル)

投稿2021/08/17 06:24

mather

総合スコア6759

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kou-pen

2021/08/17 06:50 編集

一発で直りました!! 僕の勉強不足でした。。。 ありがとうございました(ToT)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問