返回404

from django.http import HttpResponse,  HttpResponseNotFound

def not_found(request):
return HttpResponse('Not found', status=)

return HttpResponseNotFound('Not found')

注意 返回的页面和status=200一样都是'Not found'

自定义错误视图

1. 修改配置文件

# settings.py

DEBUG = False
ALLOWED_HOSTS = ['*']

2. 创建视图函数

# views.py
from django.http import HttpResponse
def not_found_view(request):
return HttpResponse('404页面') def server_error(request):
return HttpResponse('500页面')

3. 配置项目路由

# urls.py
from . import views handler404 = views.not_found_view
handler500 = views.server_error # handler403 = views.403_view
# handler400 = views.400_view

render()函数

render(request, template_name, context=None, content_type=None, status=None, using=None)

必填项

  • request:request用户生成response

  • template_name:模板名称,可以是列表会使用先找到的那个

可选项

  • context:渲染模板的context字典,默认是{}

  • content_type:响应的 MIME type,默认使用 settings.py中 DEFAULT_CONTENT_TYPE

  • status:响应状态码 默认 status=200

  • using:模板引擎,可更改默认引擎,如jinja2

redirect()函数

redirect(to, permanet=False, *args,  **kwargs),返回一个HttpResponseRedirect

to参数可以是:

model对象、视图名称、相对或绝对URL地址

object    = MyModel.objects.get(...)
return redirect(object)
return redirect('some-view-name', foo='bar' )
return redirect('/some/url/')
return redirect('https://example.com/', permanent=True)

get_object_or_404() 函数

from django.shortcuts import get_object_or_404
def my_view(request):
my_object = get_object_or_404(MyModel, pk=1) # 代码等同于
from django.http import Http404
def my_view(request):
try:
my_object = MyModel.objects.get(pk=1)
except MyModel.DoesNotExist:
raise Http404("No MyModel matches the given query.")

其他 get_list_or_404()函数

reverse() 反向解析URL

reverse(viewname, urlconf=None, agrs=None, kwargs=None, current_app=None)

reverse_lazy(viewname, urlconf=None, agrs=None, kwargs=None, current_app=None)  惰性解析,Django启动加载顺序  如类中用reverse_lazy(),类视图

装饰器

  • require_http_methods(request_method_list)

  • require_GET()

  • require_POST()

  • require_safe()  安全性请求 GET、HEAD

  • gzip_page()  内容压缩, 一般会在代理服务器里处理,Nginx

  • cache_control(**kwargs),告诉浏览器的缓存,和memecache不同,可用在password

  • never_cache()

  • login_required()  验证页面必须登录,常用

  • transaction.atmoic  事务功能

from django.views.decorators.http import require_http_methods
from django.db.transaction import atomic @require_http_methods(["GET", "POST"])
@atomic
def my_view(request):
pass

HttpRequest and HttpResponse

https://docs.djangoproject.com/en/1.11/ref/request-response/

用户请求属性

  • HttpReqeust.scheme

  • HttpReqeust.body

  • HttpReqeust.path

  • HttpReqeust.method

  • HttpReqeust.GET

  • HttpReqeust.POST

  • HttpReqeust.COOKIES

  • HttpReqeust.FILES

  • HttpReqeust.META

应用程序设置的属性

  • HttpReqeust.current_app

  • HttpReqeust.urlconf

中间件设置的属性

  • HttpReqeust.session

  • HttpReqeust.site

  • HttpReqeust.user

  • HttpReqeust.user.is_authenticated

  • ......

发送邮件(Django自带)

django.core.mail.send_mail(subject, message, from_email, recipient_list,

fail_sliently=False, auth_user=None, auth_password=None, connection=None, html_message=None)

# settings.py
EMAIL_HOST = 'smtp.126.com'
EMAIL_PORT = 25
EMAIL_HOST_USER = '******'
EMAIL_HOST_PASSWORD = '******'
# EMAIL_USE_SSL = True # if port is 587, set True
# EMAIL_USE_TLS = True # if port is 465, set True # views.py
from django.core.mail import send_mail def send_email(request): if request.method == "POST":
subject = request.POST.get('subject', '')
message = request.POST.get('message', '')
from_email = request.POST.get('from_email', '')
if subject and message and from_email:
try:
send_mail(subject, message, from_email, ['nin@jianxin.com.cn'])
except Exception as e:
return HttpResponse(str(e)) return HttpResponse('发送成功!')
else:
return HttpResponse("确保字段填写正确!") elif request.method == "GET":
return render(request, 'send_email.html')

导出CSV

import csv
def download_csv(request):
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment;filename="download.csv"' writer = csv.writer(response)
writer.writerow(['First Row', 'Foo', 'Bar', 'Baz'])
writer.writerow(['SecondRow', 'A', 'B', 'C', '"Testing"', "Here's a quote"])
return response def download(request):
f = open('601318.csv', 'rb')
response = HttpResponse(f, content_type='application/csv')
response['Content-Disposition'] = 'attachment;filename="601318.csv"'
f.close()
return response

上传文件

# views.py
def upload(request):
if request.method == "POST":
upload_file = request.FILES.get('file', None)
if upload_file is None:
return HttpResponse('No file get')
else:
with open(upload_file.name, 'wb') as f:
for chunk in upload_file.chunks():
f.write(chunk) # f.write(upload_file.read())
return HttpResponse('OK')
elif request.method == "GET":
return render(request, 'upload.html') # upload.html
<h1>Upload</h1>
<form method="post" enctype="multipart/form-data">
{% csrf_token %}
<label for="file">Upload: </label><input type="file" id="file" name="file"/><br/> <input type="submit" value="upload"/>
</form>

说明:

  • request.FILES

  • enctype 默认是 "application/x-www-form-urlencoded"

Django View 进阶的更多相关文章

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

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

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

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

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

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

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

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

  5. django view 装饰器

    Django提供了几个可以应用于视图以支持各种HTTP特性的装饰器 Allowed HTTP django.views.decorators.http里的装饰器可以根据请求方法限制对视图的访问. re ...

  6. Django 2.0 学习(07):Django 视图(进阶-续)

    接Django 2.0 学习(06):Django 视图(进阶),我们将聚焦在使用简单的表单进行处理和精简代码. 编写简单表单 我们将用下面的代码,来替换之前的detail模板("polls ...

  7. Django View(视图系统)

    Django View 官方文档 一个视图函数(类),简称视图,是一个简单的 Python 函数(类),它接受Web请求并且返回Web响应.响应可以是一张网页的HTML内容,一个重定向,一个404错误 ...

  8. Django orm进阶查询(聚合、分组、F查询、Q查询)、常见字段、查询优化及事务操作

    Django orm进阶查询(聚合.分组.F查询.Q查询).常见字段.查询优化及事务操作 聚合查询 记住用到关键字aggregate然后还有几个常用的聚合函数就好了 from django.db.mo ...

  9. 安卓自定义View进阶-Canvas之画布操作 转载

    安卓自定义View进阶-Canvas之画布操作 转载 https://www.gcssloop.com/customview/Canvas_Convert 本来想把画布操作放到后面部分的,但是发现很多 ...

随机推荐

  1. (14)其他Linux命令

    *****拷贝文件cp somefile.1 /home/hadoop/      以原文件名进行拷贝 cp somefile.1 /home/hadoop/somefile.2    以新文件名进行 ...

  2. 编写Servlet 实例 -Shopping网站时,遇到的几个问题

    问题一.在Web 上运行时,用JDBC链接MySQL总是出错,一直出现驱动加载失败 ------提示java.lang.ClassNotFoundException.解决方案:将数据库驱动jar文件导 ...

  3. python使用细节

    python的函数位置参数在调用时可以直接传参,也可以a=5,b=7的形式传参,原以为kw参数才可以. >>> def f(a,b): print a+b >>> ...

  4. web和app的简单测试区别和工具介绍

    首先说一下我对Web自动化测试与CS自动化测试的认识.从宏观对比都是通过脚本自动化完成功能的验证,区别不大.Web测试更为显著的浏览器兼容性.安全,以及与Web技术相关的表单测试.链接测试等,其实都是 ...

  5. 吴裕雄 python深度学习与实践(12)

    import tensorflow as tf q = tf.FIFOQueue(,"float32") counter = tf.Variable(0.0) add_op = t ...

  6. prim及其练习

    关于prim,其实我今天才学... prim其实就是最小生成树的一种算法,严格每次的找最小边连到树上.看书上的代码看不懂,于是就自己大胆用堆优化写prim. 搞了很长时间,经过不写努力,还是搞出来了. ...

  7. VueJs相关学习网址

      麦子学院 http://www.maiziedu.com/course/916/   慕课网-vue.js入门基础 https://www.imooc.com/learn/694   查阅的网址 ...

  8. php面试题五之nginx如何调用php和php-fpm的作用和工作原理

    nginx如何调用php 采用nginx+php作为webserver的架构模式,在现如今运用相当广泛.然而第一步需要实现的是如何让nginx正确的调用php.由于nginx调用php并不是如同调用一 ...

  9. 三、putty工具常见设置

    转载自:https://www.cnblogs.com/hdk1993/p/4769072.html Putty是一个免费小巧的Win32平台下的telnet,rlogin和ssh客户端. 它的主程序 ...

  10. PHP开发——分支结构

    If if if···else··· if···else··· switch