验证码的三个常见漏洞和修复方法

   2015-07-25 0
核心提示:这篇文章主要介绍了验证码的三个常见漏洞和修复方法,本文讲解了把验证码存储在Cookie中、没有进行非空判断、没有及时销毁验证码三个常见问题和解决方法,需要的朋友可以参考下

把验证码存储在Cookie中

一般来说,我们会把验证码的值用Session存储起来,通过对比用户提交的验证码和Session中的验证码,就可以知道输入是否正确。由于Session会占用服务器资源,我曾经想过是否可以把验证码的值加密后存储在Cookie中。不过事实证明,这只是异想天开罢了。

假设验证码的值是a,通过sha1加密后得到的值为b = sha1(a),并且把b存储在Cookie中。而用户提交的验证码值为c,通过判断sha1(c)是否与b相等,可以知道输入的验证码是否正确。然而,Cookie是受客户端控制的。如果用户事先通过肉眼看到验证码的值是a,又从Cookie中得知此时的加密值为b,那么,他只要在提交前把Cookie的值修改为b,提交的验证码值为a,就可以永远通过验证。

没有进行非空判断

这种情况可以直接用代码来说明:

复制代码 代码如下:

if (Request["captcha"] == Session["captcha"] as string)
{
    // 验证通过,继续操作
}

假设用户绕过了系统提供的表单直接提交数据,此时验证码还没生成,Session["captcha"]为空。用户不提交验证码时,Request["captcha"]也为空。于是,验证通过了。

要解决这个问题,其实只要加个非空判断就可以了:

复制代码 代码如下:

if (!String.IsNullOrEmpty(Request["captcha"]) &&
    Request["captcha"] == Session["captcha"] as string)
{
    // 验证通过,继续操作
}

没有及时销毁验证码

使用验证码要遵循一个原则,在一次比对之后,无论用户输入正确与否,都要立刻将验证码销毁。

如果不这样做,就可以出现以下情况:

假设用户输入错误,且验证码没有重新生成,那么他就可以一直尝试,直到正确为止。虽然机器对图片的一次性识别率比较低,但是,如果同一张图片你给它无限次机会的话,它还是可以识别出来的。
假设用户输入成功,且验证码没有销毁,那么在Session过期之前,他就可以一直用这个验证码通过验证。

 
标签: 验证码 漏洞 修复
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 这个Spring Security登录插件牛啊,验证码、小程序、OAuth2都能快速接入
    这个Spring Security登录插件牛啊,验证码、小
    上次我们把验证码登录、小程序登录优雅地集成到了Spring Security,很多同学大呼过瘾,相比较一些传统玩法高级了很多。胖哥就赶紧抓住机会举一反三,把几个非标准的OAuth2也接入了进来,主要是微信、企业微信,做到应接尽接。只需要通过下面几行简单的代码就
    02-09 java
  • Matlab神经网络验证码识别
    Matlab神经网络验证码识别
    本文,将会简述如何利用Matlab的强大功能,调用神经网络处理验证码的识别问题。 预备知识,Matlab基础编程,神经网络基础。 可以先看下:Matlab基础视频教程Matlab经典教程——从入门到精通神经网络入门验证码识别原理Matlab对图像读入处理,去掉噪声点和较
    02-09
  • ionic typescript--验证码发送倒计时功能
    1.新建页面ionic g page forget 2.mode.html文件ion-itemion-input clearInput [(ngModel)]='code' placeholder='请输入验证码'/ion-inputbutton clear ion-button class="i" item-end (tap)="getCode()" [disabled]="!verifyCode.disable&
    02-09
  • Nodejs简单验证码ccap安装 nodejs生成验证码
    首先要求:  node  npm安装时如果提示npm-gyp失败,可进行如下操作:确认python版本2.7+安装npm install ccap如果失败,尝试npm install ccap@0.5.3
    02-09
  • VB.NET验证码生成代码
    VB.NET验证码生成代码
    前台代码为:    asp:image id="Image2" runat="server" ImageUrl="ValidateCode.aspx"ValidateCode.aspx文件的代码为:        Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase
    02-09
  • 教你用Python实现短信验证码的发送
    教你用Python实现短信验证码的发送
    目录1. 短信API平台2. 使用官方提供的SDK实现短信发送2.1 安装SDK2.2 使用官方的测试用例进行测试2.3 参数及其参数的查看3. 单例模式实现短信发送总结1. 短信API平台使用的短信API平台为:容联云(https://www.yuntongxun.com/)开发者文档:http://doc.yuntong
  • Python使用Cv2模块识别验证码的操作方法
    Python使用Cv2模块识别验证码的操作方法
    目录业务需求需求分析代码一结果分析 代码二代码模块结果呈现总结经验 参考文献业务需求        识别验证码图片中的数字信息,用python的图形表示出来了需求分析        使用Cv2模块、pytesseract模块进行操作。CV2是计算机建模识别的库,
  • asp.net mvc 短信验证码
    asp.net mvc 短信验证码
      把发短信功能写成一个类包,需要引用:SmsUtillity.cs:using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Net;using System.IO;//到吉信通申请试用账号namespace ProcuracyRoom.Dll{public sealed class
    02-09
  • 用C#(asp.net)写出登录验证码! 用chatGPT
    /* Copyright all(c) 2005 ZhongFeng, http://blog.csdn.net/SW515 */ public class ValidateCode : System.Web.UI.Page {  private void Page_Load(object sender, System.EventArgs e)  {   this.CreateCheckCodeImage(GenerateCheckCode());  }
    02-09
  • ASP.net生成各种随机数字,用于优惠券、验证码
    北京网站建设-恒动时空将网上查到的资料收集整理如下:1、利用GUID生成全球唯一标识符,长度为32位,格式如:6F9619FF-8B86-D011-B42D-00C04FC964FF。    SQLSERVER本身可以生成,ASP.NET也可以生成。    最简单的如:GUID guid = Guid.newguid()2、
    02-09
点击排行