内容简介:基于 java 注解生成加签验签 checksum。开源地址:原来的代码中,checksum 的生成是用的工具类方法。
checksum
基于 java 注解生成加签验签 checksum。
开源地址: github checksum
创作缘由
原来的代码中,checksum 的生成是用的 工具 类方法。
后来发现如下的问题:
- 有些字段太大,不想参与验签,但是无法方便的调整。
- 不同系统的 checksum 字段不同,只好把工具方法 copy 过去,改来改去。
感觉这样有很大的弊端,完全失去了灵活性。
特性
- 基于注解的 checksum 加签验签
- Fluent 流式语法
- 支持灵活的策略自定义
更新记录
快速开始
环境要求
jdk7+
maven 3.x+
引入
<dependency> <groupId>com.github.houbb</groupId> <artifactId>checksum</artifactId> <version>0.0.1</version> </dependency>
定义待加签的示例对象
- User.java
public class User { @CheckField private String name; @CheckField private String password; private String address; @Checksum private String checksum; //Getter & Setter //toString() }
核心注解
@CheckField
表示参与加签的字段信息
@Checksum
表示加签结果存放的字段
调用测试
package com.github.houbb.checksum.core; import com.github.houbb.checksum.model.User; import org.junit.Assert; import org.junit.Test; /** * @author binbin.hou * @since 0.0.1 */ public class ChecksumBsTest { @Test public void checksumTest() { User user = buildUser(); final String checksum = ChecksumBs .newInstance(user) .checksum(); Assert.assertEquals("8D62F2BC49A9AB51280C8F42A483ED54", checksum); } @Test public void fillTest() { User user = buildUser(); ChecksumBs.newInstance(user).fill(); Assert.assertEquals("User{name='ryo', password='1234', address='china', checksum='8D62F2BC49A9AB51280C8F42A483ED54'}", user.toString()); } /** * 构建示例对象 * @return 构建示例对象 */ private User buildUser() { User user = new User(); user.name("ryo") .password("1234") .address("china"); return user; } }
ChecksumBs 引导类
用来创建加签的相关配置及实现。
配置核心方法
方法 | 默认值 | 备注 |
---|---|---|
newInstance() | 新建 ChecksumBs 实例(static) | |
newInstance(object) | 新建 ChecksumBs 实例,并且指定待加签的对象(static,建议使用) | |
target(Object) | 指定待加签的对象 | |
secret(ISecret) | DefaultMd5Secret | 指定加密的策略,默认使用 md5 加密 |
sort(ISort) | NameAscSort | 指定 排序 的策略,默认根据字段的名称正序排列表 |
cache(ICache) | DefaultFieldListCache | 指定字段的缓存策略,默认使用本地 map 进行字段信息缓存 |
调用核心方法
方法 | 返回值 | 备注 |
---|---|---|
checksum() | String | 返回加签的结果 |
fill() | 无 | 将上面 checksum 的结果设置到 @Checksum 标识的字段中 |
自定义
上述 ISecret/ISort/ICache 都是支持自定义的。
一般只需要重新定义 ISecret 即可。
以上所述就是小编给大家介绍的《基于注解的 java 加签验签框架 checksum》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 框架基础:深入理解Java注解类型(@Annotation)
- Java持久层框架MyBatis全注解详解
- 【剖析 | SOFARPC 框架】系列之 SOFARPC 注解支持剖析
- 基于注解的6.0权限动态请求框架——JPermission
- Erupt 1.6.1 发布,全注解式开发,通用后台管理框架,提供全栈注解级解决方案
- Git 项目推荐 | ECharts 的 Java 注解框架
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Ajax开发精要
柯自聪 / 电子工业出版社 / 2006 / 45.00
书籍目录: 概念篇 第1章 Ajax介绍 2 1.1 Ajax的由来 2 1.2 Ajax的定义 3 1.3 Web应用程序的解决方案 5 1.4 Ajax的工作方式 7 1.5 小结 8 第2章 B/S请求响应机制与Web开发模式 9 2.1 HTTP请求响应模型 9 2.2 B/S架构的请求响应机......一起来看看 《Ajax开发精要》 这本书的介绍吧!