如何限制对媒体图像url访问,并使其只能由django中的访问所有者用户访问,
下面是我的类模型:
class private_image(models.Model):
i_user = models.OneToOneField(User, related_name='related_PRF_user', on_delete=models.CASCADE)
i_image= models.ImageField(upload_to='images', blank=True, null=True )
我的媒体设置是:
MEDIA_ROOT = os.path.join(BASE_DIR, 'media_root/')
MEDIA_URL = '/media_url/'
例如:我不希望用户把这样的图像URL“http://127.0.0.1:8000/media_url/images/67155_0_AVemgEZ.jpg“在他们的浏览器和打开图像,如果请求用户不相同的所有者用户.
我相信,我可以做一个小函数来检查访问用户和请求的URL '/media_url/images/'来获取图像名称,然后使用图像名称从数据库中获取对象,然后检查所有者(i_user)是否相同访问用户。
但是我如何告诉Django在请求MEDIA_URL之前使用这个函数呢?
如果你有一个例子,那将是非常有帮助。
先谢谢你了
1条答案
按热度按时间6ie5vjzr1#
media的所有
requests
都应通过特定视图。myproject/urls.py:
添加视图并检查访问权限。
myproject/views.py:
请告诉我这是否有效。