在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. 手动开发动态资源之servlet初步

    1.1 静态资源和动态资源的区别 静态资源:当用户多次访问这个资源,资源的源代码永远不会改变的资源. 动态资源:当用户多次访问这个资源,资源的源代码可能会发送改变. 1.2动态资源的开发技术 Serv ...

  2. JAVA之旅(二十三)——System,RunTime,Date,Calendar,Math的数学运算

    JAVA之旅(二十三)--System,RunTime,Date,Calendar,Math的数学运算 map实在是太难写了,整理得我都晕都转向了,以后看来需要开一个专题来讲这个了,现在我们来时来学习 ...

  3. Mybatis插入MySQL数据库中文乱码

    Mybatis插入MySQL数据库中文乱码 在dataSource.properties配置文件中设置useUnicode=true&characterEncoding=utf-8编码即可. ...

  4. pig 的chararry类型不能用比较运算符comparison operator

    pig 的chararry类型可能是按字段,逐个字段进行比较. element_id 是chararray类型, 语句: no_app_category_mapping = filter no_ele ...

  5. EBS DBA指南笔记(一)

    第一章  ORACLE APPLICATIONS 的组件与架构 1.ebs组件的几大构成:客户端,form server,web server,concurrent processor,数据库.每个组 ...

  6. 学习TensorFlow,邂逅MNIST数据集

    如果说"Hello Word!"是程序员的第一个程序,那么MNIST数据集,毫无疑问是机器学习者第一个训练的数据集,本文将使用Google公布的TensorFLow来学习训练MNI ...

  7. Swing——鼠标(Action)

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/41346969 看完这篇文章,你可能会学到到知识如下: (1 ...

  8. 导航控制器&nbsp;UI_08(上)

    主要内容:UINavigationController 重要:属性传值(向后一个界面传值).代理传值(向前相邻的界面传值).单例传值(不相邻的界面向前传值) 1.UINavigationControl ...

  9. UNIX环境高级编程——进程环境

    一.main函数 C程序总是从main函数开始.当内核执行C程序时,在调用main前先调用一个特殊的启动例程.可执行程序文件将此启动例程指定为程序的起始地址--这是由连接编译器设置的,而连接编译器则由 ...

  10. python 操作mysql数据库demo

    sudo apt-get install python-mysqldb #!/usr/bin/env python #encoding=utf-8 import sys import MySQLdb ...