概述:

登录用户就可以查看文章详情,访客就不能查看文章详情并且报错

报错代码如下:

Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
--以上代码基本都是确定访客身份的--
1
next_topic的值是: <QuerySet [<Topic: Topic object (2)>, <Topic: Topic object (3)>]>
Internal Server Error: /v1/topics/qq66907360
Traceback (most recent call last):
File "D:\Program Files (x86)\Python\Python310\lib\site-packages\django\core\handlers\exception.py", line 47, in inner
response = get_response(request)
File "D:\Program Files (x86)\Python\Python310\lib\site-packages\django\core\handlers\base.py", line 181, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "D:\Program Files (x86)\Python\Python310\lib\site-packages\django\views\generic\base.py", line 69, in view
return self.dispatch(request, *args, **kwargs)
File "D:\Program Files (x86)\Python\Python310\lib\site-packages\django\views\generic\base.py", line 101, in dispatch
return handler(request, *args, **kwargs)
File "D:\PycharmProjects\linuxTangblog\topic\views.py", line 151, in get
res = self.make_topic_res(author,author_topic,is_self)
File "D:\PycharmProjects\linuxTangblog\topic\views.py", line 29, innext_id = next_topic.id if next_topic else None
AttributeError: 'QuerySet' object has no attribute 'id'
[17/Dec/2021 15:02:20] "GET /v1/topics/qq66907360?t_id=1 HTTP/1.1"

排查过程:

我遍历了一下'QuerySet'对象,发现遍历后的数据是object对象,然后再用object取值就把值取出来了,

next_topic的值是: <QuerySet [<Topic: Topic object (2)>, <Topic: Topic object (3)>]>
next_topic = Topic.objects.filter(id__gt=author_topic.id,author=author,limit='public')
for i in next_topic:
print(i.id)

然后我就想,上一篇和和下一篇只要一个值,但是显然这个queryset对象有多个值,不符合预期,然后就看代码发现没有写first()或last()这个条件

if is_self:
#下一篇
next_topic = Topic.objects.filter(id__gt=author_topic.id,author=author).first()
#上一篇
last_topic = Topic.objects.filter(id__lt=author_topic.id,author=author).last()
else:
next_topic = Topic.objects.filter(id__gt=author_topic.id,author=author,limit='public')
last_topic = Topic.objects.filter(id__lt=author_topic.id,author=author,limit='public')

解决办法:

加上first()或last()这个条件

if is_self:
#下一篇
next_topic = Topic.objects.filter(id__gt=author_topic.id,author=author).first()
#上一篇
last_topic = Topic.objects.filter(id__lt=author_topic.id,author=author).last()
else:
next_topic = Topic.objects.filter(id__gt=author_topic.id,author=author,limit='public').first()
last_topic = Topic.objects.filter(id__lt=author_topic.id,author=author,limit='public').last()