基于注解的 java 加签验签框架 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 引导类
用来创建加签的相关配置及实现。
配置核心方法上述 ISecret/ISort/ICache 都是支持自定义的。
一般只需要重新定义 ISecret 即可。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。