首页 > 技术文章 > Django:restframework与缓存By大熊

daysn 2019-04-30 15:48 原文

http://chibisov.github.io/drf-extensions/docs/#cache-key

以上为drf-ext的文档

 

首先我们要下载两个东西,因为缓存我们用redis所以下

 Django-redis,其次我们下载restframework的拓展
pip install Django-redis
  pip install drf-extensions

settings配置好redis

CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
 "LOCATION": "redis://localhost:6379/1",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
            #"PASSWORD": "mysecret"
        }
    }
}

 

以及拓展

 

一般像官网那样用即可(https://github.com/chibisov/drf-extensions/blob/master/docs/index.md)

从github我们知道两个要求,一个继承于apiview,一个是必须返回Response对象

现在我们有以下用法,我写个例子

#timeout:过期时间       ,cache:setting里面使用哪个缓存   ,key_func:使用下面的key的设置来自己制定key,cache——errors:是否缓存错误的请求,比如说请求401可能会被缓存,待会用户明明都登录了还返回401就不太好了

@cache_response(timeout=60 * 1, cache='default',key_func='calculate_cache_key',cache_errors=False) def get(self,request, *args, **kwargs): ....return Response()对象 #key的设置 def calculate_cache_key(self, view_instance, view_method, request, args, kwargs): id = "app" rtn = '.'.join([ id, "url", request.GET.get("data_app_url",None) ]) return rtn

 

推荐阅读