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

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

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

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

0回答

331閲覧

データベースにあるカラムの一つが読み込まれず、commit()できない。

zero-penguin

総合スコア1

Flask

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2023/04/27 05:28

やりたい事

fraskでCRUD操作による記録保管アプリケーションを作成しています。
CRUD操作は問題なく実装できましたが、サインインからログインする工程でエラーが発生したので、
その部分を直したいです。

エラー

サインインからログインの過程で必要と思われるコードをいかに貼ります。
アプリケーショのインスタンス化を行っているapp.py

from flask import Flask from flask import render_template, request, redirect from flask_sqlalchemy import SQLAlchemy from flask_login import UserMixin, LoginManager, login_user, logout_user, login_required # パスワードの非表示化と確認機能のインポート from werkzeug.security import generate_password_hash, check_password_hash from datetime import datetime import pytz import os # インスタンス化 app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///blog.db' # ランダムなシークレットキーの作成 app.config['SECRET_KEY'] = os.urandom(24) # アプリにデータベースを紐づけ db = SQLAlchemy(app) # ログインマネージャのインスタンス化 login_manager = LoginManager() # アプリにログイン機能を紐づけ login_manager.init_app(app) #databaseの作成 class Post(db.Model): id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(50), nullable=False) body = db.Column(db.String(500), nullable=False) created_at = db.Column(db.DateTime, nullable=False, default=datetime.now(pytz.timezone('Asia/Tokyo'))) class User(UserMixin, db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(30), nullable=False, unique=True) password = db.Column(db.String(12),unique=True) @app.route('/', methods=['GET','POST']) @login_required def index(): if request.method == 'GET': # Postに保存されている全てのデータの取得 posts = Post.query.all() return render_template('index.html', posts=posts) @app.route('/signup', methods=['GET', 'POST']) def signup(): if request.method == 'POST': username = request.form.get('username') password = request.form.get('password') user = User(username=username, password=generate_password_hash(password, method='sha256')) #入れたデータを保存 db.session.add(user) #保存されたデータに変更 db.session.commit() #login.htmlに移動 return redirect('/login') else: return render_template('signup.html') # 下記にデコレーターによるセキュリティ強化があるが、その実施に必要なコード @login_manager.user_loader def load_user(user_id): return User.query.get(int(user_id)) @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': username = request.form.get('username') password = request.form.get('password') # Userのデータベースから合致する名前を探す。 user = User.query.filter_by(username=username).first() # 探し出されたユーザー名のパスワードと入力されたパスワードが同じならば if check_password_hash(user.password, password): # importしたlogin_userを用いてログインする login_user(user) # トップページに移動する return redirect('/') else: return render_template('login.html') @app.route('/logout') # デコレーターの設定により、ログインしているユーザーのみアクセス出来るようにセキュリティ @login_required def logout(): logout_user() return redirect('/login') @app.route('/create', methods=['GET', 'POST']) @login_required def create(): #新しい投稿がされたなら、createのform内のname=title,bodyを取得する if request.method == 'POST': title = request.form.get('title') body = request.form.get('body') #取得したデータをデータベースに入れる post = Post(title=title, body=body) #入れたデータを保存 db.session.add(post) #保存されたデータに変更 db.session.commit() #変更されたらトップページに戻る return redirect('/') else: return render_template('create.html') # index.htmlのa href="/{{post.id}}/update"からidを受取り、可変型のルーティングで取得する @app.route('/<int:id>/update', methods=['GET','POST']) @login_required def update(id): # postのインスタンス化 idをURLに入れておく post = Post.query.get(id) if request.method == 'GET': return render_template('update.html', post=post) else: # インスタンス化されたpostに上書きする post.title = request.form.get('title') post.body = request.form.get('body') # 更新 db.session.commit() return redirect('/') @app.route('/<int:id>/delete', methods=['GET']) @login_required def delete(id): # postのインスタンス化 post = Post.query.get(id) db.session.delete(post) db.session.commit() return redirect('/')

サインインページのhtmlテンプレート

{% extends "base.html" %} {% block content %} <h1>ユーザー登録</h1> <form method = "POST"> <label for ="title">ユーザー名</label> <input type="text" name="username"> <label for = "body">パスワード</label> <input type="password" name="password"> <input type="submit" value="新規登録"> </form> {% endblock %}

ログインページのテンプレート

{% extends "base.html" %} {% block content %} <h1>New Post</h1> <form method = "POST"> <label for ="title">ユーザー名</label> <input type="text" name="username"> <label for = "body">パスワード</label> <input type="password" name="password"> <input type="submit" value="ログイン"> </form> {% endblock %}

問題のサインインからログインにページが移動する際のエラー表示画像と、その説明文らしき英文を載せます。

Image

sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) table user has no column named password [SQL: INSERT INTO user (username, password) VALUES (?, ?)] [parameters: ('1234', 'sha256$kzNfVvQqCCDiF8tm$27b9e7ef5cf9b1ae4f229cc737efba04a0b695a7f8d57bf51331e7167fb128ae')] (Background on this error at: https://sqlalche.me/e/20/e3q8)

試したこと

・vscode内のpythonの対話モードでデータベースを再度読み込んだが、治らなかった。
・同じようなエラーの問題をネットで検索したが、うまく見つけられなかった。

情報

  • vscodeで作成中
  • Python のバージョン 3.11.3
  • 参考教材 「【完全版】この動画1本でFlaskの基礎を習得!忙しい人のための速習コース(Flask超入門)」

 https://www.youtube.com/watch?v=VtJ-fGm4gNg

###参考

  • githubにこのアプリケーションに必要なすべてのファイルを入れています。
    https://github.com/zero-penguin/qalog
    (README.mdを必要なら参考にしてください。)

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

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

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

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

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

AbeTakashi

2023/04/27 05:35

「table user has no column named password」とわりと明確にエラーの原因が書いてありますが、こちらはちゃんと確認されましたか? 試されたことやそれ以外のところでもまったく触れられてませんが・・・
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問