fail_count = get_from_redis(fail_username)
if fail_count > 3:
if captcha is None:
return error( 需要验证码 )
check_captcha(captcha)
if fail_count > 10:
# 大于10次,使用验证码和密码登录
if dynamic_code is None:
return error( 请输入手机验证码 )
if not validate_dynamic_code(username, dynamic_code):
delete_dynamic_code(username)
return error( 手机验证码错误 )
success = do_login(username, password, dynamic_code)
if not success:
set_redis(fail_username, fail_count + 1)
我们结合了上面说的几种方式的同时,加上了手机验证码的验证模式,基本上可以阻止相当多的一部分恶意攻击者。但是没有系统是绝对安全的,我们只能够尽可能的增加攻击者的攻击成本。大家可以根据自己网站的实际情况来选择合适的策略。 / J# ]$ \' }+ R, E6 n) b# O% e二、中间人攻击 7 c% R3 p4 m/ o) R1 D; D. l& Y' J" H$ i什么是中间人攻击# W) o9 q9 R% Y5 W) G& ^2 C
中间人攻击(man-in-the-middle attack, abbreviated to MITM),简单一点来说就是,A和B在通讯过程中,攻击者通过嗅探、拦截等方式获取或修改A和B的通讯内容。, F3 s# S5 b, Z; o* g( l9 F
举个栗子:小白给小黄发快递,途中要经过快递点A,小黑就躲在快递点A,或者干脆自己开一个快递点B来冒充快递点A。然后偷偷的拆了小白给小黄的快递,看看里面有啥东西。甚至可以把小白的快递给留下来,自己再打包一个一毛一样的箱子发给小黄。 % q8 S' X7 [" Y5 ^/ V. {- Q 那在登录过程中,如果攻击者在嗅探到了从客户端发往服务端的登录请求,就可以很轻易的获取到用户的用户名和密码。4 |6 {4 W2 @7 K6 a6 W) k
HTTPS! B$ q9 T9 j! V1 b9 i
防范中间人攻击最简单也是最有效的一个操作,更换HTTPS,把网站中所有的HTTP请求修改为强制使用HTTPS。 + |. b8 ^+ L& S, J. q& D. A) R为什么HTTPS可以防范中间人攻击?2 m7 Q7 }, y8 T0 N! F& K, R
HTTPS实际上就是在HTTP和TCP协议中间加入了SSL/TLS协议,用于保障数据的安全传输。相比于HTTP,HTTPS主要有以下几个特点: . i) @$ i8 ?6 @" t. O
内容加密
数据完整性" ~2 \5 ]! p' O0 b# a; S2 A
身份验证8 T, K1 i# D) d' }
具体的HTTPS原理这里就不再扩展了,大家可以自行Google/ _9 ]' e K9 ^: s1 c
加密传输- s: Q" P7 f. s) z; p6 w H6 w6 c
在HTTPS之外,我们还可以手动对敏感数据进行加密传输: 7 z3 c; j( Q9 v2 c g7 P3 x