在views里边,怎么导入局部配置和全局配置

from s18day24  import  settings
#这样导入的是仅仅用户自定义的配置 from django.conf import settings
#这样导入的是全局的配置,包含用户自己定义的配置和内部自带的配置

装饰器怎么写:

装饰器有一个模板,

先定义一个函数,内层再定义一个函数,然后直接将函数名返回。

  函数里边写功能,最后return返回回去

模板:

def auth(func):
def inner (request,*args,**kwargs):
response = func (request,*args,**kwargs)
return response
return inner def auth(func):
def inner(request,*args,**kwargs):
# 在执行视图函数之前
user_info = request.session.get(settings.USER_SESSION_KEY)
if not user_info:
return redirect('/login/')
# 执行视图函数
response = func(request,*args,**kwargs)
return response
return inner

中间件:

装饰器对于一个功能来说,能够做到很好的调节,但是对于某些功能来说,例如验证。

如果功能都需要用到它, 改动起来会比较麻烦。所以这时候我们可以利用中间件。

Django的请求周期:

请求过来路由系统,然后做url的匹配,当匹配成功了以后做路由分发执行视图函数,然后执行视图函数取数据等一系列操作,最后将网页字符串返回给用户。

中间件就是在路由系统前面加的一些规则(类)。

django中间件必须知道的图:

 process_request:
#先正常执行request process_views:
#先正常执行request,不执行后边的路由系统,然后先执行views,最后执行路由系统 process_expection:
#异常时执行 process_response:
#先正常执行request,然后先执行views,然后执行response,最后执行路由系统 process_template_response:
#视图返回的对象中有render方法

网页有一个模板,写新网页的时候直接继承过来,改想改的内容就可以:

<html>
<head>
<title></title>
<style></style>
{% block css %}{% endblock %}
</head> <body>
{% block body %}{% endblock %}
</body> <script></script>
{% block body %}{% endblock %} </html> #继承时写上继承哪个网页
{% extends "layout.html" %}
#然后后边修改某些模块就可以了

写一个分页的模块:

新建一个目录utils,然后在下面写一个pager.py文件:

"""
分页组件:
使用方法:
视图函数:
from utils.pager import Pagination
def host(request):
all_count = models.Host.objects.all().count()
# page_obj = Pagination(request.GET.get('page'),all_count,'/host/')
page_obj = Pagination(request.GET.get('page'),all_count,request.path_info)
host_list = models.Host.objects.all()[page_obj.start:page_obj.end]
return render(request,'host.html',{'host_list':host_list,'page_html': page_obj.page_html()})
HTML:
<style>
.pager a{
display: inline-block;
padding: 3px 5px;
margin: 3px;
border: 1px solid #dddddd;
}
.pager a.active{
background-color: cadetblue;
color: white;
} </style> <div class="pager">
{{ page_html}}
</div> """ from django.utils.safestring import mark_safe
class Pagination(object):
def __init__(self,current_page,total_count,base_url, per_page_count=,max_pager_num=):
"""
:param current_page: 用户请求的当前页
:param per_page_count: 每页显示的数据条数
:param total_count: 数据库中查询到的数据总条数
:param max_pager_num: 页面上最多显示的页码
"""
self.base_url = base_url
total_page_count, div = divmod(total_count, per_page_count)
if div:
total_page_count += self.total_page_count = total_page_count
try:
current_page = int(current_page)
except Exception as e:
current_page =
if current_page > total_page_count:
current_page = total_page_count self.current_page = current_page
self.per_page_count = per_page_count
self.total_count = total_count
self.max_pager_num = max_pager_num
self.half_max_pager_num = int(max_pager_num/) @property
def start(self):
return (self.current_page - ) * self.per_page_count @property
def end(self):
return self.current_page * self.per_page_count def page_html(self):
page_html_list = [] if self.current_page <= :
prev = "<a href='#'>上一页</a>"
else:
prev = "<a href='%s?page=%s'>上一页</a>" % (self.base_url,self.current_page - ,)
page_html_list.append(prev) max_pager_num =
half_max_pager_num = int(max_pager_num / ) # 数据总页数 < 页面上最大显示的页码个数
if self.total_page_count <= max_pager_num:
page_start =
page_end = self.total_page_count
else:
# 数据比较多,已经超过11个页码
# 如果当前页 <=,显示 -
if self.current_page <= half_max_pager_num:
page_start =
page_end = max_pager_num
else:
# 当前页 >=
if (self.current_page + ) > self.total_page_count:
page_end = self.total_page_count
# page_start = current_page -
page_start = self.total_page_count - max_pager_num +
else:
page_start = self.current_page - half_max_pager_num # 当前页 -
page_end = self.current_page + half_max_pager_num # 当前页 + for i in range(page_start, page_end + ):
if self.current_page == i:
tag = "<a class='active' href='%s?page=%s'>%s</a>" % (self.base_url,i, i,)
else:
tag = "<a href='%s?page=%s'>%s</a>" % (self.base_url,i, i,)
page_html_list.append(tag) # 下一页
if self.current_page >= self.total_page_count:
nex = "<a href='#'>下一页</a>"
else:
nex = "<a href='%s?page=%s'>下一页</a>" % (self.base_url,self.current_page + ,)
page_html_list.append(nex) return mark_safe("".join(page_html_list))

然后在views视图中写入函数:

def host(request):
all_count = models.Host.objects.all().order_by('-id').count()
# page_obj = Pagination(request.GET.get('page'),all_count,'/host/')
page_obj = Pagination(request.GET.get('page'),all_count,request.path_info)
host_list = models.Host.objects.all().order_by('-id')[page_obj.start:page_obj.end]
return render(request,'host.html',{'host_list':host_list,'page_html': page_obj.page_html()})

前面的models里是这样定义的:

class Host(models.Model):
hostname = models.CharField(verbose_name='主机名',max_length=)
ip = models.CharField(max_length=)# ip = models.GenericIPAddressField(protocol='both')
port = models.IntegerField()
user = models.ForeignKey(to='UserInfo',default=)
dp = models.ManyToManyField(to="Department")

Day24 中间件 自定义分页 ModelForm 序列化 缓存 信号的更多相关文章

  1. python 全栈开发,Day87(ajax登录示例,CSRF跨站请求伪造,Django的中间件,自定义分页)

    一.ajax登录示例 新建项目login_ajax 修改urls.py,增加路径 from app01 import views urlpatterns = [ path('admin/', admi ...

  2. django 自定义分页,网址存储缓存,CBV

    1. 通过切片控制分页 自定义分页: from django.shortcuts import render # Create your views here. from app01.models i ...

  3. day19 Models补充+缓存+信号+序列化+分析抽屉页面

    参考链接: http://www.cnblogs.com/wupeiqi/articles/5237704.html http://www.cnblogs.com/wupeiqi/articles/5 ...

  4. Django 分页器 缓存 信号 序列化

    阅读目录 分页器 缓存 信号 序列化 Django分页器  (paginator) 导入 from django.core.paginator import Paginator, EmptyPage, ...

  5. Cookie Session和自定义分页

    cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不 ...

  6. Django框架详细介绍---cookie、session、自定义分页

    1.cookie 在HTTP协议介绍中提到,该协议是无状态的,也就是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不会直接影响后面的 ...

  7. Cookie、Session和自定义分页

    一.cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响, ...

  8. 自定义分页及Cookie、Session机制

    分页 自定义分页 data = [] , ): tmp = {"id": i, "name": "alex-{}".format(i)} d ...

  9. Django - Cookie、Session、自定义分页和Django分页器

    2. 今日内容 https://www.cnblogs.com/liwenzhou/p/8343243.html 1. Cookie和Session 1. Cookie 服务端: 1. 生成字符串 2 ...

随机推荐

  1. Guava 教程(3):Java 的函数式编程,通过 Google Collections 过滤和调用

    原文出处: oschina 在本系列博客的第一.二部分,我介绍了非常优秀的Google Collections和Guava包.本篇博客中我们来看看如何使用Google Collections来做到过滤 ...

  2. java文件的基本操作示例

    一.获得控制台用户输入的信息 public String getInputMessage() throws IOException...{ System.out.println("请输入您的 ...

  3. C#之面向对象的特性

                类是一种抽象的数据类型,但是其抽象的程度有可能会不同,而对象就是一个类的实例,例如,将花设计为一个类,天堂鸟和矢车菊就可以各为一个对象,从这里我们可以看出来,天堂鸟和矢车菊 ...

  4. 浅析GDAL库C#版本支持中文路径问题

    GDAL库对于C#的支持问题还是蛮多的,对于中文路径的支持就是其中之一(另一个就是通过OGR库获取图形的坐标信息). 关于C#支持中文路径,看过我之前博客的应该都不陌生,如果使用的是我修改过的GDAL ...

  5. Android学习之旅-android系统服务的启动过程以及分类(90)

    读了android开发精要这本书,所以我把书中的比较精彩的地方截图了,一块分享一下

  6. STL的容器算法迭代器的设计理念

    1) STL的容器通过类模板技术,实现数据类型和容器模型的分离. 2) STL的迭代器技术实现了遍历容器的统一方法:也为STL的算法提供了统一性. 3) STL的函数对象实现了自定义数据类型的算法运算 ...

  7. Android中怎样获取SD卡路径

    很多时候我们需要将我们的数据或者apk保存到SD卡中,但是使用绝对路径可能会遇到错误,怎样解决这个问题呢?     可以通过以下方法获取SD卡的路径: Environment.getExternalS ...

  8. 第十一章 图像之2D(2)

    Android游戏开发群:290051794 Libgdx游戏开发框架交流群:261954621 作者:宋志辉  出处:http://blog.csdn.net/song19891121 本文版权归作 ...

  9. Gradle 1.12用户指南翻译——第四十章. ANTLR 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  10. Android监听自身卸载,弹出用户反馈调查

    1,情景分析 在上上篇博客中我写了一下NDK开发实践项目,使用开源的LAME库转码MP3,作为前面几篇基础博客的加深理解使用的,但是这样的项目用处不大,除了练练NDK功底.这篇博客,我将讲述一下一个各 ...