2016-07-14 7 views
0
デフォルトとは異なるHTMLページに成功したレジスタにリダイレクトする方法

:。「/」 リダイレクトは、ログインしているユーザーのプロフィールページに成功したログイン後にリダイレクトしてFlask-Securityに登録するには?そして、エラー

を言うと、登録した後、私はこのエラーを持っている

AttributeError: 'NoneType' object has no attribute 'send'

Traceback (most recent call last): 

    File "/usr/lib/python2.7/threading.py", line 801, in __bootstrap_inner 

    File "/usr/lib/python2.7/threading.py", line 754, in run 

    File "/home/maharshi/.local/lib/python2.7/site-packages/werkzeug/serving.py", line 659, in inner 

    File "/home/maharshi/.local/lib/python2.7/site-packages/werkzeug/serving.py", line 499, in serve_forever 

    File "/usr/lib/python2.7/SocketServer.py", line 236, in serve_forever 

    File "/usr/lib/python2.7/threading.py", line 585, in set 

    File "/usr/lib/python2.7/threading.py", line 407, in notifyAll 

<type 'exceptions.TypeError'>: 'NoneType' object is not callable 

データが登録されますが、このエラーはまだ発生しています。

from flask import Flask 
from flask_sqlalchemy import SQLAlchemy 
from flask import render_template 
from flask import request, redirect, url_for 
from flask_security import Security, SQLAlchemyUserDatastore, UserMixin, RoleMixin, login_required 
import datetime 


#Create app 
app= Flask(__name__) 
app.config['DEBUG']= True 
app.config['SQLALCHEMY_DATABASE_URI']= 'postgresql://postgres:[email protected]/pdb1' 
app.config['SECRET_KEY']= 'MaharshI' 
app.config['SECURITY_REGISTERABLE'] = True 

#Create database connection object 
db= SQLAlchemy(app) 

#Define models 
roles_users= db.Table('roles_users', db.Column('user_id', db.Integer(), db.ForeignKey('user.id')), 
    db.Column('role_id', db.Integer(), db.ForeignKey('role.id'))) 

class Role(db.Model, RoleMixin): 
    id= db.Column(db.Integer(), primary_key=True) 
    name= db.Column(db.String(80), unique=True) 
    description= db.Column(db.String(225)) 

class User(db.Model, UserMixin): 
    id = db.Column(db.Integer, primary_key=True) 
    email = db.Column(db.String(255), unique=True) 
    password = db.Column(db.String(255)) 
    active = db.Column(db.Boolean()) 
    confirmed_at = db.Column(db.DateTime()) 
    roles= db.relationship('Role', secondary=roles_users, backref=db.backref('user',lazy='dynamic')) 

#setup Flask-Security 
user_datastore= SQLAlchemyUserDatastore(db, User, Role) 
security= Security(app, user_datastore) 

# @app.before_first_request 
# def create_user(): 
# user_datastore.create_user(email='[email protected]', password='pass') 
# db.session.commit() 

@app.route('/') 
def home(): 
    return render_template('home.html') 

@app.route('/profile/<email>') 
@login_required 
def profile(email): 
    user= User.query.filter_by(email=email).first() 
    return render_template('profile.html', user=user) 

# SECURITY_POST_LOGIN_VIEW= 'snd.html' 


# @app.route('/login_form') 
# def login_form(): 
# SECURITY_POST_LOGIN_VIEW= '/templates/snd.html' 
# return render_template(url_for(SECURITY_POST_LOGIN_VIEW)) 

# @app.route('/post_user', methods=['POST']) 
# def post_user(): 
# user=User(request.form['email'], request.form['password']) 
# db.session.add(user) 
# db.session.commit() 
# return redirect(url_for('home')) 


if __name__ == "__main__": 
    app.run(host='0.0.0.0') 
+0

@ security.login_context_processor デフsecurity_login_processor():()SECURITY_POST_LOGIN_VIEW(なurl_for) \t SECURITY_POST_LOGIN_VIEW = '/templates/snd.html' \t戻りrender_templateは、この近くに#IS ??? – maharshi

+0

最後のエラーメッセージだけでなく、エラートレースバック全体を送信します。 –

+0

@JohnGordonどうぞご覧ください... – maharshi

答えて

0

は、私はエラーがその他設定「SECURITY_SEND_REGISTER_EMAIL」成功の登録に登録メールを送信しようとするあなたのアプリを引き起こしデフォルトはtrue、結果としてあると思います。フラスコメールをアプリケーションインスタンスで初期化していない場合は、この例外が発生します。

AttributeError: 'NoneType' object has no attribute 'send'

SECURITY_SEND_REGISTER_EMAIL = False」を設定するとこの問題が解決されます。

関連する問題