CN112883359A - 一种动态验证方法和系统 - Google Patents

一种动态验证方法和系统 Download PDF

Info

Publication number
CN112883359A
CN112883359A CN202110269548.6A CN202110269548A CN112883359A CN 112883359 A CN112883359 A CN 112883359A CN 202110269548 A CN202110269548 A CN 202110269548A CN 112883359 A CN112883359 A CN 112883359A
Authority
CN
China
Prior art keywords
user
verification
code
risk
cosine similarity
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202110269548.6A
Other languages
English (en)
Other versions
CN112883359B (zh
Inventor
闫荣新
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Hebei Wangxin Technology Group Co ltd
Original Assignee
Hebei Yaying Technology Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hebei Yaying Technology Co ltd filed Critical Hebei Yaying Technology Co ltd
Priority to CN202110269548.6A priority Critical patent/CN112883359B/zh
Publication of CN112883359A publication Critical patent/CN112883359A/zh
Application granted granted Critical
Publication of CN112883359B publication Critical patent/CN112883359B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/36User authentication by graphic or iconic representation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F18/00Pattern recognition
    • G06F18/20Analysing
    • G06F18/22Matching criteria, e.g. proximity measures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F18/00Pattern recognition
    • G06F18/20Analysing
    • G06F18/24Classification techniques
    • G06F18/243Classification techniques relating to the number of classes
    • G06F18/24323Tree-organised classifiers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/316User authentication by observing the pattern of computer usage, e.g. typical user behaviour
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/45Structures or tools for the administration of authentication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/60Editing figures and text; Combining figures or text
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2221/00Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/21Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/2133Verifying human interaction, e.g., Captcha

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Computer Hardware Design (AREA)
  • Software Systems (AREA)
  • Evolutionary Computation (AREA)
  • Evolutionary Biology (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Bioinformatics & Computational Biology (AREA)
  • Bioinformatics & Cheminformatics (AREA)
  • Artificial Intelligence (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Social Psychology (AREA)
  • Collating Specific Patterns (AREA)

Abstract

本发明属于信息安全技术领域,公开了一种动态验证方法和系统,包括:接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码;接收用户在输入界面中输入的第一待验码并进行验证;若所述第一待验码验证失败,则结束当前流程;若验证成功,则获取用户在第一验证过程中产生的用户行为信息;其中,用户行为信息包含用户账户信息;调用数据库并根据所述用户行为信息判断用户的风险等级;若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证。本发明能够形成一个区分度高的人机识别系统,最终保障用户用网安全。

Description

一种动态验证方法和系统
技术领域
本发明属于信息安全技术领域,具体涉及一种动态验证方法和系统。
背景技术
随着信息技术的不断发展,用户信息安全越来越受到广泛的关注。目前,为了防止及其快速进行批量自动化操作行为(如暴力尝试密码、刷票等),保护用户账号安全,常用以下技术方案:1、验证码,比如字符型验证码,拼图验证码等;2、动态密码。
但是,在上述技术应用的过程中,出现了如下的问题:1、字符验证码曾经是一种非常有效的对抗自动机的解决方案,在验证码出现的早期,机器根本没有可能识别出验证码里面的字符。然而随着图像识别技术、机器学习技术的迅猛发展,现有的普通字符验证码已经难以抵挡自动机的破解。无论如何对字符做扭曲变形也极大的降低了用户体验,甚至出现自动机可以识别但是用户无法正常识别的情况;2、交互型验证码可以为如拼图验证码、点字验证码等,但目前也已经有人工打码平台支持交互型验证码的验证,也就是说,这种类型的验证码仍存在人工打码的风险;3、动态验证码,通过接收动态验证码生成请求,生成验证码字符和验证码背景,生成多帧图像,进而生成动态验证码。通过此种方式验证时机器仍具有较高的自动识别能力,验证码被破解的风险较高、会降低网络安全性。
因此,现有技术中尚未存在一种安全可靠的验证方法。
发明内容
本发明的目的在于提供一种动态验证方法和系统,用以解决现有技术中的验证方法难以规避机器操作的技术问题。
为了实现上述目的,本发明采用以下的技术方案:
一种动态验证方法,所述方法包括:
接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码;
接收用户在输入界面中输入的第一待验码并进行验证;
若所述第一待验码验证失败,则结束当前流程;若验证成功,则获取用户在第一验证过程中产生的用户行为信息;其中,用户行为信息包含用户账户信息;
调用数据库并根据所述用户行为信息判断用户的风险等级;
若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证。
进一步的,所述中危用户进行二次验证的过程包括:
接收所述中危用户的第二验证请求,响应所述第二验证请求并随机生成第二动态验证码;
接收所述中危用户在输入界面中输入的第二待验码并获取所述第二待验码输入的平均时间间隔;
判断所述第二待验码是否输入正确,若错误则提示验证失败;若正确则进一步判断所述平均时间间隔是否大于系统平均时间间隔阈值,若是则提示验证成功,否则验证失败。
进一步的,所述第一动态验证码和所述第二动态验证码的生成过程均包括:
使用随机字符生成验证码;
根据所述验证码生成基础静态图层;
使用随机字符生成多个干扰图层,将所述多个干扰图层分别与所述基础静态图层合并为多个复合帧;
为得到的多个复合帧预设帧速以生成所述第一动态验证码或第二动态验证码。
进一步的,所述基础静态图层中字符与背景使用对比色,所述验证码的各个字符相互分离。
进一步的,所述数据库的构建过程包括:
分别选取一定数量的真实用户第一样本数据和机器第一样本数据;其中,两种第一样本数据均包括鼠标悬停时间、输入字符时间间隔、响应时间单一用户访问频率以及用户客户端环境信息个数;
其中,客户端环境信息包括:浏览器版本、操作系统版本、屏幕分辨率、I P地址;
将所述真实用户第一样本数据和所述机器第一样本数据作为训练样本,通过决策树算法分别建立真实用户和机器的决策树分类模型;
将所述决策树分类模型存储在所述数据库中。
进一步的,基于所述决策树算法识别为是否为真实用户的过程包括:
采集当前用户的用户行为信息;
调用所述决策树分类模型对所述用户行为信息进行分类,并获得分类结果;
其中,所述分类结果为真实用户或机器。
进一步的,所述数据库的构建过程还包括:
分别选取一定数量的真实用户第二样本数据和机器第二样本数据;其中,两种所述第二样本数据均为鼠标轨迹;
将所述真实用户第二样本数据和所述机器第二样本数据作为训练样本,通过余弦相似度算法分别对第二样本数据进行训练,以获得第一余弦相似度阈值α和第二余弦相似度阈值β;
将所述第一余弦相似度阈值和第二余弦相似度阈值存储在所述数据库中;
其中,余弦相似度的计算公示为:
Figure BDA0002973677270000031
其中,(x1,y1)为鼠标轨迹上的第一向量坐标点;(x1,y1)为鼠标轨迹上的第二向量坐标点;cosθ为第一向量坐标点和第二向量坐标点的相似度值。
进一步的,基于所述余弦相似度算法计算是否为真实用户的过程包括:
采集用户移动鼠标时鼠标轨迹上各点的横坐标x和纵坐标y;
将采集到的多个鼠标轨迹坐标点进行多项式拟合;
通过最高幂次判断多项式是否为一次型多项式,若为一次型,则判定为机器操作;其中,判定为一次型多项式的情形包括:
a)若多项式最高幂次为1,则为一次型多项式,则判定为机器操作;
b)若多项式最高幂次大于1,但大于1的幂次系数之和小于第一余弦相似度阈值α,则表示高幂次系数很小,此时也认为该多项式为一次型多项式,判定为机器操作;
若拟合的多项式不为一次型,则进行余弦相似度判定,判定过程包括:
将采集的坐标点与系统中保存的同一用户的坐标点进行余弦相似度计算,当余弦相似度大于第一余弦相似度阈值β时,则判定该用户为机器模拟的用户,否则为真实用户。
进一步的,所述调用数据库并根据所述用户行为信息判断用户的风险等级包括:
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定均为真实用户时,认为该用户为低危用户;
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定不同时,则认为该用户为中危用户;
当基于所述当所述决策树分类模型和所述余弦相似度算法对该用户的判定均为机器操作时,则认为该用户为高危用户。
第二方面,本发明还提供一种动态验证系统,所述系统包括:
一次验证模块,用于接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码对用户进行第一次验证;
用户行为信息采集模块,用于采集用户在第一次验证过程中产生的用户行为信息;
用户风险等级判断模块,用于调用数据库并根据用户行为信息对用户的风险等级进行判断;
二次验证模块,用户根据用户风险等级的判定结果,对中危用户进行二次验证。
本发明的有益效果为:
1、本发明通过接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码对用户进行第一次验证;并通过获取用户行为信息,调用数据库并根据所述用户行为信息判断用户的风险等级;若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证,能够形成一个区分度高的人机识别系统,最终保障用户用网安全。
2、本发明基于决策树分类模型和余弦相似度算法分别进行真实用户还是机器用户的识别计算,并在两种方式判定均为机器用户时提示验证失败;在两种方式判定均为真实用户时则验证成功,不再二次验证;在两种方式判定结果不同时,判定为中危用户并进行二次验证,能够准确识别真实用户和机器用户,进而有效规避机器扒取用户信息的风险。
3、本发明生成的动态验证码动态变化时,视觉上,验证码精致不动可清楚辨认,干扰图层中的随机字符则不断闪现,干扰图层中的随机字符能够干扰机器破解程序,增加验证码的安全性,同时验证码本身不需要进行干扰处理,验证码辨识度高,方便用户快速识别验证码,提高验证码输入的正确性。
附图说明
图1是本发明实施例中的一种动态验证方法的流程示意图;
图2是本发明实施例中的二次验证过程的流程示意图;
图3是本发明实施例中的动态验证码生成过程的流程示意图;
图4是本发明实施例中的数据库的构建过程的流程示意图;
图5是本发明实施例中基于决策树分类模型和余弦相似度算法识别真实用户的流程示意图;
图6是本发明实施例中的一种动态验证系统的模块示意图。
具体实施方式
为使本说明书实施例的目的、技术方案和优点更加清楚,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本说明书一部分实施例,而不是全部的实施例。基于本说明书中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本说明保护的范围。
应当理解,尽管本文可能使用术语第一、第二等等来描述各种单元,但是这些单元不应当受到这些术语的限制。这些术语仅用于区分一个单元和另一个单元。例如可以将第一单元称作第二单元,并且类似地可以将第二单元称作第一单元,同时不脱离本发明的示例实施例的范围。
应当理解,对于本文中可能出现的术语“和/或”,其仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,单独存在B,同时存在A和B三种情况;对于本文中可能出现的术语“/和”,其是描述另一种关联对象关系,表示可以存在两种关系,例如,A/和B,可以表示:单独存在A,单独存在A和B两种情况;另外,对于本文中可能出现的字符“/”,一般表示前后关联对象是一种“或”关系。
应当理解,在本文中若将单元称作与另一个单元“连接”、“相连”或“耦合”时,它可以与另一个单元直相连接或耦合,或中间单元可以存在。相対地,在本文中若将单元称作与另一个单元“直接相连”或“直接耦合”时,表示不存在中间单元。另外,应当以类似方式来解释用于描述单元之间的关系的其他单词(例如,“在……之间”对“直接在……之间”,“相邻”对“直接相邻”等等)。
应当理解,本文使用的术语仅用于描述特定实施例,并不意在限制本发明的示例实施例。若本文所使用的,单数形式“一”、“一个”以及“该”意在包括复数形式,除非上下文明确指示相反意思。还应当理解,若术语“包括”、“包括了”、“包含”和/或“包含了”在本文中被使用时,指定所声明的特征、整数、步骤、操作、单元和/或组件的存在性,并且不排除一个或多个其他特征、数量、步骤、操作、单元、组件和/或他们的组合存在性或增加。
应当理解,还应当注意到在一些备选实施例中,所出现的功能/动作可能与附图出现的顺序不同。例如,取决于所涉及的功能/动作,实际上可以实质上并发地执行,或者有时可以以相反的顺序来执行连续示出的两个图。
应当理解,在下面的描述中提供了特定的细节,以便于对示例实施例的完全理解。然而,本领域普通技术人员应当理解可以在没有这些特定细节的情况下实现示例实施例。例如可以在框图中示出系统,以避免用不必要的细节来使得示例不清楚。在其他实例中,可以不以不必要的细节来示出众所周知的过程、结构和技术,以避免使得示例实施例不清。
实施例一
参见图1,示出了一种动态验证方法的流程示意图,所述方法包括:
步骤S1:接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码;
在本发明实施例中,用户通过登入网页,输入用户账户信息,然后进一步点击的网页按钮,系统通过接收用户点击网页按钮生成的第一验证请求,生成第一动态验证码。
步骤S2:接收用户在输入界面中输入的第一待验码并进行验证;
步骤S3:若所述第一待验码验证失败,则结束当前流程;若验证成功,则获取用户在第一验证过程中产生的用户行为信息;其中,用户行为信息包含用户账户信息;
步骤S4:调用数据库并根据所述用户行为信息判断用户的风险等级;
步骤S5:若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证。
进一步的,所述中危用户进行二次验证的过程包括:
步骤S51:接收所述中危用户的第二验证请求,响应所述第二验证请求并随机生成第二动态验证码;
步骤S52:接收所述中危用户在输入界面中输入的第二待验码并获取所述第二待验码输入的平均时间间隔;
步骤S53:判断所述第二待验码是否输入正确,若错误则提示验证失败;若正确则进一步判断所述平均时间间隔是否大于系统平均时间间隔阈值,若是则提示验证成功,否则验证失败。
参见图2,所述第一动态验证码和所述第二动态验证码的生成过程均包括:
步骤A:使用随机字符生成验证码;
步骤B:根据所述验证码生成基础静态图层;
步骤C:使用随机字符生成多个干扰图层,将所述多个干扰图层分别与所述基础静态图层合并为多个复合帧;
步骤D:为得到的多个复合帧预设帧速以生成所述第一动态验证码或第二动态验证码。
进一步的,所述基础静态图层中字符与背景使用对比色,所述验证码的各个字符相互分离。
参见图3,所述数据库的构建过程包括:
步骤a:分别选取一定数量的真实用户第一样本数据和机器第一样本数据;其中,两种第一样本数据均包括鼠标悬停时间、输入字符时间间隔、响应时间单一用户访问频率以及用户客户端环境信息个数;
其中,客户端环境信息包括:浏览器版本、操作系统版本、屏幕分辨率、I P地址;
其中,需要说明的是,所述鼠标悬停时间的获取方式为:将鼠标进入“获取验证”按钮的触发区域的时刻记录为t1,将用户点击按钮的时间记录为t2,则鼠标悬停时间=t2-t1
其中,需要说明的是,输入字符时间间隔的获取方式为:用户输入第一待验码或第二待验码时,将第一次按下键盘的时刻记录为t3,将松开键盘的时刻记录为t4,叠加所有字符的输入时间间隔记录为总时间,由此计算平均输入一个字符的时间间隔t5,作为输入字符时间间隔。
其中,需要说明的是,所述响应时间的获取方式为:响应时间是指浏览器页面加载完成时刻t6到用户作出响应时刻t6间所使用的时间,为t7与t6的差值。
其中,需要说明的是,所述单一用户访问频率的获取方式为:单一用户访问频率为单一用户单位时间内(例如以小时为单位)的登录次数。
步骤b:将所述真实用户第一样本数据和所述机器第一样本数据作为训练样本,通过决策树算法分别建立真实用户和机器的决策树分类模型;
步骤c:将所述决策树分类模型存储在所述数据库中。
进一步的,由于在二维空间,通过测量两个向量夹角的余弦值来度量向量间的相似性可以得出两个向量的位置关系,因此,基于余弦相似度算法来构建数据库,所述数据库的构建过程还包括:
步骤d:分别选取一定数量的真实用户第二样本数据和机器第二样本数据;其中,两种所述第二样本数据均为鼠标轨迹;
步骤e:将所述真实用户第二样本数据和所述机器第二样本数据作为训练样本,通过余弦相似度算法分别对第二样本数据进行训练,以获得第一余弦相似度阈值α和第二余弦相似度阈值β;
步骤f:将所述第一余弦相似度阈值和第二余弦相似度阈值存储在所述数据库中;
其中,余弦相似度的计算公示为:
Figure BDA0002973677270000091
其中,(x1,y1)为鼠标轨迹上的第一向量坐标点;(x1,y1)为鼠标轨迹上的第二向量坐标点;cosθ为第一向量坐标点和第二向量坐标点的相似度值。
参见图4,基于所述决策树算法识别为是否为真实用户的过程包括:
步骤(1):采集当前用户的用户行为信息;
步骤(2):调用所述决策树分类模型对所述用户行为信息进行分类,并获得分类结果;
其中,所述分类结果为真实用户或机器。
进一步的,由于真实登录的用户,鼠标轨迹一般不为直线,且两次鼠标轨迹不完全相同,因此基于所述余弦相似度算法计算是否为真实用户的过程包括:
步骤(3):采集用户移动鼠标时鼠标轨迹上各点的横坐标x和纵坐标y;
步骤(4):将采集到的多个鼠标轨迹坐标点进行多项式拟合;
步骤(5):通过最高幂次判断多项式是否为一次型多项式,若为一次型,则判定为机器操作;其中,判定为一次型多项式的情形包括:
a)若多项式最高幂次为1,则为一次型多项式,则判定为机器操作;
b)若多项式最高幂次大于1,但大于1的幂次系数之和小于第一余弦相似度阈值α,则表示高幂次系数很小,此时也认为该多项式为一次型多项式,判定为机器操作;
步骤(6):若拟合的多项式不为一次型,则进行余弦相似度判定,判定过程包括:
将采集的坐标点与系统中保存的同一用户的坐标点进行余弦相似度计算,当余弦相似度大于第一余弦相似度阈值β时,则判定该用户为机器模拟的用户,否则为真实用户。
在本发明实施例中,基于上述,所述调用数据库并根据所述用户行为信息判断用户的风险等级包括:
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定均为真实用户时,认为该用户为低危用户;
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定不同时,则认为该用户为中危用户;
当基于所述当所述决策树分类模型和所述余弦相似度算法对该用户的判定均为机器操作时,则认为该用户为高危用户。
实施例二
第二方面,本发明还提供一种动态验证系统100,所述系统包括:
一次验证模块1,用于接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码对用户进行第一次验证;
用户行为信息采集模块2,用于采集用户在第一次验证过程中产生的用户行为信息;
用户风险等级判断模块3,用于调用数据库并根据用户行为信息对用户的风险等级进行判断;
二次验证模块4,用户根据用户风险等级的判定结果,对中危用户进行二次验证。
本发明实施例的有益效果为:
1、本发明实施例通过接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码对用户进行第一次验证;并通过获取用户行为信息,调用数据库并根据所述用户行为信息判断用户的风险等级;若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证,能够形成一个区分度高的人机识别系统,最终保障用户用网安全。
2、本发明实施例基于决策树分类模型和余弦相似度算法分别进行真实用户还是机器用户的识别计算,并在两种方式判定均为机器用户时提示验证失败;在两种方式判定均为真实用户时则验证成功,不再二次验证;在两种方式判定结果不同时,判定为中危用户并进行二次验证,能够准确识别真实用户和机器用户,进而有效规避机器扒取用户信息的风险。
3、本发明实施例生成的动态验证码动态变化时,视觉上,验证码精致不动可清楚辨认,干扰图层中的随机字符则不断闪现,干扰图层中的随机字符能够干扰机器破解程序,增加验证码的安全性,同时验证码本身不需要进行干扰处理,验证码辨识度高,方便用户快速识别验证码,提高验证码输入的正确性。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型。

Claims (10)

1.一种动态验证方法,其特征在于,所述方法包括:
接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码;
接收用户在输入界面中输入的第一待验码并进行验证;
若所述第一待验码验证失败,则结束当前流程;若验证成功,则获取用户在第一验证过程中产生的用户行为信息;其中,用户行为信息包含用户账户信息;
调用数据库并根据所述用户行为信息判断用户的风险等级;
若用户为低危用户则提示验证通过,若用户为高危用户则提示验证失败,若用户为中危用户则进行二次验证。
2.根据权利要求1所述的动态验证方法,其特征在于,所述中危用户进行二次验证的过程包括:
接收所述中危用户的第二验证请求,响应所述第二验证请求并随机生成第二动态验证码;
接收所述中危用户在输入界面中输入的第二待验码并获取所述第二待验码输入的平均时间间隔;
判断所述第二待验码是否输入正确,若错误则提示验证失败;若正确则进一步判断所述平均时间间隔是否大于系统平均时间间隔阈值,若是则提示验证成功,否则验证失败。
3.根据权利要求2所述的动态验证方法,其特征在于,所述第一动态验证码和所述第二动态验证码的生成过程均包括:
使用随机字符生成验证码;
根据所述验证码生成基础静态图层;
使用随机字符生成多个干扰图层,将所述多个干扰图层分别与所述基础静态图层合并为多个复合帧;
为得到的多个复合帧预设帧速以生成所述第一动态验证码或第二动态验证码。
4.根据权利要求3所述的动态验证方法,其特征在于,所述基础静态图层中字符与背景使用对比色,所述验证码的各个字符相互分离。
5.根据权利要求3所述的动态验证方法,其特征在于,所述数据库的构建过程包括:
分别选取一定数量的真实用户第一样本数据和机器第一样本数据;其中,两种第一样本数据均包括鼠标悬停时间、输入字符时间间隔、响应时间单一用户访问频率以及用户客户端环境信息个数;
其中,客户端环境信息包括:浏览器版本、操作系统版本、屏幕分辨率、IP地址;
将所述真实用户第一样本数据和所述机器第一样本数据作为训练样本,通过决策树算法分别建立真实用户和机器的决策树分类模型;
将所述决策树分类模型存储在所述数据库中。
6.根据权利要求4所述的动态验证方法,其特征在于,基于所述决策树算法识别为是否为真实用户的过程包括:
采集当前用户的用户行为信息;
调用所述决策树分类模型对所述用户行为信息进行分类,并获得分类结果;
其中,所述分类结果为真实用户或机器。
7.根据权利要求5所述的动态验证方法,其特征在于,所述数据库的构建过程还包括:
分别选取一定数量的真实用户第二样本数据和机器第二样本数据;其中,两种所述第二样本数据均为鼠标轨迹;
将所述真实用户第二样本数据和所述机器第二样本数据作为训练样本,通过余弦相似度算法分别对第二样本数据进行训练,以获得第一余弦相似度阈值α和第二余弦相似度阈值β;
将所述第一余弦相似度阈值和第二余弦相似度阈值存储在所述数据库中;
其中,余弦相似度的计算公示为:
Figure FDA0002973677260000031
其中,(x1,y1)为鼠标轨迹上的第一向量坐标点;(x1,y1)为鼠标轨迹上的第二向量坐标点;cosθ为第一向量坐标点和第二向量坐标点的相似度值。
8.根据权利要求6所述的动态验证方法,其特征在于,基于所述余弦相似度算法计算是否为真实用户的过程包括:
采集用户移动鼠标时鼠标轨迹上各点的横坐标x和纵坐标y;
将采集到的多个鼠标轨迹坐标点进行多项式拟合;
通过最高幂次判断多项式是否为一次型多项式,若为一次型,则判定为机器操作;其中,判定为一次型多项式的情形包括:
a)若多项式最高幂次为1,则为一次型多项式,则判定为机器操作;
b)若多项式最高幂次大于1,但大于1的幂次系数之和小于第一余弦相似度阈值α,则表示高幂次系数很小,此时也认为该多项式为一次型多项式,判定为机器操作;
若拟合的多项式不为一次型,则进行余弦相似度判定,判定过程包括:
将采集的坐标点与系统中保存的同一用户的坐标点进行余弦相似度计算,当余弦相似度大于第一余弦相似度阈值β时,则判定该用户为机器模拟的用户,否则为真实用户。
9.根据权利要求7所述的动态验证方法,其特征在于,所述调用数据库并根据所述用户行为信息判断用户的风险等级包括:
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定均为真实用户时,认为该用户为低危用户;
当基于所述决策树分类模型和所述余弦相似度算法对该用户的判定不同时,则认为该用户为中危用户;
当基于所述当所述决策树分类模型和所述余弦相似度算法对该用户的判定均为机器操作时,则认为该用户为高危用户。
10.一种动态验证系统,其特征在于,所述系统包括:
一次验证模块,用于接收用户的第一验证请求,响应所述第一验证请求并随机生成第一动态验证码对用户进行第一次验证;
用户行为信息采集模块,用于采集用户在第一次验证过程中产生的用户行为信息;
用户风险级别判断模块,用于调用数据库并根据用户行为信息对用户的封信等级进行判断;
二次验证模块,用户根据用户风险等级的判定结果,对中危用户进行二次验证。
CN202110269548.6A 2021-03-12 2021-03-12 一种动态验证方法和系统 Active CN112883359B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110269548.6A CN112883359B (zh) 2021-03-12 2021-03-12 一种动态验证方法和系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110269548.6A CN112883359B (zh) 2021-03-12 2021-03-12 一种动态验证方法和系统

Publications (2)

Publication Number Publication Date
CN112883359A true CN112883359A (zh) 2021-06-01
CN112883359B CN112883359B (zh) 2022-10-21

Family

ID=76040958

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110269548.6A Active CN112883359B (zh) 2021-03-12 2021-03-12 一种动态验证方法和系统

Country Status (1)

Country Link
CN (1) CN112883359B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113420276A (zh) * 2021-08-20 2021-09-21 北京顶象技术有限公司 基于验证码的风险确定方法、装置、电子设备和存储介质
CN113521750A (zh) * 2021-07-15 2021-10-22 珠海金山网络游戏科技有限公司 异常账号检测模型训练方法和异常账号检测方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106815515A (zh) * 2016-12-12 2017-06-09 微梦创科网络科技(中国)有限公司 一种基于轨迹验证的验证码实现方法及装置
US20170323093A1 (en) * 2016-05-05 2017-11-09 Baidu Online Network Technology (Beijing) Co., Ltd. Verification method and apparatus for distinguishing man from machine
CN107872438A (zh) * 2016-09-28 2018-04-03 腾讯科技(深圳)有限公司 一种验证方法、装置及终端
CN109600336A (zh) * 2017-09-30 2019-04-09 武汉极意网络科技有限公司 存储设备、验证码应用方法和装置
CN110166250A (zh) * 2019-05-16 2019-08-23 四川长虹电器股份有限公司 一种防暴力破解的验证码交互方法
CN112182221A (zh) * 2020-10-12 2021-01-05 哈尔滨工程大学 一种基于改进随机森林的知识检索优化方法

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20170323093A1 (en) * 2016-05-05 2017-11-09 Baidu Online Network Technology (Beijing) Co., Ltd. Verification method and apparatus for distinguishing man from machine
CN107872438A (zh) * 2016-09-28 2018-04-03 腾讯科技(深圳)有限公司 一种验证方法、装置及终端
CN106815515A (zh) * 2016-12-12 2017-06-09 微梦创科网络科技(中国)有限公司 一种基于轨迹验证的验证码实现方法及装置
CN109600336A (zh) * 2017-09-30 2019-04-09 武汉极意网络科技有限公司 存储设备、验证码应用方法和装置
CN110166250A (zh) * 2019-05-16 2019-08-23 四川长虹电器股份有限公司 一种防暴力破解的验证码交互方法
CN112182221A (zh) * 2020-10-12 2021-01-05 哈尔滨工程大学 一种基于改进随机森林的知识检索优化方法

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113521750A (zh) * 2021-07-15 2021-10-22 珠海金山网络游戏科技有限公司 异常账号检测模型训练方法和异常账号检测方法
CN113521750B (zh) * 2021-07-15 2023-10-24 珠海金山数字网络科技有限公司 异常账号检测模型训练方法和异常账号检测方法
CN113420276A (zh) * 2021-08-20 2021-09-21 北京顶象技术有限公司 基于验证码的风险确定方法、装置、电子设备和存储介质
CN113420276B (zh) * 2021-08-20 2021-11-12 北京顶象技术有限公司 基于验证码的风险确定方法、装置、电子设备和存储介质

Also Published As

Publication number Publication date
CN112883359B (zh) 2022-10-21

Similar Documents

Publication Publication Date Title
Serwadda et al. When kids' toys breach mobile phone security
EP2069993B1 (en) Security system and method for detecting intrusion in a computerized system
CN112883359B (zh) 一种动态验证方法和系统
CN103593609B (zh) 一种可信行为识别的方法和装置
Islam et al. Anomaly detection techniques based on kappa-pruned ensembles
CN109756458B (zh) 身份认证方法和系统
CN106951832A (zh) 一种基于手写字符识别的验证方法及装置
KR102088509B1 (ko) 컴퓨터 시스템의 이상 행위 탐지 방법 및 장치
CN106778151B (zh) 基于笔迹的用户身份识别方法和装置
CN104281795B (zh) 基于鼠标行为的密码容错方法
CN112837069A (zh) 基于区块链与大数据的安全支付方法及云平台系统
CN101261669A (zh) 用鼠标操作的视觉验证码系统的实现方法
Polakis et al. Faces in the distorting mirror: Revisiting photo-based social authentication
CN107358148A (zh) 一种基于手写识别的防作弊网络调研的方法及装置
CN107358088A (zh) 基于时钟的验证方法和系统
CN109299592B (zh) 人机行为特征边界构建方法、系统、服务器及存储介质
Lee et al. Vulnerability analysis challenges of the mouse data based on machine learning for image-based user authentication
CN110263530B (zh) 密码重置请求的鉴别方法与装置
CN111125672A (zh) 一种图像验证码的生成方法及装置
CN112257053B (zh) 一种基于通用对抗扰动的图像验证码生成方法及系统
CN115879083A (zh) 一种智能验证码方法
CN113190310B (zh) 基于随机位置对象语义识别的验证码设计方法
CN105678157B (zh) 一种基于应用环境识别的数据产权保护系统和方法
CN112995128A (zh) 一种基于人工智能的界面信息自动验证组件和方法
AU2017100409A4 (en) Password fault tolerance method based on mouse behaviour

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20230713

Address after: Room 44, Room 401, South Building, Building C08, Entrepreneurship Headquarters Base, North Fuyuan Road, Development Zone, Wuqing District, Tianjin, 300000

Patentee after: Tianjin Online Medical Software Co.,Ltd.

Address before: 050000 Room 201, 99 Industrial Street, circular chemical industry park, Shijiazhuang City, Hebei Province

Patentee before: Hebei YAYING Technology Co.,Ltd.

TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20231221

Address after: 050000 floor 7, administrative service center, northwest corner of the intersection of Alishan street and Xingong Road, circular chemical industry park, Shijiazhuang City, Hebei Province

Patentee after: Hebei Wangxin Technology Group Co.,Ltd.

Address before: Room 44, Room 401, South Building, Building C08, Entrepreneurship Headquarters Base, North Fuyuan Road, Development Zone, Wuqing District, Tianjin, 300000

Patentee before: Tianjin Online Medical Software Co.,Ltd.