views.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. from django.shortcuts import render, redirect
  2. from django.http import HttpResponse
  3. from django.contrib.auth.models import User
  4. from django.contrib.auth.decorators import login_required
  5. from django.core.paginator import Paginator
  6. from django.db.models import Q
  7. import markdown
  8. from .models import ArticlePost, ArticleColumn
  9. from .form import ArticlePostForm
  10. from comment.models import Comment
  11. # 视图函数
  12. def article_list(request):
  13. search = request.GET.get('search')
  14. order = request.GET.get('order')
  15. if search:
  16. if order == 'total_views':
  17. article_list = ArticlePost.objects.filter(
  18. Q(title__icontains=search) |
  19. Q(body__icontains=search)
  20. ).order_by('-total_views')
  21. else:
  22. article_list = ArticlePost.objects.filter(
  23. Q(title__icontains=search) |
  24. Q(body__icontains=search)
  25. )
  26. else:
  27. search = ''
  28. if order == 'total_views':
  29. article_list = ArticlePost.objects.all().order_by('total_views')
  30. else:
  31. article_list = ArticlePost.objects.all()
  32. paginator = Paginator(article_list, 3)
  33. page = request.GET.get('page')
  34. articles = paginator.get_page(page)
  35. context = {'articles': articles, 'order': order, 'search': search}
  36. return render(request, 'article/list.html', context)
  37. def article_detail(request, id):
  38. articles = ArticlePost.objects.get(id=id)
  39. comments = Comment.objects.filter(article=id)
  40. articles.total_views += 1
  41. articles.save(update_fields=['total_views'])
  42. md = markdown.Markdown(
  43. extensions=[
  44. 'markdown.extensions.extra',
  45. 'markdown.extensions.codehilite',
  46. 'markdown.extensions.toc'
  47. ])
  48. articles.body = md.convert(articles.body)
  49. context = {'article': articles, 'toc': md.toc, 'comments': comments}
  50. return render(request, 'article/detail.html', context)
  51. @login_required(login_url='/user/login/')
  52. def article_create(request):
  53. if request.method == 'POST':
  54. article_post_form = ArticlePostForm(data=request.POST)
  55. # 判断提交的数据是否满足模型要求
  56. if article_post_form.is_valid():
  57. # 保存数据,但是暂时不提交到数据库中
  58. new_article = article_post_form.save(commit=False)
  59. new_article.author = User.objects.get(id=request.user.id)
  60. if request.POST['column'] != 'none':
  61. new_article.column = ArticleColumn.objects.get(id=request.POST['column'])
  62. # 将新文章保存到数据库中
  63. new_article.save()
  64. return redirect("article:article_list")
  65. # 如果数据不合法,返回错误信息
  66. else:
  67. return HttpResponse("表单有错误,请重新填写")
  68. # 如果用户请求获取数据
  69. else:
  70. # 创建表单类实例
  71. article_post_form = ArticlePostForm()
  72. columns = ArticleColumn.objects.all()
  73. context = {'article_post_form': article_post_form, 'columns': columns}
  74. # 返回模板
  75. return render(request, 'article/create.html', context)
  76. def article_delete(request, id):
  77. article = ArticlePost.objects.get(id=id)
  78. article.delete()
  79. return redirect("article:article_list")
  80. @login_required(login_url='/user/login/')
  81. def article_safe_delete(request, id):
  82. if request.method == 'POST':
  83. article = ArticlePost.objects.get(id=id)
  84. if article.author == User.objects.get(id=request.user.id):
  85. article.delete()
  86. return redirect("article:article_list")
  87. else:
  88. return HttpResponse("你无权限进行此操作")
  89. else:
  90. return HttpResponse("仅允许POST请求")
  91. @login_required(login_url='/user/login/')
  92. def article_update(request, id):
  93. article = ArticlePost.objects.get(id=id)
  94. if article.author == User.objects.get(id=request.user.id):
  95. if request.method == 'POST':
  96. article_post_form = ArticlePostForm(data=request.POST)
  97. if article_post_form.is_valid():
  98. article.title = request.POST['title']
  99. article.body = request.POST['body']
  100. if request.POST['column'] != 'none':
  101. article.column = ArticleColumn.objects.get(id=request.POST['column'])
  102. else:
  103. article.column = None
  104. article.save()
  105. return redirect("article:article_detail", id=id)
  106. else:
  107. return HttpResponse("表单内容有误,请重新填写")
  108. else:
  109. article_post_form = ArticlePostForm()
  110. columns = ArticleColumn.objects.all()
  111. context = {'article': article, 'article_post_form': article_post_form, 'columns': columns}
  112. return render(request, 'article/update.html', context)
  113. else:
  114. return HttpResponse("你无权进行此操作")