复习

  1. """
  2. 1、vue如果控制html
  3. 在html中设置挂载点、导入vue.js环境、创建Vue对象与挂载点绑定
  4. 2、vue是渐进式js框架
  5. 3、vue指令
  6. {{ }}
  7. v-text|html => 限制一次性渲染 v-once
  8. v-if|show
  9. v-if v-else-if v-else
  10. v-for
  11. v-model
  12. v-bind [c1, c2] | {active: isActive}
  13. v-on fn | fn(...) | fn($event, ...)
  14. {{ data中出现的变量 }} v-if="data中出现的变量 的条件表达式"
  15. 4、vue实例成员
  16. el | template
  17. components
  18. data {} | data () { return {} }
  19. methods
  20. computed:定义的是方法属性
  21. watch:监听属性
  22. props
  23. <div id="app">
  24. <Nav :subdata="supdata" @subaction="supaction"></Nav>
  25. </div>
  26. 5、生命周期钩子
  27. 都是实例成员,在组件创建到销毁整个过程的某些时间节点回调的函数
  28. beforeCreated() {
  29. this._fn => this.$option.methods._fn
  30. }
  31. 6、项目
  32. 环境:node => npm(cnpm) => vue/cli
  33. 创建与配置 vue create proj | 选择基础插件 | 配置npm启动
  34. 插件:vue-router | vuex | axios | vue-cookies | element-ui
  35. """

drf框架

全称:django-rest framework

知识点

  1. """
  2. 1、接口:什么是接口、restful接口规范
  3. 2、CBV生命周期源码 - 基于restful规范下的CBV接口
  4. 3、请求组件、解析组件、响应组件
  5. 4、序列化组件(灵魂)
  6. 5、三大认证(重中之重):认证、权限(权限六表)、频率
  7. 6、其他组件:过滤、筛选、排序、分页、路由
  8. """
  9. # 难点:源码分析

接口

  1. """
  2. 接口:联系两个物质的媒介,完成信息交互
  3. web程序中:联系前台页面与后台数据库的媒介
  4. web接口组成:
  5. url:长得像放回数据的url链接
  6. 请求参数:前台按照指定的key提供数据给后台
  7. 响应数据:后台与数据库交互后将数据反馈给前台
  8. """

restful接口规范

接口规范:就是为了采用不同的后台语言,也能使用同样的接口获取到同样的数据

如何写接口:接口规范是 规范化书写接口的,写接口要写 url、响应数据

​ 注:如果将请求参数也纳入考量范围,那就是在写 接口文档

两大部分:

  • url
  1. 1) api关键字标识接口url
  2. api.baidu.com | www.baidu.com/api
  3. 2) 接口数据安全性决定优先选择https协议
  4. 3) 如果一个接口有多版本存在,需要在url中标识体现
  5. api.baidu.com/v1/... | api.baidu.com/v2/...
  6. 4) 接口操作的数据源称之为 资源,在url中一般采用资源复数形式,一个接口可以概括对该资源的多种操作方式
  7. api.baidu.com/books | api.baidu.com/books/(pk)
  8. 5) 请求方式有多种,用一个url处理如何保证不混乱 - 通过请求方式标识操作资源的方式
  9. /books get 获取所有
  10. /books post 增加一个(多个)
  11. /books/(pk) delete 删除一个
  12. /books/(pk) put 整体更新一个
  13. /books/(pk) patch 局部更新一个
  14. 6) 资源往往涉及数据的各种操作方式 - 筛选、排序、限制
  15. api.baidu.com/books/?search=西&ordering=-price&limit=3
  • 响应数据
  1. 1) http请求的响应会有响应状态码,接口用来返回操作的资源数据,可以拥有 操作数据结果的 状态码
  2. status 0(操作资源成功) 1(操作资源失败) 2(操作资源成功,但没匹配结果)
  3. 注:资源状态码不像http状态码,一般都是后台与前台或是客户约定的
  4. 2) 资源的状态码文字提示
  5. status ok '账号有误' '密码有误' '用户锁定'
  6. 3) 资源本身
  7. results
  8. 注:删除资源成功不做任何数据返回(返回空字符串)
  9. 4) 不能直接放回的资源(子资源、图片、视频等资源),返回该资源的url链接

基于restful规范的原生Django接口

主路由:url.py
  1. from django.conf.urls import url, include
  2. from django.contrib import admin
  3. urlpatterns = [
  4. url(r'^admin/', admin.site.urls),
  5. # 路由分发
  6. url(r'^api/', include('api.urls'))
  7. ]
api组件的子路由:api/url.py
  1. from django.conf.urls import url
  2. from . import views
  3. urlpatterns = [
  4. url(r'^books/', views.Book.as_view()),
  5. url(r'^books/(?P<pk>.*)/$', views.Book.as_view()),
  6. ]
模型层:model.py
  1. from django.db import models
  2. class Book(models.Model):
  3. title = models.CharField(max_length=64)
  4. price = models.DecimalField(max_digits=5, decimal_places=2)
  5. class Meta:
  6. db_table = 'old_boy_book'
  7. verbose_name = '书籍'
  8. verbose_name_plural = verbose_name
  9. def __str__(self):
  10. return '《%s》' % self.title
后台层:admin.py
  1. from django.contrib import admin
  2. from . import models
  3. admin.site.register(models.Book)
数据库迁移
  1. >: python manage.py makemigrations
  2. >: python manage.py migrrate
  3. >: python manage.py createsuperuser
视图层:views.py
  1. from django.http import JsonResponse
  2. from django.views import View
  3. from . import models
  4. # 六大基础接口:获取一个 获取所有 增加一个 删除一个 整体更新一个 局部更新一个
  5. # 十大接口:群增 群删 整体改群改 局部改群改
  6. class Book(View):
  7. def get(self, request, *args, **kwargs):
  8. pk = kwargs.get('pk')
  9. if not pk: # 群查
  10. # 操作数据库
  11. book_obj_list = models.Book.objects.all()
  12. # 序列化过程
  13. book_list = []
  14. for obj in book_obj_list:
  15. dic = {}
  16. dic['title'] = obj.title
  17. dic['price'] = obj.price
  18. book_list.append(dic)
  19. # 响应数据
  20. return JsonResponse({
  21. 'status': 0,
  22. 'msg': 'ok',
  23. 'results': book_list
  24. }, json_dumps_params={'ensure_ascii': False})
  25. else: # 单查
  26. book_dic = models.Book.objects.filter(pk=pk).values('title', 'price').first()
  27. if book_dic:
  28. return JsonResponse({
  29. 'status': 0,
  30. 'msg': 'ok',
  31. 'results': book_dic
  32. }, json_dumps_params={'ensure_ascii': False})
  33. return JsonResponse({
  34. 'status': 2,
  35. 'msg': '无结果',
  36. }, json_dumps_params={'ensure_ascii': False})
  37. # postman可以完成不同方式的请求:get | post | put ...
  38. # postman发送数据包有三种方式:form-data | urlencoding | json
  39. # 原生django对urlencoding方式数据兼容最好
  40. def post(self, request, *args, **kwargs):
  41. # 前台通过urlencoding方式提交数据
  42. try:
  43. book_obj = models.Book.objects.create(**request.POST.dict())
  44. if book_obj:
  45. return JsonResponse({
  46. 'status': 0,
  47. 'msg': 'ok',
  48. 'results': {'title': book_obj.title, 'price': book_obj.price}
  49. }, json_dumps_params={'ensure_ascii': False})
  50. except:
  51. return JsonResponse({
  52. 'status': 1,
  53. 'msg': '参数有误',
  54. }, json_dumps_params={'ensure_ascii': False})
  55. return JsonResponse({
  56. 'status': 2,
  57. 'msg': '新增失败',
  58. }, json_dumps_params={'ensure_ascii': False})

Postman接口工具

官网下载安装

get请求,携带参数采用Params

post等请求,提交数据包可以采用三种方式:form-date、urlencoding、json

所有请求都可以携带请求头

















代码

注意点:

1.使用get过滤条件返回的是对象,所以后面不能点value,,filter是得到querySet对象可以点querySet方法

2.浏览器访问默认就是get请求

3.post请求一定要注掉csrf

4.create返回的也是对象

5.request.POST.dict() 是request.POST QuerySet对象的dict()方法,将数据变成字典的形式

6.rest_framework中的Response默认是浏览器返回的是页面,postman返回的数据

使用路由分发(api下也要创建一个url.py),然后视图类写视图,再models.py中写模型,数据迁移,创建createsuperuser,到admin后台进行录入数据,然后下载pip3 install djangorestframework,再到settings中注册app中’rest_framework‘ ,还有post请求要讲settings中csrf注掉

  1. 项目dp_proj下的url.py
  2. from django.conf.urls import url, include
  3. from django.contrib import admin
  4. urlpatterns = [
  5. url(r'^admin/', admin.site.urls),
  6. # 路由分发
  7. url(r'^api/', include('api.urls'))
  8. ]
  1. 应用api下的urls.py
  2. from django.conf.urls import url
  3. from . import views
  4. urlpatterns = [
  5. url(r'^books/$', views.Book.as_view()),
  6. url(r'^books/(?P<pk>.*)/$', views.Book.as_view()),
  7. url(r'^test/$', views.Test.as_view()),
  8. url(r'^test2/$', views.Test2.as_view()),
  9. ]
  1. models.py
  2. from django.db import models
  3. class Book(models.Model):
  4. title = models.CharField(max_length=64)
  5. price = models.DecimalField(max_digits=5, decimal_places=2)
  6. class Meta:
  7. db_table = 'old_boy_book'
  8. verbose_name = '书籍'
  9. verbose_name_plural = verbose_name
  10. def __str__(self):
  11. return '《%s》' % self.title
  1. admin.py
  2. from django.contrib import admin
  3. from . import models
  4. admin.site.register(models.Book)
  1. views.py
  2. from django.http import JsonResponse
  3. from django.views import View
  4. from . import models
  5. # 六大基础接口:获取一个 获取所有 增加一个 删除一个 整体更新一个 局部更新一个
  6. # 十大接口:群增 群删 整体改群改 局部改群改
  7. class Book(View):
  8. def get(self, request, *args, **kwargs):
  9. pk = kwargs.get('pk')
  10. if not pk: # 群查
  11. # 操作数据库
  12. book_obj_list = models.Book.objects.all()
  13. # 序列化过程
  14. book_list = []
  15. for obj in book_obj_list:
  16. dic = {}
  17. dic['title'] = obj.title
  18. dic['price'] = obj.price
  19. book_list.append(dic)
  20. # 响应数据
  21. return JsonResponse({
  22. 'status': 0,
  23. 'msg': 'ok',
  24. 'results': book_list
  25. }, json_dumps_params={'ensure_ascii': False})
  26. else: # 单查
  27. book_dic = models.Book.objects.filter(pk=pk).values('title', 'price').first()
  28. if book_dic:
  29. return JsonResponse({
  30. 'status': 0,
  31. 'msg': 'ok',
  32. 'results': book_dic
  33. }, json_dumps_params={'ensure_ascii': False})
  34. return JsonResponse({
  35. 'status': 2,
  36. 'msg': '无结果',
  37. }, json_dumps_params={'ensure_ascii': False})
  38. # postman可以完成不同方式的请求:get | post | put ...
  39. # postman发送数据包有三种方式:form-data | urlencoding | json
  40. # 原生django对urlencoding方式数据兼容最好
  41. def post(self, request, *args, **kwargs):
  42. # 前台通过urlencoding方式提交数据
  43. try:
  44. book_obj = models.Book.objects.create(**request.POST.dict())
  45. if book_obj:
  46. return JsonResponse({
  47. 'status': 0,
  48. 'msg': 'ok',
  49. 'results': {'title': book_obj.title, 'price': book_obj.price}
  50. }, json_dumps_params={'ensure_ascii': False})
  51. except:
  52. return JsonResponse({
  53. 'status': 1,
  54. 'msg': '参数有误',
  55. }, json_dumps_params={'ensure_ascii': False})
  56. return JsonResponse({
  57. 'status': 2,
  58. 'msg': '新增失败',
  59. }, json_dumps_params={'ensure_ascii': False})
  60. # drf框架的封装风格
  61. from rest_framework.views import APIView
  62. from rest_framework.response import Response
  63. from rest_framework.request import Request
  64. from rest_framework.serializers import Serializer
  65. from rest_framework.settings import APISettings
  66. from rest_framework.filters import SearchFilter
  67. from rest_framework.pagination import PageNumberPagination
  68. from rest_framework.authentication import TokenAuthentication
  69. from rest_framework.permissions import IsAuthenticated
  70. from rest_framework.throttling import SimpleRateThrottle
  71. # 总结:
  72. # 1) drf 对原生request做了二次封装,request._request就是原生request
  73. # 2) 原生request对象的属性和方法都可以被drf的request对象直接访问(兼容)
  74. # 3) drf请求的所有url拼接参数均被解析到query_params中,所有数据包数据都被解析到data中
  75. class Test(APIView):
  76. def get(self, request, *args, **kwargs):
  77. # url拼接的参数
  78. print(request._request.GET) # 二次封装方式
  79. print(request.GET) # 兼容
  80. print(request.query_params) # 拓展
  81. return Response('drf get ok')
  82. def post(self, request, *args, **kwargs):
  83. # 所有请求方式携带的数据包
  84. print(request._request.POST) # 二次封装方式
  85. print(request.POST) # 兼容
  86. print(request.data) # 拓展,兼容性最强,三种数据方式都可以
  87. print(request.query_params)
  88. return Response('drf post ok')
  89. # 在setting.py中配置REST_FRAMEWORK,完成的是全局配置,所有接口统一处理
  90. # 如果只有部分接口特殊化,可以完成 - 局部配置
  91. from rest_framework.renderers import JSONRenderer
  92. class Test2(APIView):
  93. renderer_classes = [JSONRenderer]
  94. def get(self, request, *args, **kwargs):
  95. return Response('drf get ok 2')
  96. def post(self, request, *args, **kwargs):
  97. return Response('drf post ok 2')

DRF框架

安装
  1. >: pip3 install djangorestframework
drf框架规矩的封装风格
  1. from rest_framework.views import APIView
  2. from rest_framework.response import Response
  3. from rest_framework.request import Request
  4. from rest_framework.serializers import Serializer
  5. from rest_framework.settings import APISettings
  6. from rest_framework.filters import SearchFilter
  7. from rest_framework.pagination import PageNumberPagination
  8. from rest_framework.authentication import TokenAuthentication
  9. from rest_framework.permissions import IsAuthenticated
  10. from rest_framework.throttling import SimpleRateThrottle
  11. class Test(APIView):
  12. def get(self, request, *args, **kwargs):
  13. return Response('drf get ok')
drf请求生命周期
  1. """
  2. 1) 请求走的是APIView的as_view函数
  3. 2) 在APIView的as_view调用父类(django原生)的as_view,还禁用了 csrf 认证
  4. 3) 在父类的as_view中dispatch方法请求走的又是APIView的dispatch
  5. 4) 完成任务方法交给视图类的请求函数处理,得到请求的响应结果,返回给前台
  6. """
  7. 1.views.py视图文件中写一个类继承APIView,点击APIView
  8. 2. renderer_classes = api_settings.DEFAULT_RENDERER_CLASSES
  9. parser_classes = api_settings.DEFAULT_PARSER_CLASSES
  10. authentication_classes = api_settings.DEFAULT_AUTHENTICATION_CLASSES
  11. throttle_classes = api_settings.DEFAULT_THROTTLE_CLASSES
  12. permission_classes = api_settings.DEFAULT_PERMISSION_CLASSES
  13. content_negotiation_class = api_settings.DEFAULT_CONTENT_NEGOTIATION_CLASS
  14. metadata_class = api_settings.DEFAULT_METADATA_CLASS
  15. versioning_class = api_settings.DEFAULT_VERSIONING_CLASS
  16. 看到以上这些所以的类属性都是可以在自定义类中来重写自定义renderer_class=[...]
  17. 3.这些类属性都是默认的,如果你没有重写这些类属性就默认找api_settings
  18. views.py中导入from rest_framework.settings import APISettings 点击APISettings进行查看,这个配置文件中说如果你设置rest_framework全局的名称空间,你需要到自己的项目中settings配置文件中进行自定义配置,否则就采用默认的
  19. 4.re_path(r'^test/$', views.Test.as_view()),访问路由的as_view(),走的是APIView中的as_view()
  20. 5.APIViewas_wiew()方法返回的是return csrf_exempt(view) 这是禁用csrf,也就是局部禁用csrf,继承APIView视图的类会禁用csrf认证
  21. 6.APIViewview=super().as_view(**initkwargs) 这里调用的super就是APIView父类
  22. 7.先不用点击APIView继承的父类,往上找发现是导包的View from django.views.generic import View
  23. 8.这个View就是视图函数继承的View
  24. from django.views import View 点击View查看,点击进去之后按pycharm的左上角定位到文件,发现就是views文件夹下没有View,所以走的是文件夹下__init__中的__all__=['View']
  25. 这个Viewfrom django.views.genneric.base import View
  26. 9.其实走的还是View中的return self.dispatch(request,*args,**kwargs),先走自定义类中Test中是否重写dispatch方法,没有就走APIView中的dispatch
  27. 10.APIView中根View不一样的地方就是有异常捕获,response = self.handle_exception(exc)这个是自己提供的

请求模块:request对象

源码入口

APIView类的dispatch方法中:request = self.initialize_request(request, *args, **kwargs)

源码分析
  1. """
  2. # 二次封装得到def的request对象
  3. request = self.initialize_request(request, *args, **kwargs) 点进去
  4. # 在rest_framework.request.Request实例化方法中
  5. self._request = request 将原生request作为新request的_request属性
  6. # 在rest_framework.request.Request的__getattr__方法中
  7. try:
  8. return getattr(self._request, attr) # 访问属性完全兼容原生request
  9. except AttributeError:
  10. return self.__getattribute__(attr)
  11. """
  12. 1.入口是从APIView中的dispatch方法中看源码
  13. 2. request = self.initialize_request(request, *args, **kwargs)这是request的二次封装
  14. 3. try:
  15. self.initial(request, *args, **kwargs) #request对象处理完之后,请求之前执行的代码,这个通过了才可以请求,没有通过就是走response
  16. # Get the appropriate handler method
  17. if request.method.lower() in self.http_method_names:#请求
  18. handler = getattr(self, request.method.lower(),
  19. self.http_method_not_allowed)
  20. else:
  21. handler = self.http_method_not_allowed
  22. response = handler(request, *args, **kwargs)
  23. except Exception as exc:
  24. response = self.handle_exception(exc)
  25. self.response = self.finalize_response(request, response, *args, **kwargs)
  26. return self.response
  27. 4.request = self.initialize_request(request, *args, **kwargs)点击initialize_request
  28. parser_context = self.get_parser_context(request)将request传入进行解析数据
  29. 5.
  30. #这个request是导入的from rest_framework.request import Request的类
  31. 这是在实例化
  32. return Request(
  33. request, #传入原生的request
  34. parsers=self.get_parsers(), #self代表视图函数中的自定义类的对象,没有重写的就到APIView中找打,解析数据
  35. authenticators=self.get_authenticators(),
  36. negotiator=self.get_content_negotiator(),
  37. parser_context=parser_context
  38. )
  39. 6.点击Request这个类,__init__先走断言,是否遵守了https协议,遵守了就到self._request = request#这是二次封装request,将原生reqeust作为drf request对象的_request
  40. 7.self.name这是会触发魔法方法__getattr__方法,所以找到Reuqest__getattr__方法
  41. 8.
  42. 继承了APIView request就不是原生django的,而是drfrequest方法,request.属性就会触发(request.user__getattr__
  43. def __getattr__(self, attr):
  44. """
  45. If an attribute does not exist on this instance, then we also attempt
  46. to proxy it to the underlying HttpRequest object.
  47. """
  48. try:
  49. return getattr(self._request, attr) #而这里self._request是原生django的reqeust,在Request类实例化的时候进行赋值的,这里就是完全兼容了原功能,在此基础上再拓展新功能,先在这里面找,找不到去自己的self.__getattribute__(attr)中找
  50. except AttributeError:
  51. return self.__getattribute__(attr)
  52. 9.
  53. views.py中的类
  54. class Test(APIView):
  55. def get(self, request, *args, **kwargs):
  56. return Response('drf get ok') #在这里打断点
  57. 然后postman发送GET http//127.0.0.1:8000/api/test/ 的请求数据
  58. 查看后台debug数据request展开,这里面找到下划线_request就是django原生的WSGIR协议的request
  59. _request中可以找到GET,POST,META
  60. request中找不到GETMETA,但是有data,POSTquery_params
  61. datadjango,res_framework中三种方式提交数据包都会解析到这里来 比如PUTPOST
  62. GET请求的数据会解析到query_params里面
  63. 10.
  64. #三种获取get请求数据的方法
  65. class Test(APIView):
  66. def get(self, request, *args, **kwargs):
  67. # url拼接的参数
  68. print(request._request.GET) # 二次封装方式
  69. print(request.GET) # 兼容
  70. print(request.query_params) # 拓展
  71. return Response('drf get ok')
  72. 11.
  73. postman中发送post请求,使用form_datajsonurlencoded发送新增数据
  74. def post(self, request, *args, **kwargs):
  75. # 所有请求方式携带的数据包
  76. print(request._request.POST) # 二次封装方式,这里只能获取到form_data和urlencoded的数据
  77. print(request.POST) # 兼容,这里也只能获取搭配form_data和urlencoded的数据
  78. print(request.data) # 拓展,兼容性最强,三种数据方式都可以,这里三种请求方式的数据都可以获取的到
  79. print(request.query_params)
  80. return Response('drf post ok')
重点总结
  1. # 1) drf 对原生request做了二次封装,request._request就是原生request
  2. # 2) 原生request对象的属性和方法都可以被drf的request对象直接访问(兼容)
  3. # 3) drf请求的所有url拼接参数均被解析到query_params中,所有数据包数据都被解析到data中
  1. class Test(APIView):
  2. def get(self, request, *args, **kwargs):
  3. # url拼接的参数
  4. print(request._request.GET) # 二次封装方式
  5. print(request.GET) # 兼容
  6. print(request.query_params) # 拓展
  7. return Response('drf get ok')
  8. def post(self, request, *args, **kwargs):
  9. # 所有请求方式携带的数据包
  10. print(request._request.POST) # 二次封装方式
  11. print(request.POST) # 兼容
  12. print(request.data) # 拓展,兼容性最强,三种数据方式都可以
  13. print(request.query_params)
  14. return Response('drf post ok')

渲染模块:浏览器和Postman请求结果渲染数据的方式不一样

源码入口

APIView类的dispatch方法中:self.response = self.finalize_response(request, response, *args, **kwargs)

源码分析
  1. """
  2. self.response = self.finalize_response(request, response, *args, **kwargs)这里点击finalize_response进入
  3. # 最后解析reponse对象数据
  4. self.response = self.finalize_response(request, response, *args, **kwargs) 点进去
  5. # 拿到运行的解析类的对象们
  6. neg = self.perform_content_negotiation(request, force=True) 点进去
  7. # 获得解析类对象
  8. renderers = self.get_renderers() 点进去
  9. # 从视图类中得到renderer_classes请求类,如何实例化一个个对象形参解析类对象列表
  10. return [renderer() for renderer in self.renderer_classes]
  11. # 重点:self.renderer_classes获取renderer_classes的顺序
  12. # 自己视图类的类属性(局部配置) =>
  13. # APIView类的类属性设置 =>
  14. # 自己配置文件的DEFAULT_RENDERER_CLASSES(全局配置) =>
  15. # drf配置文件的DEFAULT_RENDERER_CLASSES
  16. """
全局配置:所有视图类统一处理,在项目的settings.py中
  1. REST_FRAMEWORK = {
  2. # drf提供的渲染类
  3. 'DEFAULT_RENDERER_CLASSES': [
  4. 'rest_framework.renderers.JSONRenderer',
  5. 'rest_framework.renderers.BrowsableAPIRenderer',
  6. ],
  7. }
局部配置:某一个或一些实体类单独处理,在views.py视图类中提供对应的类属性
  1. class Test(APIView):
  2. def get(self, request, *args, **kwargs):
  3. return Response('drf get ok')
  4. def post(self, request, *args, **kwargs):
  5. return Response('drf post ok')
  6. # 在setting.py中配置REST_FRAMEWORK,完成的是全局配置,所有接口统一处理
  7. # 如果只有部分接口特殊化,可以完成 - 局部配置
  8. from rest_framework.renderers import JSONRenderer
  9. class Test2(APIView):
  10. # 局部配置
  11. renderer_classes = [JSONRenderer]
  12. def get(self, request, *args, **kwargs):
  13. return Response('drf get ok 2')
  14. def post(self, request, *args, **kwargs):
  15. return Response('drf post ok 2')

drf 简介以及部分源码分析的更多相关文章

  1. 探索drf执行流程之APIView源码分析

    Django REST framework 简介 现在新一代web应用都开始采用前后端分离的方式来进行,淘汰了以前的服务器端渲染的方式.而实现前后端分离是通过Django REST framework ...

  2. DRF框架(一)——restful接口规范、基于规范下使用原生django接口查询和增加、原生Django CBV请求生命周期源码分析、drf请求生命周期源码分析、请求模块request、渲染模块render

    DRF框架    全称:django-rest framework 知识点 1.接口:什么是接口.restful接口规范 2.CBV生命周期源码 - 基于restful规范下的CBV接口 3.请求组件 ...

  3. drf 视图使用及源码分析

    前言 drf视图的源码非常的绕,但是实现的功能却非常的神奇. 它能够帮你快速的解决ORM增删改查的重复代码,非常的方便好用. 下面是它源码中的一句话: class ViewSetMixin: &quo ...

  4. drf 认证校验及源码分析

    认证校验 认证校验是十分重要的,如用户如果不登陆就不能访问某些接口. 再比如用户不登陆就不能够对一个接口做哪些操作. drf中认证的写法流程如下: 1.写一个类,继承BaseAuthenticatio ...

  5. DRF中的APIView源码分析

    首先写一个简单的drf接口 from rest_framework.views import APIView from rest_framework.response import Response ...

  6. 【死磕 Java 集合】— ConcurrentSkipListMap源码分析

    转自:http://cmsblogs.com/?p=4773 [隐藏目录] 前情提要 简介 存储结构 源码分析 主要内部类 构造方法 添加元素 添加元素举例 删除元素 删除元素举例 查找元素 查找元素 ...

  7. Django drf:认证及组件、token、局部钩子源码分析

    一.drf认证功能 二.token讲解 三.局部钩子源码分析 一.drf认证功能 1.认证简介: 只有认证通过的用户才能访问指定的url地址,比如:查询课程信息,需要登录之后才能查看,没有登录则不能查 ...

  8. Appium Android Bootstrap源码分析之简介

    在上一个系列中我们分析了UiAutomator的核心源码,对UiAutomator是怎么运行的原理有了根本的了解.今天我们会开始另外一个在安卓平台上基于UiAutomator的新起之秀--Appium ...

  9. cvb源码分析,resful规范,drf,drf序列化组件,95

    1 CBV的源码分析 -Class Base View(基于类的视图) -Function Base View(基于函数的视图) -def as_view 类方法 -def view:类方法内部,闭包 ...

随机推荐

  1. Python---10小结

    因一边上班一边自学python,一旦忙起来,python就会放两天,可是2天后之前学的内容就会有点忘记. 今天把python的各种启动方法总结一下; 我的文档路径: ------- 1打开文件所在的c ...

  2. VMware 虚拟机重启后获取不到ip的问题

    问题: VMware 虚拟机重启后获取不到ip,如图: 解决: 打开windows服务管理器,将VMware相关服务启动. 验证: 重启网络服务后,成功获取ip.

  3. SecureCRT语法高亮设置

    因为默认情况下,SecureCRT不能显示语法高亮特性,整个界面颜色单一,看起来不爽,也没有效率,所有通过设置一下语法高亮还是很有必要的, 默认字体也看着不是很清晰,还是更改为我比较喜欢的Courie ...

  4. 【转载】checkbox实现全选/取消全选

    比较简单.好理解的写法,做个备注.查看请前往原地址:http://blog.csdn.net/graceup/article/details/46650781 <html> <bod ...

  5. Hexo+github如何搭建博客

    前言 博客有第三方平台,也可以自建,比较早的有博客园.CSDN,近几年新兴的也比较多诸如:WordPress.segmentFault.简书.掘金.知乎专栏.Github Page 等等. 这次我要说 ...

  6. 从输入URL到页面展示

    当我们输入 URL 并按回车后,浏览器会对 URL 进行检查,首先判断URL格式,比如是ftp http ed2k等等,我们这里假设这个URL是http://hellocassie.cn,那么浏览器会 ...

  7. SAP CRM Transaction处理中的权限控制

    当试图打开一个Opportunity时, 系统会进行如下一系列的权限检查: 1. 检查Authorization object CRM_ORD_OP: 此处会检查当前user的partner func ...

  8. 使用EventBus + Redis发布订阅模式提升业务执行性能(下)

    前言 上一篇博客上已经实现了使用EventBus对具体事件行为的分发处理,某种程度上也算是基于事件驱动思想编程了.但是如上篇博客结尾处一样,我们源码的执行效率依然达不到心里预期.在下单流程里我们明显可 ...

  9. 【django】 接收所有文件,前端展示文件(包括视频,文件,图片)ajax请求

    如果是后台上传文件: setting配置: STATIC_URL = '/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), ...

  10. 整合Kafka+Flink 实例(第二部分 设计思路)

    前     言 拖了蛮久了,一直说要接着上一部分写设计思路以及代码,因为自己技术底子薄弱,加上人又懒,所以一直没能继续,今天补上设计思路及部分代码,后面有时间我会再补充一些应用性的功能,的确有些忙,希 ...