第二十一章 Django的分页与cookie

第一课 模板

1.模板的继承

在Template目录下新建模板master.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>{% block title %}{% endblock %}</title>

<link rel="stylesheet" href="/static/commons.css">

<style>

.pg-header{

height:48px;

background-color: cornflowerblue;

color: red;

}

</style>

{% block css %}{% endblock %}

</head>

<body>

<div class="pg-header">小男孩管理</div>

{% block content %}{% endblock %}

<script src="/static/jquery.js"></script>

{% block js %}{% endblock %}

</body>

</html>

新建tpl1.html

{% extends 'master.html' %}

{% block title %}用户管理{% endblock %}

{% block content %}

<h1>用户管理</h1>

<ul>

{% for i in u %}

<li>{{ i }}</li>

{% endfor %}

</ul>

{% endblock %}

{% block css %}

<style>

body{

background-color: red;

}

</style>

{% endblock %}

2.模板的导入

新建tag.html

<form>

<input type="text" name="" id="1">

<input type="submit" value="sub">

</form>

在tpl1.html中:

{% include 'tag.html' %}

第二课 自定义函数

1.simple_tag:

1.app下创建templatetags目录

2.任意xxoo.py文件

3.from django import template 创建template对象 register=template.Library()

4.@register.simple_tag

def func(arg1,arg2...):

return 'aagagnaads...'

5.settings中注册app

6.html文件顶部{% load xxoo %}

7.{% 函数名 arg1 arg2 %}

缺点:不能作为if条件

优点:参数任意

2.filter:

1.app下创建templatetags目录

2.任意xxoo.py文件

3.from django import template 创建template对象 register=template.Library()

4.@register.simple_tag

def func(arg1,arg2): #参数只能是两个!

return 'aagagnaads...'

5.settings中注册app

6.html文件顶部{% load xxoo %}

7.{{参数1|函数名:参数2}}

缺点:参数限制 引用时不能加空格

优点:能作为if条件

第三课 分页

1.防止xss攻击(默认不执行包含代码的字符串):

1.在前端:{{ page_str|safe}}

2.在后端:

from django.utils.safestring import mark_safe

page_str01 = """..."""

page_str01=mark_safe(page_str01)

2.(使用分页模块)

第四课 cookie和装饰器

cookie是客户端浏览器上的一个文件键值对{'k1':'v1',....}

示例1:

urls.py中添加路径:

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

path('index/',views.index),

templates中新建登录页面login.html和主页index.html

login.html代码:

<form action="/login/" method="post">

用户名:<input type="text" name="username">

密码:<input type="password" name="pwd">

<input type="submit" value="提交">

</form>

index.html代码:

<h1>欢迎登陆:{{ k }}</h1>

views.py中代码:

user_info={

'xiaoming':'123',

'xiaohong':'321',

}

def login(req):

if req.method=='GET':

return render(req,'login.html')

if req.method=='POST':

u=req.POST.get('username')

v=req.POST.get('pwd')

if u in user_info:

if user_info[u]==v:

res=redirect('/index/')

res.set_cookie('username111',u,max_age=5)

#5代表5秒钟后清除cookie,不填则关闭浏览器清除cookie

return res

else:

return render(req,'login.html')

def index(req):

v=req.COOKIES.get('username111')

if not v:

return redirect('/login/')

else:

return render(req,'index.html', {'k': v})

cookie加密(浏览器自动给解密了,没毛用):

获取cookie:

req.COOKIES.get('...')

u=req.get_signed_cookie('pwd',salt='abcd')

设置cookie:

req.set_cookie('...')

res.set_signed_cookie('pwd',v,salt='abcd')

装饰器:

def auth(func):

def inner(req,*args,**kwargs):

v=req.COOKIES.get('username111')

if not v:

return redirect('/login/')

return func(req,*args,**kwargs)

return inner

@auth

def index(req):

v = req.COOKIES.get('username111')

return render(req,'index.html', {'k': v})

第二十一章 Django的分页与cookie第一课 模板1.模板的继承在Template目录下新建模板master.html<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>{% block title %}{% endblock %}</title><link rel="stylesheet" href="/static/commons.css"><style>.pg-header{height:48px;background-color: cornflowerblue;color: red;}</style>{% block css %}{% endblock %}</head><body><div class="pg-header">小男孩管理</div>{% block content %}{% endblock %}<script src="/static/jquery.js"></script>{% block js %}{% endblock %}</body></html>新建tpl1.html{% extends 'master.html' %}{% block title %}用户管理{% endblock %}{% block content %}<h1>用户管理</h1><ul>{% for i in u %}<li>{{ i }}</li>{% endfor %}</ul>{% endblock %}{% block css %}<style>body{background-color: red;}</style>{% endblock %}2.模板的导入新建tag.html<form><input type="text" name="" id="1"><input type="submit" value="sub"></form>在tpl1.html中:{% include 'tag.html' %}第二课 自定义函数1.simple_tag:1.app下创建templatetags目录2.任意xxoo.py文件3.from django import template 创建template对象 register=template.Library()4.@register.simple_tag   def func(arg1,arg2...):return 'aagagnaads...'5.settings中注册app6.html文件顶部{% load xxoo %}7.{% 函数名 arg1 arg2 %}缺点:不能作为if条件优点:参数任意2.filter:1.app下创建templatetags目录2.任意xxoo.py文件3.from django import template 创建template对象 register=template.Library()4.@register.simple_tag   def func(arg1,arg2): #参数只能是两个!return 'aagagnaads...'5.settings中注册app6.html文件顶部{% load xxoo %}7.{{参数1|函数名:参数2}}缺点:参数限制 引用时不能加空格优点:能作为if条件第三课 分页1.防止xss攻击(默认不执行包含代码的字符串):1.在前端:{{ page_str|safe}}2.在后端:from django.utils.safestring import mark_safepage_str01 = """..."""page_str01=mark_safe(page_str01)2.(使用分页模块)第四课 cookie和装饰器cookie是客户端浏览器上的一个文件键值对{'k1':'v1',....}示例1:urls.py中添加路径:path('login/',views.login),path('index/',views.index),templates中新建登录页面login.html和主页index.htmllogin.html代码:<form action="/login/" method="post">用户名:<input type="text" name="username">密码:<input type="password" name="pwd"><input type="submit" value="提交"></form>index.html代码:<h1>欢迎登陆:{{ k }}</h1>views.py中代码:user_info={'xiaoming':'123','xiaohong':'321',}def login(req):if req.method=='GET':return render(req,'login.html')if req.method=='POST':u=req.POST.get('username')v=req.POST.get('pwd')
if u in user_info:if user_info[u]==v:res=redirect('/index/')res.set_cookie('username111',u,max_age=5)#5代表5秒钟后清除cookie,不填则关闭浏览器清除cookiereturn reselse:return render(req,'login.html')def index(req):v=req.COOKIES.get('username111')if not v:return redirect('/login/')else:return render(req,'index.html', {'k': v})cookie加密(浏览器自动给解密了,没毛用):获取cookie:req.COOKIES.get('...')u=req.get_signed_cookie('pwd',salt='abcd')设置cookie:req.set_cookie('...')res.set_signed_cookie('pwd',v,salt='abcd')装饰器:def auth(func):def inner(req,*args,**kwargs):v=req.COOKIES.get('username111')if not v:return redirect('/login/')return func(req,*args,**kwargs)return inner@authdef index(req):v = req.COOKIES.get('username111')return render(req,'index.html', {'k': v})

第二十一章 Django的分页与cookie的更多相关文章

  1. JavaScript高级程序设计:第二十一章

    第二十一章 Ajax与Comet 一.XMLHttpRequest对象 1.XHT的用法 在使用XHR对象时,要调用的第一个方法时open( ),它接受3个参数:要发送的请求的类型.请求的URL和表示 ...

  2. Flask 教程 第二十一章:用户通知

    本文翻译自The Flask Mega-Tutorial Part XXI: User Notifications 这是Flask Mega-Tutorial系列的第二十一章,我将添加一个私有消息功能 ...

  3. Gradle 1.12用户指南翻译——第二十一章. Gradle 插件

    昨天晚上只顾着和女朋友看<匆匆那年>电视剧的最后几集,所以说好的Android文档<Gradle 插件用户指南>第五章自然也没翻译多少.所以今天也发不了第五章的翻译了,就发几个 ...

  4. “全栈2019”Java多线程第二十一章:同步代码块产生死锁的例子

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  5. “全栈2019”Java异常第二十一章:finally不被执行的情况

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...

  6. “全栈2019”Java第二十一章:流程控制语句中的决策语句if

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  7. 2017.2.15 开涛shiro教程-第二十一章-授予身份与切换身份(二) controller

    原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398 根据下载的pdf学习. 开涛shiro教程-第二十一章-授予身份与切换身份(二) 1.回顾 ...

  8. 2017.2.15 开涛shiro教程-第二十一章-授予身份与切换身份(一) table、entity、service、dao

    原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398 根据下载的pdf学习. 第二十一章 授予身份与切换身份(一) 1.使用场景 某个领导因为某 ...

  9. python 教程 第二十一章、 扩展Python

    第二十一章. 扩展Python /* D:\Python27\Lib\Extest-1.0\Extest2.c */ #include <stdio.h> #include <std ...

随机推荐

  1. pythhon_如何读写json数据

    案例: 在web应用中常常用到json数据进行传输数据,本质上是字典类型数据转换成字符串,通过字符串进行网页传输,然后把接收到的字符串转换成字典类似数据 需求:实现字典转换成字符串,字符串转换成字典数 ...

  2. 三十天学不会TCP,UDP/IP网络编程 - UDP的实践--DHCP

    在经历了一顿忙碌加出去玩了玩之后,我又开始重新更新了~这是最新的一篇~完整版可以去gitbook(https://www.gitbook.com/@rogerzhu/)看到,在gitbook的后台流量 ...

  3. JAVA中double类型运算结果异常的解决

    问题: 对两个double类型的值进行运算,有时会出现结果值异常的问题.比如: System.out.println(19.99+20); System.out.println(1.0-0.66); ...

  4. Selenium+java+idea的安装与配置

    当前操作系统:Windows10pro x64 一.安装JDK 1.到jdk官网下载一个对应当前系统的安装包(Selenium仅支持JDK1.8及以上版本) 网址:http://www.oracle. ...

  5. Nagios状态长时间处于Pending的解决方法

    1 nagios 守护进程引起的一系列问题 1 影响nagios web页面收集监控信息 致使页面出现时而收集不到服务信息 2 影响pnp查看图形化,出图缓慢 3 影响查看服务状态信息,致使有时候查看 ...

  6. mysql(4)—— 表连接查询与where后使用子查询的性能分析。

    子查询就是在一条查询语句中还有其它的查询语句,主查询得到的结果依赖于子查询的结果. 子查询的子语句可以在一条sql语句的FROM,JOIN,和WHERE后面,本文主要针对在WHERE后面使用子查询与表 ...

  7. java for循环增强(foreach)

    for循环增强,在此之前还不知道foreach有这样的功能,先鄙视一下自己,留给自己看: 功能: ***若List用foreach : [  for(Student stu : list)  ]这种形 ...

  8. Tomcat就是这么简单

    什么是Tomcat Tomcat简单的说就是一个运行JAVA的网络服务器,底层是Socket的一个程序,它也是JSP和Serlvet的一个容器. 为什么我们需要用到Tomcat 如果你学过html,c ...

  9. 20_Python字典总结

    字典: python内置了字典:dic全称dictionary.其他语言中成为map,使用key-value的存储,键-值.具有极快的查找速度类似与我们查字典,我们要查一个字1.从第一页往后翻,知道翻 ...

  10. libGDX-wiki发布

    为方便大家学习和访问,我将libgdx的wiki爬取到doku-wiki下,专门建立了以下地址.欢迎大家来共同完善. http://wiki.v5ent.com