您好,登錄后才能下訂單哦!
這篇文章主要介紹了resubmit漸進式防重復提交框架怎么使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇resubmit漸進式防重復提交框架怎么使用文章都會有所收獲,下面我們一起來看看吧。
resubmit 是一款為 java 設計的漸進式防止重復提交框架。
推薦閱讀:
面試官:你們的項目中是怎么做防止重復提交的?
有時候手動加防止重復提交很麻煩,每次手動編寫不利于復用。
所以希望從從簡到繁實現一個工具,便于平時使用。
漸進式實現,可獨立 spring 使用
基于注解+字節碼,配置靈活
支持編程式的調用
支持注解式,完美整合 spring
支持整合 spring-boot
變更日志
<dependency> <group>com.github.houbb</group> <artifact>resubmit-core</artifact> <version>1.0.0</version> </dependency>
UserService.java
@Resubmit
對應的屬性如下:
屬性 | 說明 | 默認值 |
---|---|---|
value() | 多久內禁止重復提交,單位為毫秒。 | 60000 |
@Resubmit(5000) public void queryInfo(final String id) { System.out.println("query info: " + id); }
測試代碼
如果在指定時間差內,重復請求,則會拋出異常 ResubmitException
@Test(expected = ResubmitException.class) public void errorTest() { UserService service = ResubmitProxy.getProxy(new UserService()); service.queryInfo("1"); service.queryInfo("1"); }
相同的參數直接提交2次,就會報錯。
測試場景2
如果等待超過指定的 5s,就不會報錯。
@Test public void untilTtlTest() { UserService service = ResubmitProxy.getProxy(new UserService()); service.queryInfo("1"); DateUtil.sleep(TimeUnit.SECONDS, 6); service.queryInfo("1"); }
ResubmitProxy.getProxy(new UserService());
可以獲取 UserService 對應的代理。
等價于:
ResubmitBs resubmitBs = ResubmitBs.newInstance() .cache(new CommonCacheServiceMap()) .keyGenerator(new KeyGenerator()) .tokenGenerator(new HttpServletRequestTokenGenerator()); UserService service = ResubmitProxy.getProxy(new UserService(), resubmitBs);
其中 ResubmitBs 作為引導類,對應的策略都支持自定義。
屬性 | 說明 | 默認值 |
---|---|---|
cache() | 緩存實現策略 | 默認為基于 ConcurrentHashMap 實現的基于內存的緩存實現 |
keyGenerator() | key 實現策略,用于唯一標識一個方法+參數,判斷是否為相同的提交 | md5 策略 |
tokenGenerator() | token 實現策略,用于唯一標識一個用戶。 | 從 HttpServletRequest 中的 header 屬性 resubmit_token 中獲取 |
<dependency> <group>com.github.houbb</group> <artifact>resubmit-spring</artifact> <version>1.0.0</version> </dependency>
代碼編寫
UserService.java
@Service public class UserService { @Resubmit(5000) public void queryInfo(final String id) { System.out.println("query info: " + id); } }
SpringConfig.java
@ComponentScan("com.github.houbb.resubmit.test.service") @EnableResubmit @Configuration public class SpringConfig { }
@EnableResubmit
中用戶可以指定對應的實現策略,便于更加靈活的適應業務場景。
和 ResubmitBs
中支持自定義的屬性一一對應。
屬性 | 說明 | 默認值 |
---|---|---|
cache() | 緩存實現策略 | 默認為基于 ConcurrentHashMap 實現的基于內存的緩存實現 |
keyGenerator() | key 實現策略,用于唯一標識一個方法+參數,判斷是否為相同的提交 | md5 策略 |
tokenGenerator() | token 實現策略,用于唯一標識一個用戶。 | 從 HttpServletRequest 中的 header 屬性 resubmit_token 中獲取 |
@ContextConfiguration(classes = SpringConfig.class) @RunWith(SpringJUnit4ClassRunner.class) public class ResubmitSpringTest { @Autowired private UserService service; @Test(expected = ResubmitException.class) public void queryTest() { service.queryInfo("1"); service.queryInfo("1"); } }
<dependency> <groupId>com.github.houbb</groupId> <artifactId>resubmit-springboot-starter</artifactId> <version>1.0.0</version> </dependency>
UserService.java
這個方法實現和前面的一樣。
@Service public class UserService { @Resubmit(5000) public void queryInfo(final String id) { System.out.println("query info: " + id); } }
Application.java
啟動入口
@SpringBootApplication public class ResubmitApplication { public static void main(String[] args) { SpringApplication.run(ResubmitApplication.class, args); } }
@ContextConfiguration(classes = ResubmitApplication.class) @RunWith(SpringJUnit4ClassRunner.class) public class ResubmitSpringBootStarterTest { @Autowired private UserService service; @Test(expected = ResubmitException.class) public void queryTest() { service.queryInfo("1"); service.queryInfo("1"); } }
上面提到 @EnableResubmit
中的策略支持自定義。
此處僅以 cache 為例,為了簡單,默認是基于本地內存的緩存實現。
如果你不是單點應用,那么基于 redis 的緩存更加合適
實現緩存
只需要實現 ICommonCacheService
接口即可。
public class MyDefineCache extends CommonCacheServiceMap { // 這里只是作為演示,實際生產建議使用 redis 作為統一緩存 @Override public synchronized void set(String key, String value, long expireMills) { System.out.println("------------- 自定義的設置實現"); super.set(key, value, expireMills); } }
在非 spring 項目中,可以在引導類中指定我們定義的緩存。
ResubmitBs resubmitBs = ResubmitBs.newInstance() .cache(new MyDefineCache()); UserService service = ResubmitProxy.getProxy(new UserService(), resubmitBs);
其他使用方式保持不變。
在 spring 項目中,我們需要調整一下配置,其他不變。
@ComponentScan("com.github.houbb.resubmit.test.service") @Configuration @EnableResubmit(cache = "myDefineCache") public class SpringDefineConfig { @Bean("myDefineCache") public ICommonCacheService myDefineCache() { return new MyDefineCache(); } }
@EnableResubmit(cache = "myDefineCache") 指定我們自定義的緩存策略名稱。
關于“resubmit漸進式防重復提交框架怎么使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“resubmit漸進式防重復提交框架怎么使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。