Django 常见问题回答

  • Django 密码存储
    Django 提供灵活的密码存储系统,默认使用 PBKDF2。
    对象的 password 属性是这种格式的字符串:
$$$

总共有四个部分:散列算法, 算法迭代次数,随机盐和生成的密码哈希。
Django 通过查询 PASSWORD_HASHERS来设置要使用的算法。第一个条目用于存储密码,其它是可用于检查现有密码的有效哈希。

  • Django request 什么时候创建的
    可以在 Django 项目的 wsgi.py 文件中一步一步跟进去查看源码
    request 是在 WSGIHandler 中创建的,http 请求到来之后调用其 __call__ 方法,在里面创建了 request,是一个 WSGIRequest 类型的对象,它继承自 HttpRequest 对象,它会解析 http 请求的参数,并封装 GET, POST 等方法。在GET 中返回一个 QueryDict 对象,这个是 Django 自定义的类似字典的类,它是 dict 的子类型,用来处理同一个键带多个值的情况。类似以下这样
>>> from django.conf import settings
>>> q = QuertDict('a=1&a=2&a=3&b=1&b=2&b=3')
>>> q
>>> 
>>> q['a']
'3'
>>> q.getlist('a')
['1', '2', '3']
  • request 主要属性
    scheme 请求的方法 http/https
    path 请求的全路径,不包含域名部分
    method 请求的类型,GET、POST
    COOKIES 请求的 cookie
    META 请求头的相关信息,获取 IP 地址 META['REMOTE_ADDR']
    user 当前登录的用户
    session 当前会话的字典对象
  • response 主要属性
    content 响应内容的字节
    charset 响应内容被编码所使用的字符集
    status_code 响应码
    子类
    HttpResponseRedirect 重定向 302
    HttpResponseNotFound 网页未找到 404
    HttpResponseForbidden 没有权限 403
    HttpResponseServerError 服务器错误 500
    JsonResponse 以 Json 格式返回,不是 html/xml
    以上详情见官网。
  • 中间件的调用过程
    一看源码便知:
if hasattr(mw_instance, 'process_request'):
   self._request_middleware.append(mw_instance.process_request)

if hasattr(mw_instance, 'process_view'):
    self._view_middleware.append(mw_instance.process_view)
# 请求到来时:以上是从上到下调用
# 请求结束后:以下是从下到上调用
if hasattr(mw_instance, 'process_template_response'):
    self._template_response_middleware.insert(0, mw_instance.process_template_response)

if hasattr(mw_instance, 'process_response'):
    self._response_middleware.insert(0, mw_instance.process_response)

if hasattr(mw_instance, 'process_exception'):
    self._exception_middleware.insert(0, mw_instance.process_exception)

只要注意理解 appendinsert 的区别即可

  • Django 一次响应


    Django 一次响应的总结
  • 重定向问题
    一般经常使用 HttpResponseRedirectredirect 来实现跳转,不同的是 HttpResponseRedirect 使用状态码 302,而 redirect 使用状态码 301redirect 配合 reverse 使用。另外也可以在定义 url 的时候使用 redirect_to 来重定向。在 session 中也可以传值来重定向。

  • 数据库读写分离
    有两种方法:
    手动 通过使用 .using(db_name) 来指定数据库
    自动 配置一个 Router 类,然后重写一些方法。settings.py 中指定 DATABASE_ROUTERS,配置 DATABASE_ROUTERS = ['myrouter.Router',]

你可能感兴趣的:(Django 常见问题回答)