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

大家有可能在实际开发项目中会遇到这样的情况。实现计数器功能,比如统计网站访问量、用户点击次数等。大家有可能把它放在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的注解
相关推荐
Victor3564 小时前
MongoDB(2)MongoDB与传统关系型数据库的主要区别是什么?
后端
JaguarJack4 小时前
PHP 应用遭遇 DDoS 攻击时会发生什么 从入门到进阶的防护指南
后端·php·服务端
BingoGo4 小时前
PHP 应用遭遇 DDoS 攻击时会发生什么 从入门到进阶的防护指南
后端
Victor3564 小时前
MongoDB(3)什么是文档(Document)?
后端
牛奔6 小时前
Go 如何避免频繁抢占?
开发语言·后端·golang
一只大侠的侠10 小时前
Flutter开源鸿蒙跨平台训练营 Day 10特惠推荐数据的获取与渲染
flutter·开源·harmonyos
想用offer打牌11 小时前
MCP (Model Context Protocol) 技术理解 - 第二篇
后端·aigc·mcp
KYGALYX13 小时前
服务异步通信
开发语言·后端·微服务·ruby
掘了13 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
爬山算法13 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate