亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于注解的 java 加簽驗簽框架 checksum

發布時間:2020-06-19 01:04:44 來源:網絡 閱讀:138025 作者:葉止水ryo 欄目:編程語言

checksum

基于 java 注解生成加簽驗簽 checksum。

開源地址:github checksum

創作緣由

原來的代碼中,checksum 的生成是用的工具類方法。

后來發現如下的問題:

  1. 有些字段太大,不想參與驗簽,但是無法方便的調整。

  2. 不同系統的 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 即可。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

辛集市| 石首市| 湘阴县| 札达县| 阳曲县| 平顶山市| 邵阳市| 四会市| 孟连| 汤原县| 同心县| 中牟县| 阳春市| 内江市| 宁陕县| 永善县| 大化| 吴堡县| 甘孜县| 金阳县| 监利县| 苍溪县| 靖安县| 象山县| 台南市| 潜江市| 博爱县| 科技| 仁寿县| 高安市| 博湖县| 宁都县| 西乌| 安图县| 大英县| 曲周县| 孟津县| 靖西县| 运城市| 海盐县| 佛山市|