python接收表单_python_Django 实现登入功能form表单的参数接收处理

1.创建Django工程。

参考https://www.cnblogs.com/CK85/p/10159159.html中步骤。

2.在urls.py文件中添加url分发路径

"""Django_test URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:

https://docs.djangoproject.com/en/2.1/topics/http/urls/

Examples:

Function views

1. Add an import: from my_app import views

2. Add a URL to urlpatterns: path('', views.home, name='home')

Class-based views

1. Add an import: from other_app.views import Home

2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')

Including another URLconf

1. Import the include() function: from django.urls import include, path

2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))

"""

from django.contrib import admin

from django.urls import path

from app01 import views

urlpatterns = [

path('admin/', admin.site.urls),

path('login/', views.login, name='login'),

path('authentication/', views.authentication, name='authentication'),

]

路径分发时编辑name可以为路径取一个别名,在html文件中通过别名进行访问,避免过多的命名的改变。

3.在view.py中添加两个界面的试图函数。

from django.shortcuts import render, HttpResponse

import time

# Create your views here.

def login(request):

return render(request, 'login.html', locals())

def authentication(request):

# print(request.method)

user_name = request.GET.get('user')

pwd = request.GET.get('pwd')

user_dic = {

'ck': '123',

'ck1': '123',

'ck2': '123',

}

if user_name in user_dic:

if user_dic[user_name] == pwd:

print('authentication passed')

user = user_name

output = render(request, 'well_come.html', {'username': user})

else:

print('incorrect username or password')

output = HttpResponse('

incorrect username or password

')

else:

print('不在')

output = HttpResponse('

the user dose not exist

')

return output

login视图函数在用户访问时将login.html发送给用户。

authentication进行用户登入信息的验证和处理。

HttpResponse返回一个http响应。

4.在templates文件夹中创建对应的html文件:

login.html:

Title

登入

手机号:

密码:

{% csrf_token %}

login界面是用户在登入时看到的界面,需要用户在该页面中输入账号和密码。

其中使用form表单进行读取数据,action=“/authentication/”与action=“{% url "authentiction" %}”相同,前者使用路径访问,后者使用别名访问。

在form表单中input标签type=’text‘ 和type=’submit‘组合使用,使得在用户点击提交按钮时使用form表单method中传入的方法将两个text中的值与text的name组成键值对传给在form表单action路径的文件。

well_come.html:

Title

你好! {{ username }}

well_come界面为用户成功登入之后的欢迎界面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简的Django处理示例: 1. 定义类 ```python from django import forms class ContactForm(forms.Form): name = forms.CharField(max_length=100) email = forms.EmailField() message = forms.CharField(widget=forms.Textarea) ``` 2. 创建视图函数 ```python from django.shortcuts import render from .forms import ContactForm def contact(request): if request.method == 'POST': form = ContactForm(request.POST) if form.is_valid(): name = form.cleaned_data['name'] email = form.cleaned_data['email'] message = form.cleaned_data['message'] # 处理数据 else: form = ContactForm() return render(request, 'contact.html', {'form': form}) ``` 3. 创建模板 ```html {% extends 'base.html' %} {% block content %} <h1>Contact Us</h1> <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">Send</button> </form> {% endblock %} ``` 在视图函数中,我们首先检查请求的方法是否为POST。如果是,则创建一个对象,并使用数据验证其有效性。如果数据有效,则从对象中提取数据并处理它们。否则,我们将使用无效对象呈现模板。 在模板中,我们使用Django中的模板标记和过滤器来呈现。我们使用`form.as_p`过滤器将渲染为HTML段落。我们还使用`{% csrf_token %}`标记为添加CSRF令牌,以确保在提交时不受到跨站点请求伪造攻击的影响。最后,我们在上添加一个提交按钮。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值