springboot反爬蟲組件kk-anti-reptile的使用方法
大家好,我是為廣大程序員兄弟操碎了心的小編,每天推薦一個小工具/源碼,裝滿你的收藏夾,每天分享一個小技巧,讓你輕松節(jié)省開發(fā)效率,實(shí)現(xiàn)不加班不熬夜不掉頭發(fā),是我的目標(biāo)!
今天小編推薦一款反爬蟲組件叫kk-anti-reptile,一款可快速接入的反爬蟲、接口防盜刷spring boot stater組件。
1. 系統(tǒng)要求
- 基于spring-boot開發(fā)(spring-boot1.x, spring-boot2.x均可)
- 需要使用redis
2. 工作流程
kk-anti-reptile使用基于Servlet規(guī)范的的Filter對請求進(jìn)行過濾,在其內(nèi)部通過spring-boot的擴(kuò)展點(diǎn)機(jī)制,實(shí)例化一個Filter,并注入到Spring容器FilterRegistrationBean中,通過Spring注入到Servlet容器中,從而實(shí)現(xiàn)對請求的過濾。
在kk-anti-reptile的過濾Filter內(nèi)部,又通過責(zé)任鏈模式,將各種不同的過濾規(guī)則織入,并提供抽象接口,可由調(diào)用方進(jìn)行規(guī)則擴(kuò)展。
Filter調(diào)用則鏈進(jìn)行請求過濾,如過濾不通過,則攔截請求,返回狀態(tài)碼509,并輸出驗(yàn)證碼輸入頁面,輸出驗(yàn)證碼正確后,調(diào)用過濾規(guī)則鏈對規(guī)則進(jìn)行重置。
目前規(guī)則鏈中有如下兩個規(guī)則
ip-rule
ip-rule通過時間窗口統(tǒng)計當(dāng)前時間窗口內(nèi)請求數(shù),小于規(guī)定的最大請求數(shù)則可通過,否則不通過。時間窗口、最大請求數(shù)、ip白名單等均可配置
ua-rule
ua-rule通過判斷請求攜帶的User-Agent,得到操作系統(tǒng)、設(shè)備信息、瀏覽器信息等,可配置各種維度對請求進(jìn)行過濾
3. 接入使用
后端接入非常簡單,只需要引用kk-anti-reptile的maven依賴,并配置啟用kk-anti-reptile即可。
加入maven依賴
<dependency> <groupId>cn.keking.project</groupId> <artifactId>kk-anti-reptile</artifactId> <version>1.0.0-SNAPSHOT</version> </dependency>
4.配置啟用 kk-anti-reptile
anti.reptile.manager.enabled=true
前端需要在統(tǒng)一發(fā)送請求的ajax處加入攔截,攔截到請求返回狀態(tài)碼509后彈出一個新頁面,并把響應(yīng)內(nèi)容轉(zhuǎn)出到頁面中,然后向頁面中傳入后端接口baseUrl參數(shù)即可,以使用axios請求為例:
import axios from 'axios'; import {baseUrl} from './config'; axios.interceptors.response.use( data => { return data; }, error => { if (error.response.status === 509) { let html = error.response.data; let verifyWindow = window.open("","_blank","height=400,width=560"); verifyWindow.document.write(html); verifyWindow.document.getElementById("baseUrl").value = baseUrl; } } ); export default axios;
5. 注意
apollo-client需啟用bootstrap
使用apollo配置中心的用戶,由于組件內(nèi)部用到@ConditionalOnProperty,要在application.properties/bootstrap.properties中加入如下樣例配置,(apollo-client需要0.10.0及以上版本)
apollo.bootstrap.enabled = true
需要有Redisson連接
如果項(xiàng)目中有用到Redisson,kk-anti-reptile會自動獲取RedissonClient實(shí)例對象; 如果沒用到,需要在配置文件加入如下Redisson連接相關(guān)配置
spring.redisson.address=redis://192.168.1.204:6379 spring.redisson.password=xxx
6.命中規(guī)則后
命中爬蟲和防盜刷規(guī)則后,會阻斷請求,并生成接除阻斷的驗(yàn)證碼,驗(yàn)證碼有多種組合方式,如果客戶端可以正確輸入驗(yàn)證碼,則可以繼續(xù)訪問
7.結(jié)尾
以上就是springboot反爬蟲組件kk-anti-reptile的使用方法的詳細(xì)內(nèi)容,更多關(guān)于springboot反爬蟲組件kk-anti-reptile的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Mybatis不啟動項(xiàng)目直接測試Mapper的實(shí)現(xiàn)方法
在項(xiàng)目開發(fā)中,測試單個Mybatis Mapper方法通常需要啟動整個SpringBoot項(xiàng)目,消耗大量時間,本文介紹通過Main方法和Mybatis配置類,快速測試Mapper功能,無需啟動整個項(xiàng)目,這方法使用AnnotationConfigApplicationContext容器2024-09-09基于Java 生產(chǎn)者消費(fèi)者模式(詳細(xì)分析)
下面小編就為大家分享一篇基于Java 生產(chǎn)者消費(fèi)者模式(詳細(xì)分析),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01關(guān)于注解FeignClient的使用規(guī)范
這篇文章主要介紹了關(guān)于注解FeignClient的使用規(guī)范,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03Java探索之Hibernate主鍵生成策略詳細(xì)介紹
這篇文章主要介紹了Java探索之Hibernate主鍵生成策略詳細(xì)介紹,具有一定參考價值,需要的朋友可以了解下。2017-10-10myeclipse智能提示設(shè)置的實(shí)現(xiàn)方法
本篇文章介紹了,myeclipse智能提示設(shè)置的實(shí)現(xiàn)方法。需要的朋友參考下2013-05-05SpringBoot整合JWT實(shí)戰(zhàn)教程
JWT(JSON?Web?Token)是一種用于身份驗(yàn)證和授權(quán)的開放標(biāo)準(zhǔn)(RFC?7519),它使用JSON格式傳輸信息,可以在不同系統(tǒng)之間安全地傳遞數(shù)據(jù),這篇文章主要介紹了SpringBoot整合JWT實(shí)戰(zhàn)教程,需要的朋友可以參考下2023-06-06Java使用組合模式實(shí)現(xiàn)表示公司組織結(jié)構(gòu)功能示例
這篇文章主要介紹了Java使用組合模式實(shí)現(xiàn)表示公司組織結(jié)構(gòu)功能,簡單描述了組合模式的概念、功能并結(jié)合實(shí)例形式分析了Java使用組合模式實(shí)現(xiàn)公司組織結(jié)構(gòu)表示功能具體操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-05-05