Maison > développement back-end > Tutoriel Python > Exemple détaillé de développement de la fonction d'enregistrement des utilisateurs (python)

Exemple détaillé de développement de la fonction d'enregistrement des utilisateurs (python)

Y2J
Libérer: 2017-04-26 11:13:38
original
2305 Les gens l'ont consulté

La naissance d'une application Web basée sur Flask est le cinquième article. Cet article présente principalement le développement de la fonction d'enregistrement des utilisateurs, qui a une certaine valeur de référence. Les amis intéressés peuvent s'y référer

Les rôles sont divisés. ci-dessous Il existe deux types, les utilisateurs ordinaires et les utilisateurs administrateurs. Au moins pour les utilisateurs ordinaires, il n'est pas conseillé de modifier directement la base de données. Une fonction d'enregistrement des utilisateurs est requise. Le développement de l'enregistrement des utilisateurs commencera ci-dessous.

Tableau des utilisateurs

Tout d'abord, réfléchissez aux informations que les utilisateurs doivent fournir lors de leur inscription : nom d'utilisateur, mot de passe, pseudo, email, date de naissance, sexe , self Introduction, modifions le modèle utilisateur en fonction de ces informations :

class User(db.Model):
 __tablename__="users"
 id=db.Column(db.Integer,primary_key=True)
 username=db.Column(db.String(50),unique=True,index=True)
 password=db.Column(db.String(50))
 nickname=db.Column(db.String(50))
 email=db.Column(db.String(100))
 birthday=db.Column(db.DateTime)
 gender=db.Column(db.Integer)
 remark=db.Column(db.String(200))
 role_id=db.Column(db.Integer,db.ForeignKey("roles.id"))
Copier après la connexion

Utilisez ensuite le script pour modifier db

python default.py db migrate -m "修改用户表"
Copier après la connexion

Après avoir appuyé sur Entrée, l'interface affiche le contenu :

Ensuite, modifiez la différence dans la base de données

python default.py db upgrade
Copier après la connexion

À ce stade, regardez la structure de la table dans la base de données :

a été modifié avec succès

Interface d'inscription

Créez ensuite un nouveau modèle register.html et définissez le formulaire de connexion :

{% extends "base.html"%}
{% block content %} <!--具体内容-->
<p class="container">
 <p class="row"></p>
 <p class="row">

  <p>
   <p class="page-header">
    <h1>欢迎您注册</h1>
   </p>
   {% for message in get_flashed_messages() %}
   <p class="alert alert-warning">
    <button type="button" class="close" data-dismiss="alter">&times</button>
    {{message}}
   </p>
   {% endfor %}
   <form method="post">
    <p class="form-group">
    <label for="username">用户名</label>
    <input type="text" class="form-control" name="username" id="username" placeholder="请输入用户名">
    </p>
    <p class="form-group">
    <label for="passworld">密码</label>
    <input type="password" class="form-control" name="password" id="passworld" placeholder="请输入密码">
    </p>
    <p class="form-group">
    <label for="email">昵称</label>
    <input type="email" class="form-control" name="nickname" id="nickname" placeholder="请输入昵称">
    </p>
    <p class="form-group">
    <label for="birthday">生日</label>
    <input type="date" class="form-control" name="birthday" id="birthday" placeholder="请输入生日">
    </p>
    <p class="form-group">
    <label >性别</label>
    <label class="form-control">
     <input type="radio" name="gender" value="0" id="gender0"><label for="gender0">男</label>
     <input type="radio" name="gender" value="1" id="gender1"><label for="gender1">女</label>
    </label>
    </p>
    <p class="form-group">
    <label for="email">电子邮箱</label>
    <input type="email" class="form-control" name="email" id="email" placeholder="请输入电子邮箱">
    </p>
    <button type="submit" class="btn btn-default">登录</button>
   </form>
  </p>
 </p>
</p>
{% endblock %}
Copier après la connexion

Créez ensuite un nouveau dans le fichier default.py Ajoutez une route de registre, le code est :

@app.route("/register",methods=["GET"])
def register():
 return render_template("/register.html")
Copier après la connexion

L'interface en cours d'exécution est normale, puis ajoutez une route de publication :

@app.route("/register",methods=["Post"])
def registerPost():
 user=User();
 user.username=request.form.get("username","")
 user.password = request.form.get("password", "")
 user.birthday = request.form.get("birthday", "")
 user.email = request.form.get("email", "")
 user.gender = request.form.get("gender", "")
 user.nickname = request.form.get("nickname", "")
 user.role_id = 1 #暂时约定公开用户角色为1

 #判断,其中用户名,密码,昵称不能为空
 if(len(user.username.strip())==0):
  flash("用户名不能为空")
  return render_template("/register.html")
 if(len(user.password.strip())==0):
  flash("用户密码不能为空")
  return render_template("/register.html")
 if (len(user.nickname.strip()) == 0):
  flash("用户昵称不能为空")
  return render_template("/register.html")
 db.session.add(user);
 flash("您已注册成功")
 return render_template("/register.html")
Copier après la connexion

Le code est un peu verbeux et pas beau, mais l'intention de base peut être exprimée clairement et la fonction est bonne. Il peut être implémenté, mais vient maintenant le problème. Si j'ajoute un nouveau champ, alors trois codes. doivent être modifiés (html, form.get, vérification), et surtout le html doit être modifié, et la partie html n'est pas vérifiée. Si vous ajoutez un client Pour une vérification de bout en bout, des modifications supplémentaires seront nécessaires. Alors, existe-t-il un outil pour optimiser les formulaires ? La réponse est bien sûr, c’est au tour de wtf.

Présentation du framework de formulaire WTF

Comme auparavant, vous devez d'abord installer le plug-in.

pip3.6 install flask-wtf
Copier après la connexion

Puis introduisez les packages requis

from flask.ext.wtf import Form
from wtforms import StringField,PasswordField,SubmitField,RadioField
from wtforms.validators import DataRequired,EqualTo,Length
Copier après la connexion

Créez un formulaire RegisterForm ci-dessous :

class RegisterForm(Form):
 username = StringField("请输入用户名", validators=[DataRequired()])
 password = PasswordField("请输入密码", validators=[DataRequired()])
 repassword=PasswordField("确认密码", validators=[EqualTo("password")])
 nickname= StringField("昵称")
 birthday= DateField("出生日期")
 email= StringField("邮箱地址", validators=[Email()])
 gender= RadioField("性别", choices=[("0", "男"), ("1", "女")], default=0)
 remark= TextAreaField("自我简介")
 submit=SubmitField("提交")
Copier après la connexion

Modifiez le modèle register.html :

{% extends "base.html"%}
{% block content %} <!--具体内容-->
{% import "bootstrap/wtf.html" as wtf %} <!--导入bootstrap模板 -->
<p class="container">
 <p class="row"></p>
 <p class="row">

  <p>
   <p class="page-header">
    <h1>欢迎您注册</h1>
   </p>
   {% for message in get_flashed_messages() %}
   <p class="alert alert-warning">
    <button type="button" class="close" data-dismiss="alter">&times</button>
    {{message}}
   </p>
   {% endfor %}
   {{ wtf.quick_form(form)}} <!--创建表单-->
  </p>
 </p>
</p>
{% endblock %}
Copier après la connexion

Exécution, résultat de sortie :

Oh, une erreur a été signalée, voyez quelle erreur est la sortie :

Faites attention à la ligne rouge, il s'agit d'une erreur CSRF. Le concept de CSRF peut être directement lié à Baidu, il est en fait facile de le modifier. L'ajout d'une clé secrète au framework peut efficacement l'empêcher. Ajoutez-le. Ajoutez une ligne à default.py :

app.config[&#39;SECRET_KEY&#39;] = "Niu_blog String"
Copier après la connexion

La chaîne de clé secrète peut être personnalisée

Ensuite, exécutez-la à nouveau, l'interface apparaîtra :

et contient le style de vérification pour vérifier le bootstrap. Ensuite, continuez à modifier default.py pour terminer cette fonction d'enregistrement

@app.route("/register",methods=["GET","POST"])
def register():
 form=RegisterForm()
 if form.validate_on_submit():
  user=User()
  user.username=form.username.data
  user.password=form.password.data
  user.birthday=form.birthday.data
  user.email=form.email.data
  user.gender=form.gender.data
  user.nickname=form.nickname.data
  user.role_id=1   #暂时约定公开用户角色为1
  db.session.add(user)
 return render_template("/register.html",form=form)
Copier après la connexion

Notez que le La méthode registerPost a été supprimée pour le moment

pour faciliter l'exécution des tests. Cliquez sur

pour soumettre :

Ao, pourquoi le format de date est-il incorrect ? Vous devez lire ceci à partir du code source :

class DateField(DateTimeField):
 """
 Same as DateTimeField, except stores a `datetime.date`.
 """
 def __init__(self, label=None, validators=None, format=&#39;%Y-%m-%d&#39;, **kwargs):
  super(DateField, self).__init__(label, validators, format, **kwargs)

 def process_formdata(self, valuelist):
  if valuelist:
   date_str = &#39; &#39;.join(valuelist)
   try:
    self.data = datetime.datetime.strptime(date_str, self.format).date()
   except ValueError:
    self.data = None
    raise ValueError(self.gettext(&#39;Not a valid date value&#39;))
Copier après la connexion

Ceci est le code source du champ wtforms, situé à la ligne 745 de /wtforms/fields/core.py. Vous pouvez voir que le format de date est pris en charge. voici l'année - Le format mois-jour est plutôt restrictif et la zone de texte n'utilise pas de date HTML5 mais du texte ordinaire. La solution sera discutée plus tard. Pour l'instant, modifiez l'entrée en 1988-2-5, puis cliquez sur Soumettre. :


Notez qu'une fois le code soumis avec succès, il revient toujours à cette page et injecte du contenu, il n'y a donc aucun problème d'affichage. à la base de données :

L'enregistrement entre normalement dans la base de données et la fonction est terminée.

Améliorez la page de connexion

Transformons la page de connexion, créons d'abord le formulaire de connexion :

class LoginForm(Form):
 username=StringField("请输入用户名",validators=[DataRequired()])
 password=PasswordField("请输入密码")
 submit=SubmitField("登录")
Copier après la connexion

Modifiez le modèle de connexion page :

{% extends "base.html"%}
{% import "bootstrap/wtf.html" as wtf %}
{% block content %} <!--具体内容-->
<p class="container">
 <p class="row"></p>
 <p class="row">

  <p class="col-md-4 col-md-offset-4 col-sm-6 col-sm-offset-3">
   <p class="page-header">
    <h1>欢迎您登陆</h1>
   </p>
   {% for message in get_flashed_messages() %}
   <p class="alert alert-warning">
    <button type="button" class="close" data-dismiss="alter">&times</button>
    {{message}}
   </p>
   {% endfor %}
   {{ wtf.quick_form(form)}}
  </p>
 </p>
</p>
{% endblock %}
Copier après la connexion

Modifier la méthode de routage :

@app.route("/login",methods=["GET","POST"])
def login():
 form=LoginForm()
 if form.validate_on_submit():
  username = form.username.data
  password = form.password.data
  user = User.query.filter_by(username=username, password=password).first()
  if user is not None:
   session["user"] = username
   return render_template("/index.html", name=username, site_name=&#39;myblog&#39;)
  else:
   flash("您输入的用户名或密码错误")
   return render_template("/login.html",form=form) # 返回的仍为登录页
 return render_template("/login.html",form=form)
Copier après la connexion

Redémarrez le service, exécutez le programme, saisissez zhangji et 123 et connectez-vous avec succès à la page d'accueil

Retour à la page d'accueil

La page d'accueil est désormais une vaste étendue blanche sans contenu. Un blog léger normal devrait afficher le bouton de publication, les articles suivis, etc. après la connexion. , mais le statut de connexion doit être enregistré en premier, ce qui sera discuté dans la description du prochain chapitre.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal