短信验证码防止盗刷的问题

使用场景
  • 随着互联网的发展,短信验证已经被广泛使用,那么问题也随之而来,主要体现就在于短信轰炸,短信轰炸软件调用了向指定用户发送验证码的接口,实现对攻击目标进行短信轰炸骚扰的目的;那么问题来了,短信轰炸软件的接口哪里来的?很显然,不会是软件制作者自己掏钱买的,一般都是盗取各种企业短信发送服务的接口来实现的。
如何防止?
  • 对手机号、IP、设备做一定的限制
  • 加密自己的短信验证码发送接口,尽量防止被别人拿到
  • 学习企鹅,直接让用户自己发短信
  • 增加一个授权过程
方法
  • 第一种方法是常规,有些短信服务器商已经提供了这些服务
  • 第二种方法其实属于然并卵,接口总是会暴露的
  • 第三种开玩笑?你让用户自己发看!
重点讲第三种

从简单的说就是在发送短信给用户之前,我们先做一套验证,如果验证通过了,再给用户发送短信,这种办法的好处是,你的请求短信的接口被别人知道了,别人还得验证一次才能成功发送短信,增加了复杂度。

大概流程图

简单说下流程:
  1. 第一步在client端进入发送短信的页面请求第一个步骤,获取一个验证码,这个验证码在服务器上生成,并且存到Redis等缓存服务器中,用于下次请求短信时的校验。
  2. 第二步用户填写服务器返回的验证码并带着验证码请求服务器,服务器拿着用户提交过来的验证码到缓存服务器去验证,看看验证码是否存在,如果存在就生成一个短信验证码,分别存储到本地数据库,以及调用第三方短信发送接口,向用户发送短信。
  3. 第三步用户---收到短信---输入短信码---提交
问题:
  • 问:别人就不能拿到你获取验证码的接口,请求了验证码,再用验证码去发短信吗?

答:生成验证码后,服务器把验证码转换成图片发回前台。

方便与安全:
  • 很多情况下根据场景的不同,短信验证的需求也各不相同,比如说登录或者注册的时候,验证码需要可以被多次使用,而且时效需求要高一点,又比如银行支付等场景必须保证验证短信只能使用一次,时效无需太高。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 14,004评论 6 13
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,006评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,492评论 11 349
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,042评论 25 709
  • 什么是股权代持? 股权代持是指实际投资者(又称隐名股东)向有限公司或股份有限公司出资,但不以自己的名义作为该公司的...
    tsglxy阅读 3,579评论 0 0

友情链接更多精彩内容