一个依赖组件搞定 Spring Boot 反爬虫、接口防盗刷!

接入使用


后端接入非常简单,只需要引用kk-anti-reptile的maven依赖,并配置启用kk-anti-reptile即可

加入maven依赖

cn.keking.project

kk-anti-reptile

1.0.0-SNAPSHOT

配置启用 kk-anti-reptile

anti.reptile.manager.enabled=true

前端需要在统一发送请求的ajax处加入拦截,拦截到请求返回状态码509后弹出一个新页面,并把响应内容转出到页面中,然后向页面中传入后端接口baseUrl参数即可,以使用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;

注意

  1. apollo-client需启用bootstrap

使用apollo配置中心的用户,由于组件内部用到@ConditionalOnProperty,要在application.properties/bootstrap.properties中加入如下样例配置,(apollo-client需要0.10.0及以上版本)详见apollo bootstrap说明

apollo.bootstrap.enabled = true

  1. 需要有Redisson连接

如果项目中有用到Redisson,kk-anti-reptile会自动获取RedissonClient实例对象; 如果没用到,需要在配置文件加入如下Redisson连接相关配置

spring.redisson.address=redis://192.168.1.204:6379

spring.redisson.password=xxx

配置一览表


在spring-boot中,所有配置在配置文件都会有自动提示和说明,如下图

所有配置都以anti.reptile.manager为前缀,如下为所有配置项及说明

| NAME | 描述 | 默认值 | 示例 |

| — | — | — | — |

| enabled | 是否启用反爬虫插件 | true | true |

| include-urls | 需要反爬的接口列表,以’/‘开头,以’,'分隔 | 空 | /client,/user |

| ip-rule.enabled | 是否启用IP Rule | true | true |

| ip-rule.expiration-time | 时间窗口长度(ms) | 5000 | 5000 |

| ip-rule.request-max-size | 单个时间窗口内,最大请求数 | 20 | 20 |

| ip-rule.ignore-ip | IP白名单,支持后缀’*‘通配,以’,'分隔 | 空 | 192.168.*,127.0.0.1 |

| ua-rule.enabled | 是否启用User-Agent Rule | true | true |

| ua-rule.allowed-linux | 是否允许Linux系统访问 | false | false |

| ua-rule.allowed-mobile | 是否允许移动端设备访问 | true | true |

| ua-rule.allowed-pc | 是否允许移PC设备访问 | true | true |

| ua-rule.allowed-iot | 是否允许物联网设备访问 | false | false |

| ua-rule.allowed-proxy | 是否允许代理访问 | false | false |

作者:凯京技术团队

www.oschina.net/p/kk-anti-reptile

往期精选  点击标题可跳转

都 2021 年了,你还在用 Jenkins ?赶快尝试这 13 种替代方案吧!

Spring Framework 使用时常犯的十大错误,切记不要犯!

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

9f49b566129f47b8a67243c1008edf79.png)

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

img
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值