一个简单的验证字符串是否为Base64编码的方法
2017-12-21 11:03
666 查看
一个简单的验证字符串是否为Base64编码的方法
2.base64是把3个字节变成4个可打印字符,所以base64编码后的字符串一定能被4整除(不算用作后缀的等号);
3.等号一定用作后缀,且数目一定是0个、1个或2个。这是因为如果原文长度不能被3整除,base64要在后面添加\0凑齐3n位。为了正确还原,添加了几个\0就加上几个等号。显然添加等号的数目只能是0、1或2
4.严格来说base64不能算是一种加密,只能说是编码转换。使用base64的初衷。是为了方便把含有不可见字符串的信息用可见字符串表示出来,以便复制粘贴;
Base64 encode 说明
1.标准base64只有64个字符(英文大小写、数字和+、/)以及用作后缀等号;2.base64是把3个字节变成4个可打印字符,所以base64编码后的字符串一定能被4整除(不算用作后缀的等号);
3.等号一定用作后缀,且数目一定是0个、1个或2个。这是因为如果原文长度不能被3整除,base64要在后面添加\0凑齐3n位。为了正确还原,添加了几个\0就加上几个等号。显然添加等号的数目只能是0、1或2
4.严格来说base64不能算是一种加密,只能说是编码转换。使用base64的初衷。是为了方便把含有不可见字符串的信息用可见字符串表示出来,以便复制粘贴;
def is_base64_code(s): '''Check s is Base64.b64encode''' if not isinstance(s ,str) or not s: raise ValueError, "params s not string or None" _base64_code = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4','5', '6', '7', '8', '9', '+', '/', '=' ] # Check base64 OR codeCheck % 4 code_fail = [ i for i in s if i not in _base64_code] if code_fail or len(s) % 4 != 0: return False return True
验证一下
# ➜ ~ echo "wuyiyi" | base64 # d3V5aXlpCg== print is_base64_code("d3V5aXlpCg==")
相关文章推荐
- c/c++ 使用boost库实现的一个简单判断字符串编码的方法
- 一个验证字符串是否纯英语的方法
- 想到一个对于灵魂是否存在的简单可行的验证方法
- Asp.Net判断一个字符串是否包含某个字符的最简单方法!(示例)
- 编写一个方法用于验证指定的字符串是否为反转字符,返回true和false。请用递归算法实现
- 判断一个字符串中是否含有中文的简单方法
- Android工具类,一些方法电话正则,是否为空,日期格式化,星期,车牌,身份证校验,设置地区编码,验证日期字符串是否是YYYY-MM-DD格式,判断字符串是否为数字
- 判断一个字符串是否全是数字的多种方法及其性能比较(C#实现)
- SQL中获取一个长字符串中某个字符串出现次数的简单方法
- 几种验证字符串是否全为数字方法的比较
- 利用ajax技术验证数据是否存在的一个简单例子
- SQL中获取一个长字符串中某个字符串出现次数的简单方法
- SQL中获取一个长字符串中某个字符串出现次数的简单方法
- PHP判断字符串编码是否utf8并转换的方法
- asp.net验证一个字符串是否符合指定的正则表达式
- Route 66地图安装的一个简单方法,在N70上验证过
- 一个超简单的方法验证文本框中内容的数据类型
- 验证输入内容是否为数字的简单方法
- SQL中获取一个长字符串中某个字符串出现次数的简单方法(函数)
- (转)判断一个字符串是否全是数字的多种方法及其性能比较(C#实现