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