兑换码兑换请求校验方法、装置、设备和计算机可读介质
技术领域
本公开的实施例涉及计算机技术领域,具体涉及兑换码兑换请求校验方法、装置、设备和计算机可读介质。
背景技术
兑换码在生成后无法立即与特定的用户进行绑定,因此,在生成后存在着被盗刷兑换的可能性。现有的兑换码兑换请求校验方法往往是直接在数据中查找与兑换码兑换请求相关的数据,造成了对数据库中数据的频繁读取,增加了时间和内存资源的消耗。且现有方法往往是从兑换码兑换请求的总体数量上进行限流,较难从用户维度上对兑换码兑换请求进行限流,难以避免某些用户频繁的进行兑换码兑换对服务器资源的过多占用。
发明内容
本公开的内容部分用于以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。本公开的内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。本公开的一些实施例提出了兑换码兑换请求校验方法、装置、设备和计算机可读介质,来解决以上背景技术部分提到的技术问题。
第一方面,本公开的一些实施例提供了一种兑换码兑换请求校验方法,该方法包括:根据全局配置信息对兑换码兑换请求进行全局校验,其中,上述兑换码兑换请求包括:兑换码字符;响应于确定上述兑换码兑换请求未通过上述全局校验,对上述兑换码兑换请求进行黑名单校验;响应于确定上述兑换码兑换请求通过上述黑名单校验,基于上述兑换码字符对上述兑换码兑换请求进行合法性校验;响应于确定上述兑换码兑换请求通过上述合法性校验,执行上述兑换码兑换请求对应的兑换业务操作。
可选的,在上述响应于确定上述兑换码兑换请求通过上述合法性校验,执行上述兑换码兑换请求对应的兑换业务操作之前,上述方法还包括:响应于确定上述兑换码兑换请求通过上述全局校验,对上述兑换码兑换请求进行上述合法性校验。
可选的,上述全局配置信息包括:全局开关标识值,白名单用户标识码集合,上述兑换码兑换请求还包括:用户标识码;以及上述根据全局配置信息对兑换码兑换请求进行全局校验,包括:响应于确定上述全局开关标识值表征全局开关为开或上述白名单用户标识码集合中包括上述用户标识码,确定上述兑换码兑换请求通过上述全局校验。
可选的,上述根据全局配置信息对兑换码兑换请求进行全局校验,包括:响应于确定上述全局开关标识值表征全局开关为关或上述白名单用户标识码集合中不包括上述用户标识码,确定上述兑换码兑换请求未通过上述全局校验。
可选的,上述对上述兑换码兑换请求进行黑名单校验,包括:获取黑名单用户标识码集合;响应于确定上述黑名单用户标识码集合中不包括上述用户标识码,确定上述用户标识码对应的兑换码兑换请求次数;响应于确定上述兑换码兑换请求次数不满足预设条件,将上述用户标识码作为黑名单用户标识码加入上述黑名单用户标识码集合中以及确定上述兑换码兑换请求未通过上述黑名单校验。
可选的,上述对上述兑换码兑换请求进行黑名单校验,包括:响应于确定上述兑换码兑换请求次数满足预设条件,确定上述兑换码兑换请求通过上述黑名单校验。
可选的,上述基于上述兑换码字符对上述兑换码兑换请求进行合法性校验,包括:确定上述兑换码字符是否存在于合法兑换码字符集合中;响应于确定上述兑换码字符存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求通过上述合法性校验。
可选的,上述基于上述兑换码字符对上述兑换码兑换请求进行合法性校验,包括:响应于确定上述兑换码字符不存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求未通过上述合法性校验。
可选的,上述执行上述兑换码兑换请求对应的兑换业务操作,包括:响应于确定缓存数据中存在与上述兑换码字符对应的业务数据,根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作。
可选的,上述执行上述兑换码兑换请求对应的兑换业务操作,包括:响应于确定上述缓存数据中不存在与上述兑换码字符对应的业务数据,从关系型数据库中获取上述业务数据;根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作;将上述业务数据写入上述缓存数据中。
第二方面,本公开的一些实施例提供了一种兑换码兑换请求校验装置,装置包括:全局校验单元,被配置成根据全局配置信息对兑换码兑换请求进行全局校验,其中,上述兑换码兑换请求包括:兑换码字符;黑名单校验单元,被配置成响应于确定上述兑换码兑换请求未通过上述全局校验,对上述兑换码兑换请求进行黑名单校验;合法性校验单元,被配置成响应于确定上述兑换码兑换请求通过上述黑名单校验,基于上述兑换码字符对上述兑换码兑换请求进行合法性校验;兑换业务操作执行单元,被配置成响应于确定上述兑换码兑换请求通过上述合法性校验,执行上述兑换码兑换请求对应的兑换业务操作。
可选的,上述装置还包括:响应于确定上述兑换码兑换请求通过上述全局校验,对上述兑换码兑换请求进行上述合法性校验。
可选的,上述全局配置信息包括:全局开关标识值,白名单用户标识码集合,上述兑换码兑换请求还包括:用户标识码;以及上述全局校验单元进一步被配置成:响应于确定上述全局开关标识值表征全局开关为开或上述白名单用户标识码集合中包括上述用户标识码,确定上述兑换码兑换请求通过上述全局校验。
可选的,上述全局校验单元进一步被配置成:响应于确定上述全局开关标识值表征全局开关为关或上述白名单用户标识码集合中不包括上述用户标识码,确定上述兑换码兑换请求未通过上述全局校验。
可选的,上述黑名单校验单元进一步被配置成:获取黑名单用户标识码集合;响应于确定上述黑名单用户标识码集合中不包括上述用户标识码,确定上述用户标识码对应的兑换码兑换请求次数;响应于确定上述兑换码兑换请求次数不满足预设条件,将上述用户标识码作为黑名单用户标识码加入上述黑名单用户标识码集合中以及确定上述兑换码兑换请求未通过上述黑名单校验。
可选的,上述黑名单校验单元进一步被配置成:响应于确定上述兑换码兑换请求次数满足预设条件,确定上述兑换码兑换请求通过上述黑名单校验。
可选的,上述合法性校验单元进一步被配置成:确定上述兑换码字符是否存在于合法兑换码字符集合中;响应于确定上述兑换码字符存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求通过上述合法性校验。
可选的,上述合法性校验单元进一步被配置成:响应于确定上述兑换码字符不存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求未通过上述合法性校验。
可选的,上述兑换业务操作执行单元进一步被配置成:响应于确定缓存数据中存在与上述兑换码字符对应的业务数据,根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作。
可选的,上述兑换业务操作执行单元进一步被配置成:响应于确定上述缓存数据中不存在与上述兑换码字符对应的业务数据,从关系型数据库中获取上述业务数据;根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作;将上述业务数据写入上述缓存数据中。
第三方面,本公开的一些实施例提供了一种电子设备,包括:一个或多个处理器;存储装置,其上存储有一个或多个程序,当一个或多个程序被一个或多个处理器执行,使得一个或多个处理器实现上述第一方面任一实现方式所描述的方法。
第四方面,本公开的一些实施例提供了一种计算机可读介质,其上存储有计算机程序,其中,程序被处理器执行时实现上述第一方面任一实现方式所描述的方法。
本公开的上述各个实施例具有如下有益效果:通过本公开的一些实施例的兑换码兑换请求校验方法,可以在查找与兑换码兑换请求相关的数据之前,实现对无效兑换码兑换请求的有效的过滤和拦截,降低了对数据库中存储的数据的频繁读取。同时,可以在用户维度上对兑换码兑换请求进行限流。具体来说,造成兑换码兑换请求校验时的时间和内存资源消耗较大的原因在于:未对兑换码兑换请求进行有效的过滤和拦截。基于此,本公开的一些实施例的兑换码兑换请求校验方法中不仅通过全局校验对兑换码兑换请求进行初步校验,以此来确定对兑换码兑换请求所需执行的后续的校验步骤。然后,还通过黑名单校验,从用户维度出发对兑换码兑换请求进行限流,可以在一定程度上避免某些用户过于频繁的执行兑换码兑换请求,从而造成的对其他用户正常执行兑换码兑换请求的不良影响以及对服务器资源的过多占用。其次,还通过合法性校验对包含不合法的兑换码字符的兑换码兑换请求进行过滤,在一定程度上降低了对数据库中存储的数据的频繁读取。
附图说明
结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,元件和元素不一定按照比例绘制。
图1是根据本公开的一些实施例的兑换码兑换请求校验方法的一个应用场景的示意图;
图2是根据本公开的兑换码兑换请求校验方法的一些实施例的流程图;
图3是根据本公开的一些实施例的兑换码兑换请求校验方法中的黑名单校验的一个应用场景的示意图;
图4是根据本公开的兑换码兑换请求校验方法的另一些实施例的流程图;
图5是根据本公开的兑换码兑换请求校验装置的一些实施例的结构示意图;
图6是适于用来实现本公开的一些实施例的电子设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例。相反,提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。在不冲突的情况下,本公开中的实施例及实施例中的特征可以相互组合。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
下面将参考附图并结合实施例来详细说明本公开。
图1是根据本公开一些实施例的兑换码兑换请求校验方法的一个应用场景的示意图。
在图1的应用场景中,首先,计算设备101可以根据全局配置信息102对兑换码兑换请求103进行全局校验104。然后,计算设备101可以响应于确定上述兑换码兑换请求103未通过上述全局校验104,对上述兑换码兑换请求103进行黑名单校验105。接着,计算设备101可以响应于确定上述兑换码兑换请求103通过上述黑名单校验105,对上述兑换码兑换请求103进行合法性校验106。最后,计算设备101可以响应于确定上述兑换码兑换请求103通过上述合法性校验106,执行上述兑换码兑换请求103对应的兑换业务操作107。
需要说明的是,上述计算设备101可以是硬件,也可以是软件。当计算设备为硬件时,可以实现成多个服务器或终端设备组成的分布式集群,也可以实现成单个服务器或单个终端设备。当计算设备体现为软件时,可以安装在上述所列举的硬件设备中。其可以实现成例如用来提供分布式服务的多个软件和软件模块,也可以是实现成单个软件或软件模块。在此不做具体限定。
应该理解,图1中的计算设备数目仅仅是示意性的。根据实现需要,可以具有任意数目的计算设备。
继续参考图2,示出了根据本公开的兑换码兑换请求校验方法的一些实施例的流程200。该兑换码兑换请求校验方法,包括以下步骤:
步骤201,根据全局配置信息对兑换码兑换请求进行全局校验。
在一些实施例中,兑换码兑换请求校验方法的执行主体(如图1所示的计算设备101)可以根据全局配置信息对兑换码兑换请求进行全局校验。其中,上述全局配置信息可以包括:白名单客户端IP(Internet Protocol,互联网协议)地址集合。上述兑换码兑换请求可以包括:客户端IP地址,兑换码字符。上述全局配置信息用于对上述兑换码兑换请求进行初次校验,以确定是否需要对上述兑换码兑换请求进行进一步的黑名单校验。上述全局配置信息可以存储在本地缓存数据库中,也可以存储在分布式数据库中。上述客户端IP地址可以是发送上述兑换码兑换请求的客户端所在的终端设备的IP地址。上述白名单客户端IP地址集合中的白名单客户端IP地址用于标识可以直接进行合法性校验的兑换码兑换请求。
作为示例,若上述白名单客户端IP地址集合中包括上述客户端IP地址,则可以确定上述兑换码兑换请求通过上述全局校验。若上述白名单客户端IP地址集合中不包括上述客户端IP地址,则可以确定上述兑换码兑换请求未通过上述全局校验。
在一些实施例的一些可选的实现方式中,上述全局配置信息可以包括:全局开关标识值,白名单用户标识码集合。上述兑换码兑换请求还可以包括:用户标识码。上述执行主体可以响应于确定上述全局开关标识值表征全局开关为开或上述白名单用户标识码集合中包括上述用户标识码,确定上述兑换码兑换请求通过上述全局校验。上述全局开关标识值可以用于表征全局开关的状态。上述全局开关的状态可以是开或关。上述全局开关为开时可以表示上述兑换码兑换请求通过全局校验。上述全局开关为关时可以表示上述兑换码兑换请求未通过全局校验。上述用户标识码可以是发送上述兑换码兑换请求的客户端中所存储的用于唯一标识用户的标识码。上述白名单用户标识码集合中的白名单用户标识码可以用于标识可以直接进行合法性校验的兑换码兑换请求。
作为示例,上述全局开关标识值为“1”时可以表征全局开关为开。或上述全局开关标识值为“on”时可以表征全局开关为开。若上述白名单用户标识码集合中包括上述用户标识码,则可以确定上述兑换码兑换请求通过上述全局校验。若上述白名单用户标识码集合中不包括上述用户标识码,则可以确定上述兑换码兑换请求未通过上述全局校验。
在一些实施例的一些可选的实现方式中,上述执行主体可以响应于确定上述全局开关标识值表征全局开关为关或上述白名单用户标识码集合中不包括上述用户标识码,确定上述兑换码兑换请求未通过上述全局校验。
作为示例,上述全局开关标识值为“0”时可以表征全局开关为关。或上述全局开关标识值为“off”时可以表征全局开关为关。
步骤202,响应于确定兑换码兑换请求未通过全局校验,对兑换码兑换请求进行黑名单校验。
在一些实施例中,上述执行主体响应于确定上述兑换码兑换请求未通过上述全局校验,对上述兑换码兑换请求进行黑名单校验,可以包括以下步骤:
第一步,获取黑名单客户端IP地址集合。其中,上述执行主体可以从本地缓存中或者通信连接的电子设备中获取上述黑名单客户端IP地址集合。上述黑名单客户端IP地址集合中的黑名单客户端IP地址可以用于标识无效的兑换码兑换请求。即,若兑换码兑换请求中包括的客户端IP地址在上述黑名单客户端IP地址集合中,则可以将上述兑换码兑换请求确定为无效的兑换码兑换请求,且终止对该兑换码兑换请求的后续操作。
第二步,响应于确定上述黑名单客户端IP地址集合中不包括上述兑换码兑换请求中包括的单客户端IP地址,确定上述兑换码兑换请求通过黑名单校验。
第二步,响应于确定上述黑名单客户端IP地址集合中包括上述兑换码兑换请求中包括的单客户端IP地址,确定上述兑换码兑换请求未通过黑名单校验。
在一些实施例的一些可选的实现方式中,上述执行主体对上述兑换码兑换请求进行黑名单校验,可以包括以下步骤:
第一步,获取黑名单用户标识码集合。其中,上述执行主体可以从本地缓存中或者通信连接的电子设备中获取上述黑名单用户标识码集合。上述黑名单用户标识码集合中的黑名单用户标识码可以用于标识无效的兑换码兑换请求。即,若兑换码兑换请求中包括的用户标识码在上述黑名单用户标识码集合中,则可以将上述兑换码兑换请求确定为无效的兑换码兑换请求,且终止对该兑换码兑换请求的后续操作。
第二步,响应于确定上述黑名单用户标识码集合中不包括上述用户标识码,确定上述用户标识码对应的兑换码兑换请求次数。其中,上述兑换次数可以是包括上述用户标识码的所有兑换码兑换请求的次数。也可以是在预设时间段内包括上述用户标识码的兑换码兑换请求的次数。可以通过在数据库中查询的方式确定上述兑换码兑换请求次数。可以理解,通过这种方式确定上述用户标识码对应的兑换码兑换请求次数,需要将接收到的每条兑换码兑换请求记录存储在数据库中。
第三步,响应于确定上述兑换码兑换请求次数不满足预设条件,将上述用户标识码作为黑名单用户标识码加入上述黑名单用户标识码集合中以及确定上述兑换码兑换请求未通过上述黑名单校验。其中,上述预设条件可以是兑换码兑换请求次数小于预设兑换码兑换请求次数。
作为为示例,参考图3,首先,获取黑名单用户标识码集合301。接着,响应于确定上述黑名单用户标识码集合301中不包括上述用户标识码302,确定上述用户标识码302对应的兑换码兑换请求次数303。然后,响应于确定上述兑换码兑换请求次数303不满足预设条件,将上述用户标识码302作为黑名单用户标识码加入上述黑名单用户标识码集合301中以及确定上述兑换码兑换请求未通过上述黑名单校验。
在一些实施例的一些可选的实现方式中,上述执行主体还可以响应于确定上述兑换码兑换请求次数满足预设条件,确定上述兑换码兑换请求通过上述黑名单校验。
步骤203,响应于确定兑换码兑换请求通过黑名单校验,基于兑换码字符对兑换码兑换请求进行合法性校验。
在一些实施例中,上述执行主体可以响应于确定上述兑换码兑换请求通过上述黑名单校验,通过预设的哈希算法对上述兑换码兑换请求中包括的兑换码字符进行处理以生成兑换码字符哈希值,进而通过判断兑换码字符哈希值是否满足校验条件的方式对上述兑换码兑换请求进行合法性校验。其中,上述预设的哈希算法可以是MD5信息摘要算法、SHA256算法等等。上述校验条件可以是兑换码字符哈希值的前预设数量个数值均为预设数值。例如,兑换码字符哈希值的前2个数值均为0。可以理解,这种合法性校验方式需要上述兑换码兑换请求的平台方生成的兑换码字符对应的兑换码字符哈希值满足上述校验条件。
在一些实施例的一些可选的实现方式中,上述执行主体对上述兑换码兑换请求进行上述合法性校验,可以包括以下步骤:
第一步,确定上述兑换码字符是否存在于合法兑换码字符集合中。其中,上述合法兑换码字符可以是上述兑换码兑换请求的平台方所生成的兑换码字符。
作为示例,可以将合法兑换码字符集合中的合法兑换码字符存储在合法兑换码字符数组中,通过遍历合法兑换码字符数组确定合法兑换码字符数组中是否包含上述兑换码字符。若上述合法兑换码字符数组中包含上述兑换码字符,则可以确定上述兑换码字符是预先生成的兑换码字符。若上述合法兑换码字符数组中不包含上述兑换码字符,则可以确定上述兑换码字符不是合法兑换码字符。
作为又一示例,可以将所合法兑换码字符集合中的合法兑换码字符同步至布隆过滤器中。通过布隆过滤器的查重功能确定上述兑换码字符是否为合法兑换码字符。
第二步,响应于确定上述兑换码字符存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求通过上述合法性校验。
在一些实施例的一些可选的实现方式中,上述执行主体还可以响应于确定上述兑换码字符不存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求未通过上述合法性校验。
步骤204,响应于确定兑换码兑换请求通过合法性校验,执行兑换码兑换请求对应的兑换业务操作。
在一些实施例中,上述执行主体可以响应于确定上述兑换码兑换请求通过上述合法性校验,向上述兑换码兑换请求中包括的客户端IP地址所对应的客户端发送与上述兑换码兑换请求中包括的兑换码字符所表征的权益信息。上述权益信息可以是优惠券兑换提示信息,会员身份兑换提示信息等等。可以在数据库中查询上述兑换码字符对应的权益信息。可以理解,这种兑换方式,需要预先在数据库中存储兑换码字符及其所表征的权益信息。
在一些实施例的一些可选的实现方式中,上述执行主体可以响应于确定缓存数据中存在与上述兑换码字符对应的业务数据,根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作。其中,上述缓存数据中存储的数据类型可以是键值对(key-value)类型。上述缓存数据可以是Redis数据库、Memcached数据库等等。上述业务数据可以包括兑换码字符。则可以在上述缓存数据中查找包括的兑换码字符与上述兑换码字符相同的业务数据。上述业务数据还可以包括用于表示上述兑换码字符是否已经被兑换过的兑换状态值。上述兑换状态值为“1”时表示上述兑换码字符已经被兑换过,则可以向发送上述兑换码兑换请求的用户发送一条表示兑换码已被兑换过的提示信息。上述兑换状态值为“0”时表示上述兑换码字符未被兑换过,则可以向发送上述兑换码兑换请求的用户发送一条表示兑换码兑换成功的提示信息,同时,将上述兑换状态值更改为“1”。上述业务数据还可以包括表示上述兑换码字符所表征的权益信息。
在一些实施例的一些可选的实现方式中,上述执行主体对上述兑换码兑换请求执行兑换业务操作,还可以包括以下步骤:
第一步,响应于确定上述缓存数据中不存在与上述兑换码字符对应的业务数据,从关系型数据库中获取上述业务数据。其中,上述关系型数据库用于存储所有合法兑换码字符对应的业务数据。上述关系型数据库可以是MySQL、MariaDB等等。
第二步,根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作。
第三步,将上述业务数据写入上述缓存数据库中。
本公开的上述各个实施例具有如下有益效果:通过本公开的一些实施例的兑换码兑换请求校验方法,可以在查找与兑换码兑换请求相关的数据之前,实现对无效兑换码兑换请求的有效的过滤和拦截,降低了对数据库中存储的数据的频繁读取。同时,可以在用户维度上对兑换码兑换请求进行限流。具体来说,造成兑换码兑换请求校验时的时间和内存资源消耗较大的原因在于:未对兑换码兑换请求进行有效的过滤和拦截。基于此,本公开的一些实施例的兑换码兑换请求校验方法中不仅通过全局校验对兑换码兑换请求进行初步校验,以此来确定对兑换码兑换请求所需执行的后续的校验步骤。然后,还通过黑名单校验,从用户维度出发对兑换码兑换请求进行限流,可以在一定程度上避免某些用户过于频繁的执行兑换码兑换请求,从而造成的对其他用户正常执行兑换码兑换请求的不良影响以及对服务器资源的过多占用。其次,还通过合法性校验对包含不合法的兑换码字符的兑换码兑换请求进行过滤,在一定程度上降低了对数据库中存储的数据的频繁读取。
进一步参考图4,其示出了兑换码兑换请求校验方法的另一些实施例的流程400。该兑换码兑换请求校验方法的流程400,包括以下步骤:
步骤401,根据全局配置信息对兑换码兑换请求进行全局校验。
步骤402,响应于确定兑换码兑换请求未通过全局校验,对兑换码兑换请求进行黑名单校验。
步骤403,响应于确定兑换码兑换请求通过黑名单校验,基于兑换码字符对兑换码兑换请求进行合法性校验。
在一些实施例中,步骤401-403的具体实现及其所带来的技术效果可以参考图2对应的实施例中的步骤201-203,在此不再赘述。
步骤404,响应于确定兑换码兑换请求通过全局校验,对兑换码兑换请求进行合法性校验。
在一些实施例中,上述执行主体可以响应于确定上述兑换码兑换请求通过上述全局校验,基于上述兑换码字符对上述兑换码兑换请求进行上述合法性校验。其中,合法性校验的具体实现可以参考图2对应的实施例中的步骤203中的合法性校验。
步骤405,响应于确定兑换码兑换请求通过合法性校验,执行兑换码兑换请求对应的兑换业务操作。
在一些实施例中,步骤405的具体实现及其所带来的技术效果可以参考图2对应的实施例中的步骤204,在此不再赘述。
从图4中可以看出,与图2对应的一些实施例的描述相比,图4对应的一些实施例中的兑换码兑换请求校验方法的流程400体现了对兑换码兑换请求进行全局校验后的步骤的扩展。由此,这些实施例描述的方案可以在兑换码兑换请求通过全局校验后,直接省略黑名单校验的步骤,直接对兑换码兑换请求进行合法性校验。从而,在一定程度上简化了兑换码兑换请求校验的过程,缩短了兑换码兑换请求校验的时间,降低了对服务器资源的消耗。
进一步参考图5,作为对上述各图所示方法的实现,本公开提供了一种兑换码兑换请求校验装置的一些实施例,这些装置实施例与图2所示的那些方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图5所示,一些实施例的兑换码兑换请求校验装置500包括:全局校验单元501、黑名单校验单元502、合法性校验单元503和兑换业务操作执行单元504。其中,全局校验单元501被配置成根据全局配置信息对兑换码兑换请求进行全局校验,其中,上述兑换码兑换请求包括:兑换码字符;黑名单校验单元502被配置成响应于确定上述兑换码兑换请求未通过上述全局校验,对上述兑换码兑换请求进行黑名单校验;合法性校验单元503被配置成响应于确定上述兑换码兑换请求通过上述黑名单校验,基于上述兑换码字符对上述兑换码兑换请求进行合法性校验;兑换业务操作执行单元504被配置成响应于确定上述兑换码兑换请求通过上述合法性校验,执行上述兑换码兑换请求对应的兑换业务操作。
在一些实施例的可选实现方式中,装置500还可以包括:请求合法性校验单元,被配置成响应于确定上述兑换码兑换请求通过上述全局校验,对上述兑换码兑换请求进行上述合法性校验。
在一些实施例的可选实现方式中,上述全局配置信息包括:全局开关标识值,白名单用户标识码集合,上述兑换码兑换请求包括:用户标识码;上述全局校验单元501可以进一步被配置成:响应于确定上述全局开关标识值表征全局开关为开或上述白名单用户标识码集合中包括上述用户标识码,确定上述兑换码兑换请求通过上述全局校验。
在一些实施例的可选实现方式中,上述全局校验单元501可以进一步被配置成:响应于确定上述全局开关标识值表征全局开关为关或上述白名单用户标识码集合中不包括上述用户标识码,确定上述兑换码兑换请求未通过上述全局校验。
在一些实施例的可选实现方式中,上述黑名单校验单元502可以进一步被配置成:获取黑名单用户标识码集合;响应于确定上述黑名单用户标识码集合中不包括上述用户标识码,确定上述用户标识码对应的兑换码兑换请求次数;响应于确定上述兑换码兑换请求次数不满足预设条件,将上述用户标识码作为黑名单用户标识码加入上述黑名单用户标识码集合中以及确定上述兑换码兑换请求未通过上述黑名单校验。
在一些实施例的可选实现方式中,上述黑名单校验单元502可以进一步被配置成:响应于确定上述兑换码兑换请求次数满足预设条件,确定上述兑换码兑换请求通过上述黑名单校验。
在一些实施例的可选实现方式中,上述合法性校验单元503可以进一步被配置成:确定上述兑换码字符是否存在于合法兑换码字符集合中;响应于确定上述兑换码字符存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求通过上述合法性校验。
在一些实施例的可选实现方式中,上述合法性校验单元503可以进一步被配置成:响应于确定上述兑换码字符不存在于上述合法兑换码字符集合中,确定上述兑换码兑换请求未通过上述合法性校验。
在一些实施例的可选实现方式中,上述兑换业务操作执行单元504可以进一步被配置成:响应于确定缓存数据中存在与上述兑换码字符对应的业务数据,根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作。
在一些实施例的可选实现方式中,上述兑换业务操作执行单元504可以进一步被配置成:响应于确定上述缓存数据中不存在与上述兑换码字符对应的业务数据,从关系型数据库中获取上述业务数据;根据上述业务数据对上述兑换码兑换请求执行上述兑换业务操作;将上述业务数据写入上述缓存数据中。
可以理解的是,该装置500中记载的诸单元与参考图2描述的方法中的各个步骤相对应。由此,上文针对方法描述的操作、特征以及产生的有益效果同样适用于装置500及其中包含的单元,在此不再赘述。
下面参考图6,其示出了适于用来实现本公开的一些实施例的电子设备600的结构示意图。图6示出的电子设备仅仅是一个示例,不应对本公开的实施例的功能和使用范围带来任何限制。
如图6所示,电子设备600可以包括处理装置(例如中央处理器、图形处理器等)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储装置608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有电子设备600操作所需的各种程序和数据。处理装置601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
通常,以下装置可以连接至I/O接口605:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置606;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置607;以及通信装置609。通信装置609可以允许电子设备600与其他设备进行无线或有线通信以交换数据。虽然图6示出了具有各种装置的电子设备600,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。图6中示出的每个方框可以代表一个装置,也可以根据需要代表多个装置。
特别地,根据本公开的一些实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的一些实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的一些实施例中,该计算机程序可以通过通信装置609从网络上被下载和安装,或者从存储装置608被安装,或者从ROM 602被安装。在该计算机程序被处理装置601执行时,执行本公开的一些实施例的方法中限定的上述功能。
需要说明的是,本公开的一些实施例中记载的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开的一些实施例中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开的一些实施例中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
在一些实施方式中,客户端、服务器可以利用诸如HTTP(HyperText TransferProtocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“LAN”),广域网(“WAN”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:根据全局配置信息对兑换码兑换请求进行全局校验,其中,上述兑换码兑换请求包括:兑换码字符;响应于确定上述兑换码兑换请求未通过上述全局校验,对上述兑换码兑换请求进行黑名单校验;响应于确定上述兑换码兑换请求通过上述黑名单校验,基于上述兑换码字符对上述兑换码兑换请求进行合法性校验;响应于确定上述兑换码兑换请求通过上述合法性校验,执行上述兑换码兑换请求对应的兑换业务操作。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的一些实施例的操作的计算机程序代码,上述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)——连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开的一些实施例中的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括全局校验单元、黑名单校验单元、合法性校验和兑换业务操作执行单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,全局校验单元还可以被描述为“根据全局配置信息对兑换码兑换请求进行全局校验的单元”。
本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、片上系统(SOC)、复杂可编程逻辑设备(CPLD)等等。
以上描述仅为本公开的一些较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开的实施例中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开的实施例中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。