cari

Rumah  >  Soal Jawab  >  teks badan

Isu interaksi hadapan dan belakang kelalang Python

Saya mahu id di bawah sama dengan user.id di atas tetapi saya tidak tahu bagaimana untuk mendapatkan nilai ini

阿神阿神2798 hari yang lalu984

membalas semua(3)saya akan balas

  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-18 11:00:21

    Terima kasih atas jemputan. Hanya gunakan parameter fungsi paparan secara langsung.

    http://flask.pocoo.org/docs/0...

    balas
    0
  • 迷茫

    迷茫2017-05-18 11:00:21

    Terima kasih atas jemputan Berikut ialah idea, menggunakan flask_wtf untuk interaksi bentuk hadapan dan belakang Untuk bermula, lihat
    http://flask123.sinaapp.com/. a...flask_wtf来进行前后端表单交互,入门可以看
    http://flask123.sinaapp.com/a...

    这里举一个简单的登陆例子:
    首先要在后端构造表单,在forms.py中进行定义:

    from flask_wtf import Form
    from wtforms import StringField, PasswordField, BooleanField, SubmitField
    from wtforms.validators import Required, Length, Email, Regexp, EqualTo
    
    #自定义的表单都要继承于flask_wtf中的Form表单
    class LoginForm(Form):
        email = StringField('登陆邮箱', validators=[Required(), Length(1, 64),
                                                Email()])
        password = PasswordField('密码', validators=[Required()])
        remember_me = BooleanField('记住我')
        submit = SubmitField('登陆')

    那么如何把这个表单放到网页上呢?我们先来看login.html吧:

    {% extends "base.html" %}
    <!-- 注意这里要导入bootstrap/wtf.html -->
    {% import "bootstrap/wtf.html" as wtf %}
    {% set active_page = "login" %}
    {% block title %}登陆{% endblock %}
    
    {% block page_content %}
    <p class="container">
        <p class="page-header" style="margin-top: 120px;">
            <h1 class="white">登陆</h1>
        </p>
        <p class="col-md-4" >
        
            <!-- 这里使用wtf.quick_form即可创建表单,那么form哪里来呢?看下面 -->
            {{ wtf.quick_form(form) }}
            
            <br>
            <p>忘记密码? <a href="{{ url_for('auth.password_reset_request') }}">重置密码。</a></p>
            <p>没有账号? <a href="{{ url_for('auth.register') }}">注册。</a></p>
        </p>
    </p>
    {% endblock %}

    那么login.html中的form是哪里来的呢?让我们来看路由views.py

    Berikut ialah contoh log masuk mudah:
    Mula-mula, bina borang di bahagian belakang dan takrifkannya dalam forms.py:

    from flask import render_template, redirect, request, url_for, flash
    from .forms import LoginForm
    from ..models import User
    
    @auth.route('/login', methods=['GET', 'POST'])
    def login():
        #从forms.py中导入刚刚建好的 LoginForm()
        form = LoginForm()
        #【你要的答案在这里,当用户提交表单后会执行下列语句】
        if form.validate_on_submit():
            #用form.xxx.data即可获取数据,这里使用了form.email.data获取了用户输入的email进行查询
            user = User.query.filter_by(email=form.email.data).first()
            #如果查询到用户并且密码正确的话
            if user is not None and user.verify_password(form.password.data):
                #登陆用户,并重定向到之前的页面或主页
                login_user(user, form.remember_me.data)
                return redirect(request.args.get('next') or url_for('main.index'))
            #否则提示用户用户名不对或密码不对
            flash('Invalid username or password.')
        #!!!这里要注意,第一次用户开进这个登陆界面的时候是直接执行下面这条语句的,要注意把form传入,jinja2才可以对表单进行渲染。
        return render_template('auth/login.html', form=form)

    Jadi bagaimana untuk meletakkan borang ini di halaman web? Mari lihat login.html dahulu: 🎜 rrreee 🎜Jadi dari manakah borang dalam login.html berasal? Mari lihat penghalaan views.py🎜 rrreee 🎜Ia juga adalah kandungan buku "Flask Web Development: Practical Web Application Development Based on Python" Saya menyemaknya semula hari ini~Haha, jadi jika anda ingin belajar Flask, saya syorkan membaca buku ini~ Ada soalan? teruskan bertanya, terima kasih~~🎜

    balas
    0
  • phpcn_u1582

    phpcn_u15822017-05-18 11:00:21

    Gunakan konteks permintaan

    from flask import request
    
    # ...
    
    user = User.query.filter_by(User.id==request.args.get('id', 0))

    balas
    0
  • Batalbalas