我开发了一款只用一个注解就实现统计访问量的工具框架

大家有可能在实际开发项目中会遇到这样的情况。实现计数器功能,比如统计网站访问量、用户点击次数等。大家有可能把它放在redis里面,也有可能把它放在MYSQL里面。但是这样大家都需要动手实现很多的代码。繁琐而复杂。于是我就想在 simple-cache框架中发布一个新的注解。用于实现上面这样的功能。所以这次1.5.0更新给大家带来了两个注解。

这次V1.5.0主要更新的内容为:

  • @RedisCount 增加访问数
  • @RedisGetCount获取访问的值

simple-cache-spring-boot-starter

请使用1.5.0版本

java 复制代码
	    <dependency>
            <groupId>io.gitee.antopen</groupId>
            <artifactId>simple-cache-spring-boot-starter</artifactId>
            <version>1.5.0</version>
        </dependency>

准备条件在博主的上一篇文章上门已经讲的很详细了,这次就不做讲解,只讲新功能

【simple-cache】一款只用一个注解就实现缓存的框架-我们终于迎来了SpringBoot版本

直接在bean类的方法中添加@RedisCount @RedisGetCount注解即可。

说明:

@RedisCount 可选值

属性 类型 必须指定 默认值 描述
value string 记录key的名称,可以自定义
delta long 每调用一次方法加的步数,例如填2就是每访问一次就加2

@RedisGetCount 可选值

属性 类型 必须指定 默认值 描述
value string 记录key的名称,可以自定义

使用RedisCount注解

java 复制代码
    @RedisCount(value = "testCount", delta = 1L)
    public void testCount() {
        System.out.println("进入testCount方法了");
    }

这个加步数的方法会在方法里面所有的步骤都执行完成之后再执行。如果里面有报错,则不会执行。所以如果想确保增加部署成功,那必须要保证方法里面不会抛出错误,不会抛出异常。例如增加了这个方法,那么redis里面就会多一个以testCount为命名的一个key Value。

初始值都是零,但是我们访问一次过后就会增加为一。它的步数根据上面的delta 去配置,如果配置2的话则加2,3的话再加3。

使用RedisCount注解EL表达式

java 复制代码
@RedisCount(value = "#id", delta = 1L)
public void testCountEl(Integer id) {
    System.out.println("进入testCount方法了");
}

为了保持我们优良的传统,这次的RedisCount和RedisGetCount也支持el表达式。需要注意的是EL表达式里面的值要跟入参的入参名字是一样的。否则就不能绑定。例如上面的入场名字叫id,那么el表达式里面它的值应该也是id。

例如上面我们如果入仓的值是一的话,我们对应的radius里面也会增加一个1的value的值。你就说1作为这个值的key,当然,这里只是做一个举例。可以传入任何基本类型的包装类和String类。

使用RedisGetCount注解

由于上面我们已经在里面存了对应的key value值。所以说这个时候我们如果需要统计的话,也就是说在页面需要展示的话,我们就可以直接使用这个注解。在一个默认的方法上,这个方法上并不需要写很复杂的逻辑,它只是返回一个默认的值就行。

java 复制代码
    @RedisGetCount("testCount")
    public Long getCount() {
        return 0L;
    }

在调用这个方法的时候,我们就可以获得它里面对应的值及访问量。

使用RedisGetCount注解EL表达式

java 复制代码
    @RedisGetCount(value = "#id")
    public Long testgetcountel(Integer id) {
        return 0L;
    }

同样我们在这个注解中也加入了EL表达式。要以#开头,值和入参名字一样即可,可参考上面的代码实现,上面就是把1作为唯一id作为key的名称。

如果有建议欢迎提出

如果你也想为开源贡献自己的力量,欢迎加入蚂蚁开源

使用simple-cache的springboot版本也十分简单,只需要:

  1. 引入simple-cache-spring-boot-starter依赖;
  2. 在启动类加上EnableSimpleCache注解;
  3. 在配置文件中填写属于你自己项目的redistemplate的bean的名称;
  4. 在你的业务类方法上添加simple-cache的注解
相关推荐
henujolly8 小时前
go学习day two
后端
AI袋鼠帝8 小时前
腾讯这只小程序Agent🦀,帮我找到了最强日程、文件、知识管理姿势
后端
努力的小郑8 小时前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
HashTang9 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
thatway19899 小时前
ARM TFM-1介绍及代码下载运行适配
后端
千寻girling10 小时前
不知道 Java 全栈 + AI 编程有没有搞头 ?
前端·人工智能·后端
小码哥_常10 小时前
Spring Boot 实现网络限速:让流量“收放自如”
后端
冬奇Lab11 小时前
一天一个开源项目(第60篇):IndexTTS - B 站开源的工业级零样本语音合成系统
人工智能·开源·资讯
johnrui11 小时前
SpringBoot-JdbcTemplate
java·spring boot·后端
Victor35612 小时前
MongoDB(72)如何创建用户和角色?
后端