django2与ajax,Python-Django-Ajax进阶2

-forms组件的渲染错误信息

在模板中:{{ foo.errors.0 }}

6c78d2cbf60c678b2eb3d95780c6d545.png

0e69fa654dbcea84ce0e63d65071eeb5.png

771fb5cad78e1b2345527a203e0a8430.png

f4416ddbff231c051b86df7ed7604852.png

6fd44060be863f047c0b9f7d08d91167.png

-forms使用bootstrap样式

widget=widgets.EmailInput(attrs={'class':'form-control'}))

f6655f0189ba1c760aeb20d4b89dfab5.png

-全局和局部钩子函数

AOP:面向切面编程

-局部钩子函数(再校验name)

def clean_name(self):

# 从cleaned_data中取出字段的值

name = self.cleaned_data.get('name')

# # 校验是否以sb开头

if name.startswith('sb'):

raise ValidationError('不能以sb开头')

else:

return name

-全局钩子函数

def clean(self):

pwd=self.cleaned_data.get('pwd')

re_pwd=self.cleaned_data.get('re_pwd')

if pwd==re_pwd:

# 正确,返回self.cleaned_data

return self.cleaned_data

else:

# 校验失败,抛异常

raise ValidationError('两次密码不一致')

cookie,session,token

cookie

-cookie是存在浏览器上的键值对{'name':'lqz','password':123}

-服务器写到浏览器上的

session:

-因为cookie不安全,所有出了session

-存在于服务器上的键值对 'sfdasdfa':{'name':'lqz','password':123}

token:(待研究)

cookie的使用:

设置cookie:

-HttpResponse的对象 obj.set_cookie(key,value,超时时间)

-obj.set_signed_cookie('name','egon',salt='123')

取cookie:

-request.COOKIES.get(key)

-name=request.get_signed_cookie('name',salt='123')

删除:

HttpResponse的对象 obj.delete_cookie('is_login')

3b11ed8d455c948ac9bfbb85b30e9cfa.png

59f543b4203f4605093145d30130399d.png

session的使用:

设置

-request.session['name']=‘lqz’

-request.session['age']=‘18’

取cookie:

-request.session.get('name')

删除:

-request.session.delete() 只删数据库

-request.session.flush() 浏览器cookie和数据库

了解:其他参数(超时时间)

efd1fd6ebfc6081d370d7f1765a02087.png

7ec7189f3b95cde586389bb8a37cc855.png

cf6cba8fa764a9d98206e41b853c8607.png

auth组件

Auth模块是Django自带的用户认证模块:

我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统。此时我们需要实现包括用户注册、用户登录、用户认证、注销、修改密码等功能,这还真是个麻烦的事情呢。

Django作为一个完美主义者的终极框架,当然也会想到用户的这些痛点。它内置了强大的用户认证系统--auth,它默认使用 auth_user 表来存储用户数据。

6c4f28e7a8229d5ef79c0be40b12a2b2.png

扩展默认的auth_user表

from django.contrib.auth.models import AbstractUser

class UserInfo(AbstractUser):

"""

用户信息表

"""

nid = models.AutoField(primary_key=True)

phone = models.CharField(max_length=11, null=True, unique=True)

def __str__(self):

return self.username

注意:

按上面的方式扩展了内置的auth_user表之后,一定要在settings.py中告诉Django,我现在使用我新定义的UserInfo表来做用户认证。写法如下:

# 引用Django自带的User表,继承使用时需要设置

AUTH_USER_MODEL = "app名.UserInfo"

再次注意:

一旦我们指定了新的认证系统所使用的表,我们就需要重新在数据库中创建该表,而不能继续使用原来默认的auth_user表了。

ContentTypefrom django.db import models

from django.contrib.contenttypes.models import ContentType

from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation

class Course(models.Model):

title = models.CharField(max_length=32)

# 不会在数据库中生成字段,只用于数据库操作

policy = GenericRelation('PricePolicy',object_id_field='object_id',content_type_field='contentType')

class DegreeCourse(models.Model):

title = models.CharField(max_length=32)

class PricePolicy(models.Model):

# 跟ContentType表做外键关联

contentType = models.ForeignKey(to=ContentType)

# 正数

object_id = models.PositiveIntegerField()

# 引入一个字段,不会在数据库中创建,只用来做数据库操作

content_obj = GenericForeignKey('contentType', 'object_id')

period = models.CharField(max_length=32)

price = models.FloatField()

TTL:

85608753445b6ca177dbbf39e0cc2113.png

e809af5dd239ed063132b7c1b2480416.png

4a993de4d34e7b0c12edcfd0630b9a1c.png

af68059f8a5b39270db8403ca027773a.png

python django -5 进阶

高级知识点包括: 静态文件处理 中间件 上传图片 Admin站点 分页 使用jquery完成ajax 管理静态文件 项目中的CSS.图片.js都是静态文件 配置静态文件 在settings 文件中定义 ...

Python - Django - AJAX 实现 POST 请求

index.html: +

Python Django Ajax 传递列表数据

function getTableContent(node) { event.preventDefault(); var tr = node.parentNode.parentNode; var id ...

python Django Ajax基础

升级版: ajax 创建多对多以及增加示例: views中的接收

Python之路【第十七篇】:Django【进阶篇 】

Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

Python之路【第十七篇】:Django【进阶篇】

Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

Python开发【第二十二篇】:Web框架之Django【进阶】

Python开发[第二十二篇]:Web框架之Django[进阶]   猛击这里:http://www.cnblogs.com/wupeiqi/articles/5246483.html 博客园 首页 ...

Python之路,Day15 - Django适当进阶篇

Python之路,Day15 - Django适当进阶篇   本节内容 学员管理系统练习 Django ORM操作进阶 用户认证 Django练习小项目:学员管理系统设计开发 带着项目需求学习是最有趣 ...

python Django之Ajax

python Django之Ajax AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案. 异步 ...

python学习-- Django Ajax CSRF 认证

使用 jQuery 的 ajax 或者 post 之前 加入这个 js 代码:http://www.ziqiangxuetang.com/media/django/csrf.js /*======== ...

随机推荐

jsonp 实例

一直以为很复杂吧?其实很简单,简单到你不敢相信 1.前端引好jquery文件 2.前端代码: $.ajax({       url: 'http://www.xxxxxxxx.com/expand.a ...

Effective C++ -----条款07:为多态基类声明virtual析构函数

polymorphic(带多态性质的)base classes应该声明一个virtual析构函数.如果class带有任何virtual函数,它就应该拥有一个virtual析构函数. Classes的设 ...

转:关于视频H264编解码的应用实现

转:http://blog.csdn.net/scalerzhangjie/article/details/8273410 项目要用到视频编解码,最近半个月都在搞,说实话真是走了很多弯路,浪费了很多时 ...

基于AngularJS/Ionic框架开发的性能优化

AngularJS作为强大的前端MVVM框架,虽然已经做了很多的性能优化,但是我们开发过程中的不当使用还是会对性能产生巨大影响. 下面提出几点优化的方法: 1. 使用单次绑定符号{{::value}} ...

Mac 下显示隐藏文件

将下面的命令粘贴进终端,按提示操作即可(可能需要输入电脑密码) 显示:defaults write com.apple.finder AppleShowAllFiles -bool true 隐藏:d ...

linux下实现redis共享session的tomcat集群

为了实现主域名与子域名的下不同的产品间一次登录,到处访问的效果,因此采用rediss实现tomcat的集群效果.基于redis能够异步讲缓存内容固化到磁盘上,从而当服务器意外重启后,仍然能够让sess ...

10055 - Hashmat the Brave Warrior

Problem A Hashmat the brave warrior Input: standard input Output: standard output Hashmat is a brave ...

hibernate-部分字段查询方案

hibernate的延迟加载与本列记录不一样,延迟加载正常一般用于关联字段,或者大型字段使用. 本列的情况主要用于,某一张表有几十甚至上百个字段,例如财务报表等.但是在使用某些场景是却大多只是用其10 ...

.NET 实现DES加密解密处理

.NET 实现DES加密解密处理 using System; using System.Text; using System.Security.Cryptography; using System.I ...

技术文档分享_linux中生成考核用的GPT分区表结构修复

注:历史版本,后期改用python实现了 实验一: 目的:用于生成大量模拟破坏GPT分区结构案例,并生成唯一方式修复后的评判方法.故障:在一个完整的GPT分区磁盘上,丢失了GPT主分区表,或备份分区表 ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些指导。 首先,您需要使用 Django 框架来搭建您的网站。您可以先安装 Django,然后创建一个新的 Django 项目。 接着,您可以创建一个注册和登录的应用。在这个应用中,您可以创建一个名为 `views.py` 的文件,用于处理用户注册和登录的请求。您可以使用 Django 自带的表单验证来验证用户输入的信息是否正确。 在用户注册时,您需要从前端页面获取用户输入的信息,并将其保存到数据库中。在用户登录时,您需要从前端获取用户输入的用户名和密码,并将其与数据库中的信息进行验证。 对于登录和注册,您可以使用 ajax 技术,从前端向后端发送异步请求来进行处理。在 `views.py` 中,您可以使用 Django 的 `JsonResponse` 对象来返回处理结果。 下面是一个简单的示例代码: ```python from django.shortcuts import render from django.http import JsonResponse from django.contrib.auth import authenticate, login, logout from django.contrib.auth.models import User def register(request): # 获取用户输入的信息 username = request.POST.get('username') password = request.POST.get('password') email = request.POST.get('email') # 创建新用户并保存到数据库中 user = User.objects.create_user(username=username, password=password, email=email) user.save() # 返回处理结果 return JsonResponse({'status': 'success'}) def login(request): # 获取用户输入的信息 username = request.POST.get('username') password = request.POST.get('password') # 验证用户名和密码是否正确 user = authenticate(request, username=username, password=password) if user is not None: # 登录成功 login(request, user) return JsonResponse({'status': 'success'}) else: # 登录失败 return JsonResponse({'status': 'fail'}) ``` 在前端页面中,您可以使用 jQuery 来向后端发送异步请求,并处理返回的结果。 下面是一个简单的示例代码: ```html <form id="register-form"> <input type="text" name="username"> <input type="password" name="password"> <input type="email" name="email"> <button type="submit">注册</button> </form> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> <script> $(document).ready(function() { $('#register-form').submit(function(event) { event.preventDefault(); var form_data = $(this).serialize(); $.ajax({ url: '/register/', type: 'POST', data: form_data, dataType: 'json', success: function(data) { if (data.status === 'success') { alert('注册成功'); } else { alert('注册失败'); } } }); }); }); </script> ``` 类似地,您可以创建一个登录的表单,并使用类似的方式进行处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值