我的网站搭建: (第七天) 简单阅读计数

简介:  如果知道每篇文章的浏览量,管理员就可以了解到访问者对文章的喜好程度,方便后续推出相关内容文章,同时对热门博客的统计和阅读趋势图打好基础。

 如果知道每篇文章的浏览量,管理员就可以了解到访问者对文章的喜好程度,方便后续推出相关内容文章,同时对热门博客的统计和阅读趋势图打好基础。针对阅读统计功能,前前后后我一共想到了三种方法,各种方法都有利有弊。

方法一:采用该模型字段计数

    1.修改Post模型read_num
    2.优化:设置cookie判断是否用户多次点击response.set_cookie()

    优点:简单
    缺点:1.后台编辑博客可能影响数据
               2.功能单一,无法统计某一天的阅读数量

    具体实现:

    1.在Post模型类中直接定义一个read_num的字段名

read_num = models.IntegerField(default=0)

    2.然后可以通过对Post属性read_num的操作来实现阅读计数+1的逻辑处理

post.read_num += 1
    post.save()

方法二:设计功能独立的ReadNum模型数据表

    1.添加read_num字段
    2.增加post外键
    3.利用ReadNum.objects.filter(post=post)来过滤当前的文章计数对象
    4.优化:设置cookie判断是否用户多次点击response.set_cookie()

    具体实现:

    1.在blog/models.py文件中,与定义Post类似,定义一个ReadNum的模型类

class ReadNum(models.Model):
    read_num = models.IntegerField(u'阅读次数', default=0)
    post = models.OneToOneField(Post, on_delete=models.CASCADE)

    def __str__(self):
        return self.read_num

    class Meta:
        verbose_name = '阅读'
        verbose_name_plural = '阅读'

    2.通过objects的filter方法来过滤当前博客是否有阅读的记录,如不存在记录,则创建新的readnum计数对象

if ReadNum.objects.filter(post=post).count():
    # 存在记录
    readnum = ReadNum.objects.get(post=post)
else:
    # 不存在记录
    readnum = ReadNum(post=post)

readnum.read_num += 1
readnum.save()

    3.阅读计数表就算是建好了,还需要将阅读数量加到后台的每篇文章中,在Post模型类中添加该方法

def get_read_num(self):
    try:
        return self.readnum.read_num

    except exceptions.ObjectDoesNotExist:
        return 0

    4.将get_read_num方法添加到admin.py的list_display中

list_display = ('id', 'title', 'created_time', 'modified_time', 'category', 'author', 'get_read_num')

方法三:设计功能独立的计数应用read_statistics

    1.导入两个模块GenericForeignKeyContentType(非常重要)

from django.contrib.contenttypes.fields import GenericForeignKey
from django.contrib.contenttypes.models import ContentType

    2.新增ReadNum模型表,创建read_num这个字段名

from django.db import models
from django.contrib.contenttypes.fields import GenericForeignKey
from django.contrib.contenttypes.models import ContentType

class ReadNum(models.Model):
    """
        单篇博客计数的模型类
        继承model.Model模型类
    """
    read_num = models.IntegerField(u'阅读计数', default=0)

    content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
    object_id = models.PositiveIntegerField()

    # 使用contenttypes模型类来找出关联blog
    content_object = GenericForeignKey('content_type', 'object_id')

    class Meta:
        verbose_name = '阅读计数'
        verbose_name_plural = '阅读计数'
        ordering = ['-read_num']

    3.新增utils.py作为工具包,加入阅读计数+1的逻辑处理

ct = ContentType.objects.get_for_model(obj)
key = "%s_%s_read" % (ct.model, obj.pk)
if not request.COOKIES.get(key):

    '''
    if ReadNum.objects.filter(content_type=ct, object_id=obj.pk).count():
        # 存在记录
        readnum = ReadNum.objects.get(content_type=ct, object_id=obj.pk)
    else:
        # 不存在记录
        readnum = ReadNum(content_type=ct, object_id=obj.pk)
    '''

    readnum, created = ReadNum.objects.get_or_create(content_type=ct, object_id=obj.pk)

    # 计数+1
    readnum.read_num += 1
    readnum.save()

    5.解决后台计数对象没创建时的解决办法,新增一个ReadNumExpandMethod类

class ReadNumExpandMethod(object):
    """
        计数扩展类,此方法放在admin的list_display中
        继承object模型类
    """
    def get_read_num(self):
        ct = ContentType.objects.get_for_model(self)
        # 此处的一个异常处理,用来捕获没有计数对象的情况
        # 例如在admin后台中,没有计数值会显示为‘-’
        try:
            readnum = ReadNum.objects.get(content_type=ct, object_id=self.pk)
            return readnum.read_num
        # 对象不存在就返回0
        except exceptions.ObjectDoesNotExist:
            return 0

    然后让blog/models中的Post模型类继承ReadNumExpandMethod类中的方法

class Post(models.Model, ReadNumExpandMethod):  
    ...

    6.将方法加入到blog/amdin.py中的list_display

list_display = ('id', 'title', 'created_time', 'modified_time', 'category', 'author', 'get_read_num')

    以上就是文章阅读计数的简单方法,这三种方法的共同缺点就是功能单一,无法统计某一天的阅读数量,下一篇内容将对阅读计数内容进行优化,增加日期的阅读量查询

相关文章
|
Oracle 关系型数据库 数据库
oracle exp&imp之IMP-00037: Character set marker unknown
    最近,为地市技术人员做技术支持,碰到一个很奇怪的问题,别人给他提供一个exp的dmp文件,他在本地进行imp的时候报错:IMP-00037:Character set marker unknown 报错信息如下: C:\Users\localadmin>i...
4674 0
|
机器学习/深度学习 人工智能 搜索推荐
AI技术在医疗领域的应用与前景
本文探讨了人工智能(AI)技术在医疗领域的应用,包括疾病诊断、治疗方案制定、药物研发等方面。通过对现有研究成果的梳理,分析了AI技术在提高医疗服务效率、降低医疗成本、改善患者体验等方面的潜力。同时,也指出了AI技术在医疗领域面临的挑战,如数据隐私保护、伦理道德问题等,并展望了未来的发展趋势。
954 2
|
11月前
|
人工智能 资源调度 自然语言处理
《探秘:人工智能算法与鸿蒙Next携手赋能元宇宙高并发用户交互》
在元宇宙的宏大蓝图中,高并发用户交互是实现沉浸式体验的关键。鸿蒙Next通过分布式架构、微内核优化、智能场景感知和ArkTS语言等技术,使人工智能算法能高效适配,实现计算资源的最优利用,支持大规模多人在线游戏、商务会议等场景下的流畅交互,推动元宇宙产业蓬勃发展。
282 17
|
11月前
|
存储 算法 C++
【C++数据结构——查找】二分查找(头歌实践教学平台习题)【合集】
二分查找的基本思想是:每次比较中间元素与目标元素的大小,如果中间元素等于目标元素,则查找成功;顺序表是线性表的一种存储方式,它用一组地址连续的存储单元依次存储线性表中的数据元素,使得逻辑上相邻的元素在物理存储位置上也相邻。第1次比较:查找范围R[0...10],比较元素R[5]:25。第1次比较:查找范围R[0...10],比较元素R[5]:25。第2次比较:查找范围R[0..4],比较元素R[2]:10。第3次比较:查找范围R[3...4],比较元素R[3]:15。,其中是顺序表中元素的个数。
478 68
【C++数据结构——查找】二分查找(头歌实践教学平台习题)【合集】
|
9月前
|
算法 安全 应用服务中间件
云上部署WoSign SSL“国密RSA双证书”,助力国密合规建设
我国网络安全法规体系不断完善,形成了以《网络安全法》为核心的立体化法律框架。阿里云数字证书管理服务提供国产品牌SSL证书,支持签发基于国密算法的SSL/TLS证书,助力金融、政务等行业满足“网络与通信安全”合规需求。通过部署WoSign SSL国密RSA双证书方案,实现国际和国密算法自适应兼容,确保信息系统全球通用性与安全性。2025年3月阿里云“智惠采购季”活动期间,用户可享受SSL证书优惠折扣,助力信息安全建设。
328 2
云上部署WoSign SSL“国密RSA双证书”,助力国密合规建设
|
11月前
|
人工智能 搜索推荐 自动驾驶
如何抓住本世纪伟大成就AI的风口脱颖而出?AI到底会带来什么影响?AI对程序员的影响?AI对软件行业的影响?——2025年如何抓住AI的机会-成为AI工程师-程序员可成为高级AI工程师
如何抓住本世纪伟大成就AI的风口脱颖而出?AI到底会带来什么影响?AI对程序员的影响?AI对软件行业的影响?——2025年如何抓住AI的机会-成为AI工程师-程序员可成为高级AI工程师
749 55
|
9月前
|
域名解析 人工智能 API
学生看过来!白嫖阿里云服务器自建DeepSeek个人网站,3分钟站点上线,超简单!
学生看过来!利用阿里云服务器自建DeepSeek个人网站,3分钟快速上线,超简单!学生用户可领取300元代金券,实现0成本部署;普通用户则可选择99元/年的服务器。通过阿里云计算巢“DeepSeek个人站点-快速部署”服务,无需代码,最快5分钟即可体验多个AI模型。教程详情涵盖从打开部署页面、选择套餐、设置实例密码到获取API-KEY的完整步骤,助你轻松搭建专属AI网站。
465 1
|
12月前
|
数据采集 监控 安全
公司网络监控软件:Zig 语言底层优化保障系统高性能运行
在数字化时代,Zig 语言凭借出色的底层控制能力和高性能特性,为公司网络监控软件的优化提供了有力支持。从数据采集、连接管理到数据分析,Zig 语言确保系统高效稳定运行,精准处理海量网络数据,保障企业信息安全与业务连续性。
217 4
提升个人工作技能
提升个人工作技能
1184 6
|
Python
Matplotlib 安装
Matplotlib 安装
286 3