CN110084065B - 数据脱敏方法及装置 - Google Patents

数据脱敏方法及装置 Download PDF

Info

Publication number
CN110084065B
CN110084065B CN201910357401.5A CN201910357401A CN110084065B CN 110084065 B CN110084065 B CN 110084065B CN 201910357401 A CN201910357401 A CN 201910357401A CN 110084065 B CN110084065 B CN 110084065B
Authority
CN
China
Prior art keywords
code point
data
character
code
determining
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.)
Active
Application number
CN201910357401.5A
Other languages
English (en)
Other versions
CN110084065A (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.)
Beijing Pocket Fashion Technology Co ltd
Original Assignee
Beijing Pocket Fashion 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 Beijing Pocket Fashion Technology Co ltd filed Critical Beijing Pocket Fashion Technology Co ltd
Priority to CN201910357401.5A priority Critical patent/CN110084065B/zh
Publication of CN110084065A publication Critical patent/CN110084065A/zh
Application granted granted Critical
Publication of CN110084065B publication Critical patent/CN110084065B/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/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
    • G06F21/6245Protecting personal data, e.g. for financial or medical purposes
    • G06F21/6254Protecting personal data, e.g. for financial or medical purposes by anonymising data, e.g. decorrelating personal data from the owner's identification

Abstract

本公开是关于一种数据脱敏方法及装置。该方法包括:获取待脱敏数据的码点数组;根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;根据预设字符串和所述目标码确定所述脱敏数据。该技术方案将表情或者统一码的非基本多语言平面的字符整体对应的作为脱敏数据的首字符或者尾字符,避免形成的脱敏数据乱码,提高了脱敏的准确性。

Description

数据脱敏方法及装置
技术领域
本公开涉及计算机技术领域,尤其涉及一种数据脱敏方法及装置。
背景技术
目前,互联网中的用户隐私信息越来越重要,用户昵称作为用户的一种标识,为了保护用户隐私的安全,需要针对性的对用户昵称做脱敏处理。
相关技术中,在对用户昵称做脱敏处理时,首先将用户昵称转换为多个码点,一个字符对应一个码点,然后提取第一个码点作为脱敏文本的首字符,提取最后一个码点作为脱敏文本的尾字符,再在脱敏文本的首字符和尾字符之间增加***,则构成的脱敏文本为首字符***尾字符。
发明内容
为克服相关技术中存在的问题,本公开实施例提供一种数据脱敏方法及装置。所述技术方案如下:
根据本公开实施例的第一方面,提供一种数据脱敏方法,包括:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据。
本公开的实施例提供的技术方案可以包括以下有益效果:在获取到待脱敏数据时,需要确定待脱敏数据的首字符和尾字符是否为表情或者统一码的非基本多语言平面的字符,在确定待脱敏数据的首字符和尾字符为表情或者统一码的非基本多语言平面的字符时,则将表情或者统一码的非基本多语言平面的字符整体对应的作为脱敏数据的首字符或者尾字符,避免形成的脱敏数据乱码,提高了脱敏的准确性。
在一个实施例中,在根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码之前,还包括:
确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码包括:
在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
在一个实施例中,还包括:
在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
在一个实施例中,还包括:
在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
在一个实施例中,根据所述码点数组确定所述待脱敏数据的首字符是否为目标码,在确定所述待脱敏数据的首字符为目标码时,将目标码确定为对应的脱敏数据的首字符包括:
获取所述码点数组中的初始码点作为第一当前码点组;
确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,根据所述码点数组确定所述待脱敏数据的尾字符是否为目标码,在确定所述待脱敏数据的尾字符为目标码时,将目标码确定为对应的脱敏数据的尾字符包括:
在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
在一个实施例中,还包括:
在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第一当前码点组中的第一个码点是否在高位代理区;
在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
在一个实施例中,还包括:
在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在一个实施例中,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第二当前码点组中的第一个码点是否在高位代理区;
在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
在一个实施例中,还包括:
在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
根据本公开实施例的第二方面,提供一种数据脱敏装置,包括:
获取模块,用于获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
第一确定模块,用于根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
第二确定模块,用于根据预设字符串和所述目标码确定所述脱敏数据。
本公开的实施例提供的技术方案可以包括以下有益效果:在获取到待脱敏数据时,需要确定待脱敏数据的首字符和尾字符是否为表情或者统一码的非基本多语言平面的字符,在确定待脱敏数据的首字符和尾字符为表情或者统一码的非基本多语言平面的字符时,则将表情或者统一码的非基本多语言平面的字符整体对应的作为脱敏数据的首字符或者尾字符,避免形成的脱敏数据乱码,提高了脱敏的准确性。
在一个实施例中,还包括第三确定模块,所述第一确定模块包括第一确定子模块;
所述第三确定模块,用于确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述第一确定子模块,用于在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
在一个实施例中,还包括第四确定模块;
所述第四确定模块,用于在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
在一个实施例中,还包括第五确定模块;
所述第五确定模块,用于在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
在一个实施例中,所述第一确定模块还包括第一获取子模块、第二确定子模块、第三确定子模块、第四确定子模块和第五确定子模块;
所述第一获取子模块,用于获取所述码点数组中的初始码点作为第一当前码点组;
所述第二确定子模块,用于确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
所述第三确定子模块,用于在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
所述第四确定子模块,用于在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
所述第五确定子模块,用于在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,所述第一确定模块还包括第二获取子模块、第六确定子模块、第七确定子模块和第八确定子模块;
所述第二获取子模块,用于在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
所述第六确定子模块,用于确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
所述第七确定子模块,用于在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
所述第八确定子模块,用于在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
在一个实施例中,所述第一确定模块还包括第九确定子模块;
所述第九确定子模块,用于在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块还包括第十确定子模块、第十一确定子模块和第十二确定子模块;
所述第十确定子模块,用于确定所述第一当前码点组中的第一个码点是否在高位代理区;
所述第十一确定子模块,用于在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
所述第十二确定子模块,用于在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
在一个实施例中,所述第一确定模块还包括第十三确定子模块;
所述第十三确定子模块,用于在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在一个实施例中,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块还包括第十四确定子模块、第十五确定子模块和第十六确定子模块;
所述第十四确定子模块,用于确定所述第二当前码点组中的第一个码点是否在高位代理区;
所述第十五确定子模块,用于在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
所述第十六确定子模块,用于在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
在一个实施例中,所述第一确定模块还包括第十七确定子模块;
所述第十七确定子模块,用于在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
根据本公开实施例的第三方面,提供一种数据脱敏装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据。
根据本公开实施例的第四方面,提供一种计算机可读存储介质,其上存储有计算机指令,该指令被处理器执行时实现第一方面任一实施例所述方法的步骤。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1a是根据一示例性实施例示出的数据脱敏方法的流程图。
图1b是根据一示例性实施例示出的数据脱敏方法的流程图。
图1c是根据一示例性实施例示出的数据脱敏方法的流程图。
图1d是根据一示例性实施例示出的数据脱敏方法的流程图。
图2a是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2b是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2c是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2d是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2e是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2f是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2g是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2h是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2i是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2j是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图2k是根据一示例性实施例示出的数据脱敏装置的结构示意图。
图3是根据一示例性实施例示出的数据脱敏装置的结构示意图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
本公开实施例提供的技术方案涉及终端,该终端可以为用户使用的手机、平板电脑、笔记本电脑以及其他具有数据处理功能的设备,本公开实施例对此不做限定。相关技术中,在对用户昵称做脱敏处理时,首先将用户昵称转换为多个码点,一个字符对应一个码点,然后提取第一个码点作为脱敏文本的首字符,提取最后一个码点作为脱敏文本的尾字符,再在脱敏文本的首字符和尾字符之间增加***,则构成的脱敏文本为首字符***尾字符,例如,用户昵称为张三丰,则脱敏文本为张***丰。但是,若用户昵称中包含Emoji表情或者统一码Unicode的非基本多语言平面的字符,由于一个Emoji表情或者一个统一码Unicode的非基本多语言平面的字符所占的字节与汉字等字符所占的字节不同,所以在脱敏处理时,会导致脱敏文本乱码,例如,用户昵称为
Figure BDA0002045841310000101
三丰,则脱敏文本为?***丰,?为乱码,降低了脱敏的准确性。本公开实施例提供的技术方案中,在获取到待脱敏数据时,需要确定待脱敏数据的首字符和尾字符是否为表情或者统一码的非基本多语言平面的字符,在确定待脱敏数据的首字符和尾字符为表情或者统一码的非基本多语言平面的字符时,则将表情或者统一码的非基本多语言平面的字符整体对应的作为脱敏数据的首字符或者尾字符,避免形成的脱敏数据乱码,提高了脱敏的准确性。
图1a是根据一示例性实施例示出的一种数据脱敏方法的流程图,该方法应用于终端,如图1a所示,该数据脱敏方法包括以下步骤101至步骤103:
在步骤101中,获取待脱敏数据的码点数组。
其中,所述码点数组中的码点包括统一码的码点,即为unicode码点。
示例的,在需要对数据进行脱敏时,用户可向终端输入待脱敏数据,并点击脱敏按钮,发送脱敏指令,使得终端在获取到待脱敏数据时响应于脱敏指令将待脱敏数据转换为对应的码点数组;或者,终端自行检测待显示的数据中是否包含敏感字符,在数据中包含敏感字符时,则知需要对此数据进行脱敏处理,将待脱敏数据转换为对应的码点数组;例如,编码方式为UTF-16,待脱敏数据为
Figure BDA0002045841310000102
三丰,则表情
Figure BDA0002045841310000103
对应的为码点1和码点2,汉字三对应的为码点3,汉字丰对应的为码点4,码点数组为[码点1、码点2、码点3、码点4];待脱敏数据为三丰
Figure BDA0002045841310000111
则汉字三对应的为码点3,汉字丰对应的为码点4,表情
Figure BDA0002045841310000112
对应的为码点5和码点6,码点数组为[码点3、码点4、码点5、码点6];待脱敏数据为张三
Figure BDA0002045841310000113
则复杂字
Figure BDA0002045841310000114
为统一码的非基本多语言平面的字符,由两个字符组成,第一个字符位于高位代理区,第二个字符位于低位代理区,读取时,需要将第一个字符和第二个字符同时读取,例如,第一个字符对应的为码点7、第二个字符对应的为码点8、张对应的为码点9,三对应的为码点3,则码点数组为[码点9、码点3、码点7、码点8]。
在步骤102中,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符。
其中,所述目标码包括统一码的非基本多语言平面的字符或者表情,例如:统一码的非基本多语言平面的字符为熙等复杂汉字;表情为
Figure BDA0002045841310000115
等emoji表情。
可选的,如图1b所示,根据码点数组确定待脱敏数据的首字符和尾字符是否为目标码的具体方法包括以下步骤1021至步骤10218:
在步骤1021中,获取所述码点数组中的初始码点作为第一当前码点组。
在步骤1022中,确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情。
其中,表情数据库是预先在终端中建立的,表情数据库用于存储每个表情的码点及对应的码点值。
在步骤1023中,在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤1022,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情。
示例的,在确定表情数据库中未存储有与第一当前码点组中每个码点对应的表情时,说明待脱敏数据的首字符不为表情。
在步骤1024中,确定所述第一当前码点组中的第一个码点是否在高位代理区。
示例的,在确定待脱敏数据的首字符不为表情时,开始判断待脱敏数据的首字符是否为统一码的非基本多语言平面的字符,即当第一当前码点组中的第一个码点在高位代理区、第一当前码点组中的第二个码点在低位代理区时,则说明待脱敏数据的首字符是统一码的非基本多语言平面的字符;当第一当前码点组中的第一个码点不在高位代理区,则说明待脱敏数据的首字符不是统一码的非基本多语言平面的字符。
在步骤1025中,在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区。
在步骤1026中,在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
示例的,步骤1026确定待脱敏数据的首字符为统一码的非基本多语言平面的字符,而此统一码的非基本多语言平面的字符由第一当前码点组中的第一个码点和第二个码点组成,从而将第一当前码点组中的第一个码点和第二个码点作为脱敏数据的首字符。
在步骤1027中,在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
示例的,当第一当前码点组中的第一个码点未在高位代理区时,说明待脱敏数据的首字符既不是表情也不是统一码的非基本多语言平面的字符,则说明待脱敏数据的首字符为常规字符,例如,汉字、数字、字母、标点符号等,这些常规字符均采用一个码点组成,所以将第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在步骤1028中,在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点。
示例的,当表情数据库中存储有与第一当前码点组中每个码点对应的表情时,则说明待脱敏数据中包括以第一码点开头的表情,此时,确定第一当前码点组中的最后一个码点是否为数据结束码点,以确定待脱敏数据只包含一个字符还是多个字符。
在步骤1029中,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
示例的,在确定第一当前码点组中的最后一个码点为非数据结束码点时,则说明待脱敏数据包含多个字符,第一当前码点组为脱敏数据的首字符,且首字符为表情。
在步骤10210中,在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
示例的,在确定第一当前码点组中的最后一个码点为数据结束码点时,则说明待脱敏数据只包含一个字符,且此字符为表情。
在步骤10211中,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组。
示例的,在第一当前码点组包括码点数组中的所有码点,且表情数据库中未存储有与所有码点对应的表情时,说明待脱敏数据不包括以第一个码点开头的表情;在确定第一当前码点组中的最后一个码点为非数据结束码点时,则说明待脱敏数据包含多个字符,所以此时需要判断待脱敏数据的尾字符是否包含表情或者统一码的非基本多语言平面的字符。
在步骤10212中,确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情。
在步骤10213中,在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤10212,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情。
示例的,在确定表情数据库未存储有与第二当前码点组中每个码点对应的表情时,说明待脱敏数据的尾字符不为表情。
在步骤10214中,确定所述第二当前码点组中的第一个码点是否在高位代理区。
示例的,在确定待脱敏数据的尾字符不为表情时,开始判断待脱敏数据的尾字符是否为统一码的非基本多语言平面的字符。
在步骤10215中,在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区。
在步骤10216中,在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
示例的,在确定第二当前码点组中的第二个码点在低位代理区时,说明待脱敏数据的尾字符为统一码的非基本多语言平面的字符,而此统一码的非基本多语言平面的字符由第二当前码点组中的第一个码点和第二个码点组成,从而将第二当前码点组中的第一个码点和第二个码点作为脱敏数据的尾字符。
在步骤10217中,在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
示例的,当第二当前码点组中的第一个码点未在高位代理区时,说明待脱敏数据的尾字符既不是表情也不是统一码的非基本多语言平面的字符,则说明待脱敏数据的尾字符为常规字符,例如,汉字、数字、字母、标点符号等,这些常规字符均采用一个码点组成,所以将第二当前码点组中的第一个码点确定为脱敏数据的尾字符。
在步骤10218中,在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
示例的,当表情数据库中存储有与第二当前码点组中每个码点对应的表情时,则说明待脱敏数据的尾字符为表情,且此表情由第二当前码点组中的码点组成,从而将第二当前码点组确定为脱敏数据的尾字符。
在步骤103中,根据预设字符串和所述目标码确定所述脱敏数据。
示例的,在脱敏数据包括首字符和尾字符时,将预设字符串添加在脱敏数据的首字符和尾字符之间;在脱敏数据只包括首字符时,将预设字符串添加在脱敏数据的首字符后面。
需要说明的是,本公开实施例对预设字符串的内容不做限定,可根据用户需求自行设定,例如,预设字符串为***,且本公开对预设字符串的添加位置也不做限定,只要能够保证待脱敏数据的隐私即可。
进一步的,如图1c所示,在执行完步骤101之后,还包括步骤104和步骤105:
在步骤104中,确定所述待脱敏数据中是否包含所述首字符和尾字符。
示例的,终端将待脱敏数据的字符长度进行计算,根据字符长度确定待脱敏数据是只有首字符,还是首字符和尾字符都有;例如,待脱敏数据为张,则可以确定待脱敏数据只有首字符;待脱敏数据为三丰,则可以确定待脱敏数据既有首字符又有尾字符。
需要说明的是,在确定所述待脱敏数据中包含首字符和尾字符时,执行步骤102;在确定所述待脱敏数据中只包含首字符时,执行步骤105。
在步骤105中,在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
进一步的,如图1d所示,根据步骤102确定待脱敏数据的首字符和/或尾字符为非目标码时,所述方法还包括步骤106:
在步骤106中,在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
示例的,在确定待脱敏数据的首字符和/或尾字符为非目标码时,则说明待脱敏数据的首字符和/或尾字符为常规字符,例如,汉字、数字、字母、标点符号等,此时直接将非目标码确定为对应的脱敏数据的首字符和/或尾字符。
下面以实例进行举例:
示例的,若待脱敏数据为
Figure BDA0002045841310000161
三丰,码点数组为[码点1、码点2、码点3、码点4],则首先获取码点1作为第一当前码点组,在表情数据库中查找是否有与码点1的码点值对应的表情,若没有码点1的码点值对应的表情,则获取第一当前码点组码点1和下一码点码点2作为新的第一当前码点组,在表情数据库中查找是否有与码点1的码点值和码点2的码点值对应的表情,若存储有码点1的码点值和码点2的码点值对应的表情,则说明码点1和码点2组成一个表情,此时,判断码点2是否为数据结束码点,即判断码点2的码点值是否为整个待脱敏数据的数据结束码点对应的码点值,若确定码点2的码点值不为整个待脱敏数据的数据结束码点对应的码点值,则说明在码点2后面还有其他码点,此时,将码点1和码点2组成的表情作为脱敏数据的首字符,即脱敏数据的首字符为
Figure BDA0002045841310000162
在确定码点2的码点值不为整个待脱敏数据的数据结束码点对应的码点值时,说明码点2之后还有其他码点,此时获取终止码点,即获取码点4作为第二当前码点组,在表情数据库中查找是否有码点4的码点值对应的表情,若没有码点4的码点值对应的表情,则获取第二当前码点组码点4和上一码点码点3,并将码点3、码点4排序,将码点3和码点4作为新的第二当前码点组,在表情数据库中查找是否存储有码点3的码点值和码点4的码点值对应的表情,若没有存储码点3的码点值和码点4的码点值对应的表情,则获取第二当前码点组码点3和码点4,以及上一码点码点2,将码点2、码点3和码点4作为新的第二当前码点组,在表情数据库中查找是否存储有码点2的码点值、码点3的码点值和码点4的码点值对应的表情,若没有存储码点2的码点值、码点3的码点值和码点4的码点值对应的表情,则获取第二当前码点组码点2、码点3和码点4,以及上一码点码点1,将码点1、码点2、码点3和码点4作为新的第二当前码点组,在表情数据库中查找是否存储有码点1的码点值、码点2的码点值、码点3的码点值和码点4的码点值对应的表情,若没有存储码点1的码点值、码点2的码点值、码点3的码点值和码点4的码点值对应的表情,则说明待脱敏数据
Figure BDA0002045841310000171
三丰的尾字符不是表情,此时,判断码点3对应的码点值是否在高位代理区,若码点3对应的码点值不在高位代理区,码点4对应的码点值不在低位代理区,则说明待脱敏数据的尾字符不为统一码的非基本多语言平面的字符,为常规字符,此时,将码点4对应的字符确定为脱敏数据的尾字符,即脱敏数据
Figure BDA0002045841310000172
三丰的尾字符为丰。
若待脱敏数据为张三
Figure BDA0002045841310000173
,码点数组为[码点9、码点3、码点7、码点8],则首先获取码点9作为第一当前码点组,在表情数据库中查找是否有码点9的码点值对应的表情,若没有码点9的码点值对应的表情,则获取第一当前码点组码点9和下一码点码点3作为新的第一当前码点组,在表情数据库中查找是否存储有码点9的码点值和码点3的码点值对应的表情,若没有存储有码点9的码点值和码点3的码点值对应的表情,则获取第一当前码点组码点9和码点3,以及下一码点码点7作为新的第一当前码点组,在表情数据库中查找是否存储有码点9的码点值、码点3的码点值和码点7的码点值对应的表情,若没有存储有码点9的码点值、码点3的码点值和码点7的码点值对应的表情,则获取第一当前码点组码点9、码点3和码点7,以及下一码点码点8作为新的第一当前码点组,在表情数据库中查找是否存储有码点9的码点值、码点3的码点值、码点7的码点值和码点8的码点值对应的表情,若没有存储有码点9的码点值、码点3的码点值、码点7的码点值和码点8的码点值对应的表情,则说明待脱敏数据张三
Figure BDA0002045841310000181
的首字符不是表情。
接着,判断待脱敏数据张三
Figure BDA0002045841310000182
的首字符是否为统一码的非基本多语言平面的字符,即确定码点9对应的码点值是否在高位代理区,若码点9对应的码点值不在高位代理区,码点3对应的码点值不在低位代理区,则说明待脱敏数据张三
Figure BDA0002045841310000183
的首字符不为统一码的非基本多语言平面的字符,为常规字符,此时,将码点9对应的字符确定为脱敏数据的首字符,即脱敏数据的首字符为张。
接着判断待脱敏数据张三
Figure BDA0002045841310000184
的尾字符,即获取码点8对应的码点值,确定表情数据库中是否存储有码点8的码点值对应的表情,直至判断到表情数据库中没有存储码点8的码点值、码点7的码点值、码点3的码点值和码点9的码点值对应的表情时,说明待脱敏数据张三
Figure BDA0002045841310000185
的尾字符不为表情。
此时确定码点7对应的码点值是否在高位代理区,若码点7对应的码点值在高位代理区,则判断码点8对应的码点值是否在低位代理区,若码点8对应的码点值在低位代理区,则说明码点7和码点8为一个整体的字符,需要连续读取码点7和码点8,即码点7和码点8组成一个统一码的非基本多语言平面的字符,待脱敏数据的尾字符为统一码的非基本多语言平面的字符,此时,将码点7和码点8组成的统一码的非基本多语言平面的字符确定为脱敏数据的尾字符,即脱敏数据的尾字符为
Figure BDA0002045841310000186
若待脱敏数据为三丰
Figure BDA0002045841310000187
码点数组为[码点3、码点4、码点5、码点6],在确定待脱敏数据为三丰
Figure BDA0002045841310000188
的首字符是否为表情的方法与上述待脱敏数据张三
Figure BDA0002045841310000189
的首字符是否为表情的方法相同,即可确定脱敏数据的首字符为三,在此不再赘述。
接着判断待脱敏数据三丰
Figure BDA0002045841310000191
的尾字符,即获取码点6作为第二当前码点组,在表情数据库中查找是否有码点6的码点值对应的表情,若没有码点6的码点值对应的表情,则获取第二当前码点组码点6和上一码点码点5,并将码点6、码点5排序,将码点5和码点6作为新的第二当前码点组,在表情数据库中查找是否存储有码点5的码点值和码点6的码点值对应的表情,若存储有码点5的码点值和码点6的码点值对应的表情,则说明码点5和码点6组成一个表情,将码点5和码点6组成的表情作为脱敏数据的尾字符,即脱敏数据的尾字符为
Figure BDA0002045841310000192
采用上述同样的方法,若待脱敏数据为
Figure BDA0002045841310000193
则可以确定出待脱敏数据只有一个字符,还为表情,此时将
Figure BDA0002045841310000194
确定为脱敏数据的首字符,没有尾字符;若待脱敏数据为张,则可以确定出待脱敏数据只有一个字符,且为常规字符,此时将张确定为脱敏数据的首字符,没有尾字符;若待脱敏数据为张三,则将张确定为脱敏数据的首字符,将三确定为脱敏数据的尾字符;若待脱敏数据为
Figure BDA0002045841310000195
Figure BDA00020458413100001915
,则将
Figure BDA0002045841310000196
确定为脱敏数据的首字符,将
Figure BDA00020458413100001916
确定为脱敏数据的尾字符;若待脱敏数据为
Figure BDA0002045841310000197
Figure BDA0002045841310000198
则将
Figure BDA0002045841310000199
确定为脱敏数据的首字符,将
Figure BDA00020458413100001910
确定为脱敏数据的尾字符。
在确定完脱敏数据的首字符和尾字符后,则需要确定完整的脱敏数据,假设预设字符串为***,优选的,将预设字符串添加在脱敏数据的首字符与尾字符之间。
示例的,若待脱敏数据为
Figure BDA00020458413100001911
三丰,上述判断出脱敏数据的首字符为
Figure BDA00020458413100001912
尾字符为丰,则对应的脱敏数据为
Figure BDA00020458413100001913
***丰。
若待脱敏数据为张三
Figure BDA00020458413100001917
,上述判断出脱敏数据的首字符为张,尾字符为
Figure BDA00020458413100001918
,则对应的脱敏数据为张***
Figure BDA00020458413100001919
若待脱敏数据为三丰
Figure BDA00020458413100001914
上述判断出脱敏数据的首字符为三,尾字符为
Figure BDA0002045841310000201
则对应的脱敏数据为三***
Figure BDA0002045841310000202
若待脱敏数据为
Figure BDA0002045841310000203
则脱敏数据的首字符为
Figure BDA0002045841310000204
则对应的脱敏数据为
Figure BDA0002045841310000205
若待脱敏数据为张三,则脱敏数据的首字符为张,尾字符为三,则对应的脱敏数据为张***三。
若待脱敏数据为
Figure BDA0002045841310000206
Figure BDA0002045841310000207
则脱敏数据的首字符为
Figure BDA0002045841310000208
尾字符为
Figure BDA0002045841310000209
则对应的脱敏数据为
Figure BDA00020458413100002010
若待脱敏数据为
Figure BDA00020458413100002011
Figure BDA00020458413100002012
则脱敏数据的首字符为
Figure BDA00020458413100002013
尾字符为
Figure BDA00020458413100002014
则对应的脱敏数据为
Figure BDA00020458413100002015
需要说明的是,本公开的待脱敏数据可以为用户昵称,应用在商品评价界面,用户采用某账号购买东西,购买成功后,需要对购买的商品进行评价,而用户在评价后,终端会显示用户的评价内容和对应的用户标识,即用户昵称,为了避免泄露用户信息,需要将用户昵称进行脱敏处理,本公开正可以应用于此场景。
本公开实施例提供一种数据脱敏方法,在获取到待脱敏数据时,需要确定待脱敏数据的首字符和尾字符是否为表情或者统一码的非基本多语言平面的字符,在确定待脱敏数据的首字符和尾字符为表情或者统一码的非基本多语言平面的字符时,则将表情或者统一码的非基本多语言平面的字符整体对应的作为脱敏数据的首字符或者尾字符,避免形成的脱敏数据乱码,提高了脱敏的准确性。
下述为本公开装置实施例,可以用于执行本公开方法实施例。
图2a是根据一示例性实施例示出的一种数据脱敏装置20的结构示意图,该装置20可以通过软件、硬件或者两者的结合实现成为电子设备的部分或者全部。如图2a所示,该数据脱敏装置20包括获取模块201,第一确定模块202和第二确定模块203。
其中,获取模块201,用于获取待脱敏数据的码点数组。
其中,所述码点数组中的码点包括统一码的码点。
第一确定模块202,用于根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情。
第二确定模块203,用于根据预设字符串和所述目标码确定所述脱敏数据。
在一个实施例中,如图2b所示,所述装置20还包括第三确定模块204,所述第一确定模块202包括第一确定子模块2021。
其中,所述第三确定模块204,用于确定所述待脱敏数据中是否包含所述首字符和尾字符。
所述第一确定子模块2021,用于在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
在一个实施例中,如图2c所示,所述装置20还包括第四确定模块205。
其中,所述第四确定模块205,用于在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
在一个实施例中,如图2d所示,所述装置20还包括第五确定模块206。
其中,所述第五确定模块206,用于在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
在一个实施例中,如图2e所示,所述第一确定模块202包括第一获取子模块2022、第二确定子模块2023、第三确定子模块2024、第四确定子模块2025和第五确定子模块2026。
其中,所述第一获取子模块2022,用于获取所述码点数组中的初始码点作为第一当前码点组。
所述第二确定子模块2023,用于确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情。
所述第三确定子模块2024,用于在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情。
所述第四确定子模块2025,用于在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点。
所述第五确定子模块2026,用于在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,如图2f所示,所述第一确定模块202还包括第二获取子模块2027、第六确定子模块2028、第七确定子模块2029和第八确定子模块20210。
其中,所述第二获取子模块2027,用于在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组。
所述第六确定子模块2028,用于确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情。
所述第七确定子模块2029,用于在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情。
所述第八确定子模块20210,用于在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
在一个实施例中,如图2g所示,所述第一确定模块202还包括第九确定子模块20211。
其中,所述第九确定子模块20211,用于在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,如图2h所示,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块202还包括第十确定子模块20212、第十一确定子模块20213和第十二确定子模块20214。
其中,所述第十确定子模块20212,用于确定所述第一当前码点组中的第一个码点是否在高位代理区。
所述第十一确定子模块20213,用于在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区。
所述第十二确定子模块20214,用于在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
在一个实施例中,如图2i所示,所述第一确定模块202还包括第十三确定子模块20215。
其中,所述第十三确定子模块20215,用于在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在一个实施例中,如图2j所示,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块202还包括第十四确定子模块20216、第十五确定子模块20217和第十六确定子模块20218。
其中,所述第十四确定子模块20216,用于确定所述第二当前码点组中的第一个码点是否在高位代理区。
所述第十五确定子模块20217,用于在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区。
所述第十六确定子模块20218,用于在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
在一个实施例中,如图2k所示,所述第一确定模块202还包括第十七确定子模块20219。
其中,所述第十七确定子模块20219,用于在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
本公开实施例提供一种数据脱敏装置,该数据脱敏装置包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,处理器被配置为:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据。
在一个实施例中,上述处理器还可被配置为:确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码包括:
在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
在一个实施例中,上述处理器还可被配置为:
在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
在一个实施例中,上述处理器还可被配置为:在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
在一个实施例中,上述处理器还可被配置为:
获取所述码点数组中的初始码点作为第一当前码点组;
确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,上述处理器还可被配置为:
在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
在一个实施例中,上述处理器还可被配置为:
在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,上述处理器还可被配置为:
确定所述第一当前码点组中的第一个码点是否在高位代理区;
在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
在一个实施例中,上述处理器还可被配置为:
在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在一个实施例中,上述处理器还可被配置为:
确定所述第二当前码点组中的第一个码点是否在高位代理区;
在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
在一个实施例中,上述处理器还可被配置为:
在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图3是根据一示例性实施例示出的一种包括该数据脱敏装置的电子设备300的框图,该电子设备适用于终端。例如,电子设备300可以是移动电话,电脑、平板设备等。
电子设备300可以包括以下一个或多个组件:处理组件301,存储器302,电源组件303,多媒体组件304,音频组件305,输入/输出(I/O)接口306,传感器组件307,以及通信组件308。
处理组件301通常控制电子设备300的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件301可以包括一个或多个处理器320来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件301可以包括一个或多个模块,便于处理组件301和其他组件之间的交互。例如,处理组件301可以包括多媒体模块,以方便多媒体组件304和处理组件301之间的交互。
存储器302被配置为存储各种类型的数据以支持在电子设备300的操作。这些数据的示例包括用于在电子设备300上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器302可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件303为电子设备300的各种组件提供电力,包括上述实施例中所述的供电电路。电源组件303可以包括电源管理系统,一个或多个电源,及其他与为电子设备300生成、管理和分配电力相关联的组件。
多媒体组件304包括在所述电子设备300和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件304包括一个前置摄像头和/或后置摄像头。当电子设备300处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件305被配置为输出和/或输入音频信号。例如,音频组件305包括一个麦克风(MIC),当电子设备300处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器302或经由通信组件308发送。在一些实施例中,音频组件305还包括一个扬声器,用于输出音频信号。
输入/输出(I/O)接口306为处理组件301和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件307包括一个或多个传感器,用于为电子设备300提供各个方面的状态评估。例如,传感器组件307可以检测到电子设备300的打开/关闭状态,组件的相对定位,例如所述组件为电子设备300的显示器和小键盘,传感器组件307还可以检测电子设备300或电子设备300一个组件的位置改变,用户与电子设备300接触的存在或不存在,电子设备300方位或加速/减速和电子设备300的温度变化。传感器组件307可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件307还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件307还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件308被配置为便于电子设备300和其他设备之间有线或无线方式的通信。电子设备300可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信组件308经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件308还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备300可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器302,上述指令可由电子设备300的处理器320执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
本公开实施例提供一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行上述数据脱敏方法,所述方法包括:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据。
在一个实施例中,在根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码之前,还包括:
确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码包括:
在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
在一个实施例中,还包括:
在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
在一个实施例中,还包括:
在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
在一个实施例中,根据所述码点数组确定所述待脱敏数据的首字符是否为目标码,在确定所述待脱敏数据的首字符为目标码时,将目标码确定为对应的脱敏数据的首字符包括:
获取所述码点数组中的初始码点作为第一当前码点组;
确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,根据所述码点数组确定所述待脱敏数据的尾字符是否为目标码,在确定所述待脱敏数据的尾字符为目标码时,将目标码确定为对应的脱敏数据的尾字符包括:
在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
在一个实施例中,还包括:
在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
在一个实施例中,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第一当前码点组中的第一个码点是否在高位代理区;
在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
在一个实施例中,还包括:
在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
在一个实施例中,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第二当前码点组中的第一个码点是否在高位代理区;
在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
在一个实施例中,还包括:
在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。

Claims (22)

1.一种数据脱敏方法,其特征在于,包括:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据,
根据所述码点数组确定所述待脱敏数据的首字符是否为目标码,在确定所述待脱敏数据的首字符为目标码时,将目标码确定为对应的脱敏数据的首字符包括:
获取所述码点数组中的初始码点作为第一当前码点组;
确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
2.根据权利要求1所述的方法,其特征在于,在根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码之前,还包括:
确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码包括:
在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
3.根据权利要求2所述的方法,其特征在于,还包括:
在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
4.根据权利要求1所述的方法,其特征在于,还包括:
在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
5.根据权利要求1所述的方法,其特征在于,根据所述码点数组确定所述待脱敏数据的尾字符是否为目标码,在确定所述待脱敏数据的尾字符为目标码时,将目标码确定为对应的脱敏数据的尾字符包括:
在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
6.根据权利要求1所述的方法,其特征在于,还包括:
在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
7.根据权利要求5所述的方法,其特征在于,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第一当前码点组中的第一个码点是否在高位代理区;
在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
8.根据权利要求7所述的方法,其特征在于,还包括:
在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
9.根据权利要求5所述的方法,其特征在于,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,还包括:
确定所述第二当前码点组中的第一个码点是否在高位代理区;
在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
10.根据权利要求9所述的方法,其特征在于,还包括:
在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
11.一种数据脱敏装置,其特征在于,包括:
获取模块,用于获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
第一确定模块,用于根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
第二确定模块,用于根据预设字符串和所述目标码确定所述脱敏数据,
所述第一确定模块还包括第一获取子模块、第二确定子模块、第三确定子模块、第四确定子模块和第五确定子模块;
所述第一获取子模块,用于获取所述码点数组中的初始码点作为第一当前码点组;
所述第二确定子模块,用于确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
所述第三确定子模块,用于在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
所述第四确定子模块,用于在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
所述第五确定子模块,用于在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
12.根据权利要求11所述的装置,其特征在于,还包括第三确定模块,所述第一确定模块包括第一确定子模块;
所述第三确定模块,用于确定所述待脱敏数据中是否包含所述首字符和尾字符;
所述第一确定子模块,用于在确定所述待脱敏数据中包含所述首字符和所述尾字符时,根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码。
13.根据权利要求12所述的装置,其特征在于,还包括第四确定模块;
所述第四确定模块,用于在确定所述待脱敏数据中只包含首字符时,确定所述待脱敏数据的首字符是否为目标码。
14.根据权利要求13所述的装置,其特征在于,还包括第五确定模块;
所述第五确定模块,用于在确定所述待脱敏数据的首字符和/或尾字符为非目标码时,将所述非目标码确定为对应的脱敏数据的首字符和/或尾字符。
15.根据权利要求11所述的装置,其特征在于,所述第一确定模块还包括第二获取子模块、第六确定子模块、第七确定子模块和第八确定子模块;
所述第二获取子模块,用于在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情,或者,在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,获取所述码点数组中的终止码点作为第二当前码点组;
所述第六确定子模块,用于确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情;
所述第七确定子模块,用于在确定所述表情数据库中未存储有与所述第二当前码点组中每个码点对应的表情时,将前一码点和所述第二当前码点组按顺序排列作为新的第二当前码点组,并返回执行步骤确定所述表情数据库中是否存储有与所述第二当前码点组中每个码点对应的表情,直至所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
所述第八确定子模块,用于在确定所述表情数据库中存储有与所述第二当前码点组中每个码点对应的表情时,将所述第二当前码点组确定为所述脱敏数据的尾字符。
16.根据权利要求11所述的装置,其特征在于,所述第一确定模块还包括第九确定子模块;
所述第九确定子模块,用于在确定所述第一当前码点组中的最后一个码点为数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
17.根据权利要求15所述的装置,其特征在于,在所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块还包括第十确定子模块、第十一确定子模块和第十二确定子模块;
所述第十确定子模块,用于确定所述第一当前码点组中的第一个码点是否在高位代理区;
所述第十一确定子模块,用于在确定所述第一当前码点组中的第一个码点在所述高位代理区时,确定所述第一当前码点组中的第二个码点是否在低位代理区;
所述第十二确定子模块,用于在确定所述第一当前码点组中的第二个码点在所述低位代理区时,将所述第一当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的首字符。
18.根据权利要求17所述的装置,其特征在于,所述第一确定模块还包括第十三确定子模块;
所述第十三确定子模块,用于在确定所述第一当前码点组中的第一个码点未在所述高位代理区时,将所述第一当前码点组中的第一个码点确定为脱敏数据的首字符。
19.根据权利要求15所述的装置,其特征在于,在所述第二当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情时,所述第一确定模块还包括第十四确定子模块、第十五确定子模块和第十六确定子模块;
所述第十四确定子模块,用于确定所述第二当前码点组中的第一个码点是否在高位代理区;
所述第十五确定子模块,用于在确定所述第二当前码点组中的第一个码点在所述高位代理区时,确定所述第二当前码点组中的第二个码点是否在低位代理区;
所述第十六确定子模块,用于在确定所述第二当前码点组中的第二个码点在所述低位代理区时,将所述第二当前码点组中的第一个码点和所述第二个码点确定为所述脱敏数据的尾字符。
20.根据权利要求19所述的装置,其特征在于,所述第一确定模块还包括第十七确定子模块;
所述第十七确定子模块,用于在确定所述第二当前码点组中的第二个码点未在所述低位代理区时,将所述第二当前码点组中的第二个码点确定为脱敏数据的尾字符。
21.一种数据脱敏装置,其特征在于,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取待脱敏数据的码点数组;所述码点数组中的码点包括统一码的码点;
根据所述码点数组确定所述待脱敏数据的首字符和尾字符是否为目标码,在确定所述待脱敏数据的首字符和/或尾字符为目标码时,将目标码确定为对应的脱敏数据的首字符和/或尾字符;所述目标码包括统一码的非基本多语言平面的字符或者表情;
根据预设字符串和所述目标码确定所述脱敏数据,
根据所述码点数组确定所述待脱敏数据的首字符是否为目标码,在确定所述待脱敏数据的首字符为目标码时,将目标码确定为对应的脱敏数据的首字符包括:
获取所述码点数组中的初始码点作为第一当前码点组;
确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情;
在确定所述表情数据库中未存储有所述第一当前码点组中每个码点对应的表情时,将所述第一当前码点组和下一码点作为新的第一当前码点组,并返回执行步骤确定表情数据库中是否存储有与所述第一当前码点组中每个码点对应的表情,直至所述第一当前码点组包括所述码点数组中的所有码点,且所述表情数据库中未存储有与所述所有码点对应的表情;
在确定所述表情数据库中存储有与所述第一当前码点组中每个码点对应的表情时,确定所述第一当前码点组中的最后一个码点是否为数据结束码点;
在确定所述第一当前码点组中的最后一个码点为非数据结束码点时,将所述第一当前码点组确定为所述脱敏数据的首字符。
22.一种计算机可读存储介质,其上存储有计算机指令,其特征在于,该指令被处理器执行时实现权利要求1至10任意一项权利要求所述方法的步骤。
CN201910357401.5A 2019-04-29 2019-04-29 数据脱敏方法及装置 Active CN110084065B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910357401.5A CN110084065B (zh) 2019-04-29 2019-04-29 数据脱敏方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910357401.5A CN110084065B (zh) 2019-04-29 2019-04-29 数据脱敏方法及装置

Publications (2)

Publication Number Publication Date
CN110084065A CN110084065A (zh) 2019-08-02
CN110084065B true CN110084065B (zh) 2021-07-30

Family

ID=67417831

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910357401.5A Active CN110084065B (zh) 2019-04-29 2019-04-29 数据脱敏方法及装置

Country Status (1)

Country Link
CN (1) CN110084065B (zh)

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101827102A (zh) * 2010-04-20 2010-09-08 中国人民解放军理工大学指挥自动化学院 基于内容过滤的数据防护方法
US9042554B2 (en) * 2012-11-30 2015-05-26 The Nielsen Company (Us), Llc Methods, apparatus, and articles of manufacture to encode auxilary data into text data and methods, apparatus, and articles of manufacture to obtain encoded data from text data
CN105516464A (zh) * 2015-11-26 2016-04-20 厦门美图移动科技有限公司 一种来电数据隐私保护方法、装置和移动终端
CN106375990A (zh) * 2016-10-21 2017-02-01 上海统宁科技发展有限公司 一种手机隐私数据的加解密系统和加解密方法
CN106407843A (zh) * 2016-10-17 2017-02-15 深圳中兴网信科技有限公司 数据脱敏方法和数据脱敏装置
CN106874253A (zh) * 2015-12-11 2017-06-20 腾讯科技(深圳)有限公司 识别敏感信息的方法及装置
CN108304725A (zh) * 2018-02-09 2018-07-20 山东汇贸电子口岸有限公司 一种对政务数据资源脱敏的方法及系统
CN108664812A (zh) * 2018-05-14 2018-10-16 阿里巴巴集团控股有限公司 信息脱敏方法、装置及系统
CN109478221A (zh) * 2016-05-27 2019-03-15 查特通信营运有限责任公司 敏感数据的安全传输
CN109614816A (zh) * 2018-11-19 2019-04-12 平安科技(深圳)有限公司 数据脱敏方法、装置及存储介质

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107491477B (zh) * 2017-06-30 2021-02-19 百度在线网络技术(北京)有限公司 一种表情符号搜索方法及装置

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101827102A (zh) * 2010-04-20 2010-09-08 中国人民解放军理工大学指挥自动化学院 基于内容过滤的数据防护方法
US9042554B2 (en) * 2012-11-30 2015-05-26 The Nielsen Company (Us), Llc Methods, apparatus, and articles of manufacture to encode auxilary data into text data and methods, apparatus, and articles of manufacture to obtain encoded data from text data
CN105516464A (zh) * 2015-11-26 2016-04-20 厦门美图移动科技有限公司 一种来电数据隐私保护方法、装置和移动终端
CN106874253A (zh) * 2015-12-11 2017-06-20 腾讯科技(深圳)有限公司 识别敏感信息的方法及装置
CN109478221A (zh) * 2016-05-27 2019-03-15 查特通信营运有限责任公司 敏感数据的安全传输
CN106407843A (zh) * 2016-10-17 2017-02-15 深圳中兴网信科技有限公司 数据脱敏方法和数据脱敏装置
CN106375990A (zh) * 2016-10-21 2017-02-01 上海统宁科技发展有限公司 一种手机隐私数据的加解密系统和加解密方法
CN108304725A (zh) * 2018-02-09 2018-07-20 山东汇贸电子口岸有限公司 一种对政务数据资源脱敏的方法及系统
CN108664812A (zh) * 2018-05-14 2018-10-16 阿里巴巴集团控股有限公司 信息脱敏方法、装置及系统
CN109614816A (zh) * 2018-11-19 2019-04-12 平安科技(深圳)有限公司 数据脱敏方法、装置及存储介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
PHP只显示姓名首尾字符,隐藏中间字符并用*替换;admin;《http://fmwei.com/php/substr_cut.html》;20160402;第1-2页 *
判断字符串中是否包含Emoji表情代码;滴水微澜;《https://www.bbsmax.com/A/l1dyek7gde/》;20151208;第1-3页 *

Also Published As

Publication number Publication date
CN110084065A (zh) 2019-08-02

Similar Documents

Publication Publication Date Title
EP3300407A1 (en) Method and device for processing verification code
CN110781813B (zh) 图像识别方法及装置、电子设备和存储介质
EP3176999B1 (en) Method and device for processing information
CN105426094B (zh) 信息粘贴方法及装置
US11335348B2 (en) Input method, device, apparatus, and storage medium
CN107193393B (zh) 输入法切换方法及装置
EP3168755A1 (en) Method and device for adding font
US20170316011A1 (en) Method and apparatus for searching resource
CN113705225A (zh) 敏感词数据处理方法、装置和电子设备
CN111061452A (zh) 用户界面的语音控制方法和装置
CN105468606B (zh) 网页保存的方法及装置
CN107179837B (zh) 输入方法及装置
CN110213062B (zh) 处理消息的方法及装置
CN108108356B (zh) 一种文字翻译方法、装置及设备
CN110084065B (zh) 数据脱敏方法及装置
CN111667827B (zh) 应用程序的语音控制方法、装置及存储介质
US10871832B2 (en) Method and device for obtaining operation entry, and storage medium
CN107526683B (zh) 应用程序功能冗余度的检测方法、装置及存储介质
CN108345590B (zh) 一种翻译方法、装置、电子设备以及存储介质
CN112068793A (zh) 一种语音输入方法及装置
CN108241438B (zh) 一种输入方法、装置和用于输入的装置
CN107102747B (zh) 一种信息输入方法、装置和用于信息输入的装置
CN112507162B (zh) 信息处理方法、装置、终端及存储介质
CN117093267B (zh) 分支指令跳转地址的存储方法、装置、设备及存储介质
CN109408623B (zh) 信息处理方法及装置

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