基于python实现数组格式参数加密计算


Posted in Python onApril 21, 2020

代码示例

#输入
'''order_id:31489
join_course[0][join_tel]:13130999882
join_course[0][join_name]:任学雨
join_course[0][join_card_afterfour]:043X
join_course[0][join_school]:铭博教育咨询
join_course[1][join_tel]:13130999883
join_course[1][join_name]:任学雨
join_course[1][join_card_afterfour]:043X
join_course[1][join_school]:铭博教育咨询
join_course[2][join_tel]:13130999884
join_course[2][join_name]:任学雨
join_course[2][join_card_afterfour]:043X
join_course[2][join_school]:铭博教育咨询
join_course[3][join_tel]:13130999885
join_course[3][join_name]:任学雨
join_course[3][join_card_afterfour]:043X
join_course[3][join_school]:铭博教育咨询
timestamp:1574921552698
sign:8936b324e417b31d97f0c3e9a904dssss3'''
#输出
join_course[{"join_tel":"13130999882","join_name":"任学雨","join_card_afterfour":"043X","join_school":"铭博教育咨询"},{"join_tel":"13130999883","join_name":"任学雨","join_card_afterfour":"043X","join_school":"铭博教育咨询"},{"join_tel":"13130999884","join_name":"任学雨","join_card_afterfour":"043X","join_school":"铭博教育咨询"},{"join_tel":"13130999885","join_name":"任学雨","join_card_afterfour":"043X","join_school":"铭博教育咨询"}]order_id31489timestamp1575001757726994(str_encrypt)固定加密字符串

大概思路:

1.将输入字符串切割为list

2.提取数组指定参数

3.提取除sign之外的非数组指定参数并排序(asicc码排序)

4.处理数组参数拼接问题(先处理数组内参数,将key与value转换为字典,再将字典添加至list,最后拼接字符串'join_course‘,拼接非数组参数与加密字符串)

5.计算加密字符串sign并提取输入的字符串

6.拼接最终的字符串,并处理请求数据格式

def fwh_sign_sha1_Array(self,str_in):#服务请求签名处理封装(请求格式为数组时的封装)
    search_time_str='timestamp:'
    search_sign_str='sign:'
    str_inSource=re.search('(%s.+)'%(search_time_str),str_in)#匹配字段时间戳(timestamp)
    if str_inSource is not None:
      time_str=self.get_timestamp()#最终需要的时间戳,13位
      str_inSource=str_inSource.group()
      search_str_inSource=re.search('\s',str_inSource)
      #匹配时间戳,key与value是否包含空格
      #如果包含空格,替换时加上空格,如果不处理会有问题(字符串格式与其他地方不一致)
      if search_str_inSource is not None:
        str_equalSource=re.sub(str_inSource,'%s%s%s'%(search_time_str,search_str_inSource.group(),time_str),
        str_in)#将输入的时间戳替换为需要的时间戳,并加上匹配出来得空格
      else:
        str_equalSource=re.sub(str_inSource,'%s%s'%(search_time_str,time_str),
        str_in)#将输入的时间戳替换为需要的时间戳
      input_list_source=str_equalSource.split('\n')#以换行符分隔字符串并转换位列表
      input_list=[a for a in input_list_source 
        if (search_sign_str or '%s\s'%(search_sign_str) ) not in a]#列表过滤字段sign
      out_str='\n'.join(input_list)#将排序后的list拼接为字符串
      out_list_join_course=[a for a in input_list if ('[' and ']') in a ]#去除数组外的其他参数
      input_list_other=sorted([a for a in input_list if ('[' or ']') not in a ])#获取数组外的其他参数并排序
      input_list_other_str='\n'.join(input_list_other)#将排序后的list拼接为字符串
      input_out_list_other_str=self.requestDataToStr_firefoxAndChrome(input_list_other_str,'','').decode()#获取拼接完成后的请求参数字符串(sign)
      join_course_list=[]#数组
      join_course_dict={}#数组中的dict
      for index,i in enumerate(out_list_join_course):
        join_course_index=i.find('[')
        join_course=i[:join_course_index]#匹配join_course
        Array_index=i[join_course_index:].find(']')#匹配[index]的下标
        Array=i[join_course_index:][:Array_index+1]#取出[index]
        Array_key_data=i[join_course_index:][Array_index+1:]#取出[0]后面的值
        search_colon=Array_key_data.find(':')#匹配出冒号的index
        Array_key=Array_key_data[1:search_colon-1]#匹配key(冒号前面的值)并去除[]
        Array_value=Array_key_data[search_colon+1:]#匹配value(冒号后面的值)
        join_course_dict[Array_key]=Array_value#将匹配出来的key与value添加至dict
        if index+1<len(out_list_join_course):
          #判断上一个元素的部分内容(索引前的内容)是否包含于list下一个元素的内容
          #(如果不包含那么说明当前元素就是本组数据的最后一个,此时将dict添加至对应的list)
          #并清空字典(不清除会导致最终插入的值是重复的,因为key是一样的)
          if join_course+Array not in(out_list_join_course[index+1]):
            join_course_list.append(join_course_dict)
            join_course_dict={}
        else:#如果当前元素是list中的最后一个元素那么直接添加将dict至对应的list
          join_course_list.append(join_course_dict)
          join_course_dict={}
      #将list里面的数组转换为json格式,这里只能对list进行使用,不用对数组中的dict使用
      #ensure_ascii:防止中文被转义,separators:去除字符串中多余的空格
      join_course_list=json.dumps(join_course_list,ensure_ascii=False,separators=(',', ':'))
      #拼接加密前的请求字符串,用换行符区分数组参数与非数组参数(目的是方便转换为list)
      join_course_str=join_course+str(join_course_list)+'\n'+input_out_list_other_str
      join_course_str_list=sorted(join_course_str.split('\n'))#对list进行排序处理
      join_course_last_str=''.join(join_course_str_list)#对排序后的list拼接为字符串
      out_sign_str=self.sha1_Encry(join_course_last_str)#得到加密后的加密字符串
      str_inSource_sign=re.search('(%s.+)'%(search_sign_str),str_in)#匹配字段签名验证(sign)
      if str_inSource_sign is not None:
        str_inSource_sign=str_inSource_sign.group()
        search_inSource_sign=re.search('\s',str_inSource)
        #匹配sign,key与value是否包含空格
        #如果包含空格,替换时加上空格,如果不处理会有问题(字符串格式与其他地方不一致)
        if search_inSource_sign is not None:
          str_last_sign=re.sub(str_inSource_sign,'%s%s%s'%(search_sign_str,search_inSource_sign.group(),
          out_sign_str),str_equalSource)#将输入的时间戳替换为需要的时间戳
        else:
          str_last_sign=re.sub(str_inSource_sign,'%s%s'%(search_sign_str,out_sign_str),
          str_equalSource)#将输入的时间戳替换为需要的时间戳
        # print(str_last_sign)
        str_give=self.requestDataToStr_firefoxAndChrome(str_last_sign)
        return str_give

      else:
        print('输入字符串没有sign对象:sign,无法完成数据转换')
        return None

    else:
      print('输入字符串没有时间戳对象:timestamp,无法完成数据转换')
      return None

期间遇到的问题:

1.dict的单引号在使用json解析时会出问题,需要转换为双引号("),使用json.dumps可处理为这样的格式

2.json.dumps方法的问题:1.中文会自动转义,需指定参数ensure_ascii=false,默认时true;2.转换是会自动产生空格,然而开发加密时没有空格,需要去掉,需指定参数separators=(',', ':')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python基于mysql实现的简单队列以及跨进程锁实例详解
Jul 07 Python
Python3搜索及替换文件中文本的方法
May 22 Python
Python多进程同步简单实现代码
Apr 27 Python
python snownlp情感分析简易demo(分享)
Jun 04 Python
使用python实现knn算法
Dec 20 Python
Python Numpy库安装与基本操作示例
Jan 08 Python
python实现查找所有程序的安装信息
Feb 18 Python
如何基于线程池提升request模块效率
Apr 18 Python
Python连接HDFS实现文件上传下载及Pandas转换文本文件到CSV操作
Jun 06 Python
详解如何在pyqt中通过OpenCV实现对窗口的透视变换
Sep 20 Python
Django中的JWT身份验证的实现
May 07 Python
详解python的内存分配机制
May 10 Python
python实现与redis交互操作详解
Apr 21 #Python
Django-migrate报错问题解决方案
Apr 21 #Python
pandas读取csv文件提示不存在的解决方法及原因分析
Apr 21 #Python
jupyter 导入csv文件方式
Apr 21 #Python
tensorflow指定CPU与GPU运算的方法实现
Apr 21 #Python
Python多线程实现支付模拟请求过程解析
Apr 21 #Python
安装多个版本的TensorFlow的方法步骤
Apr 21 #Python
You might like
php中json_decode()和json_encode()的使用方法
2012/06/04 PHP
PHP中strtr字符串替换用法详解
2014/11/26 PHP
PHP实现一维数组转二维数组的方法
2015/02/25 PHP
PHP获取Exif缩略图的方法
2015/07/13 PHP
PHP时间戳格式全部汇总 (获取时间、时间戳)
2016/06/13 PHP
Laravel 集成微信用户登录和绑定的实现
2019/12/27 PHP
Opacity.js
2007/01/22 Javascript
拖拉表格的JS函数
2008/11/20 Javascript
将Datatable转化成json发送前台实现思路
2013/09/06 Javascript
js字符串完全替换函数分享
2014/12/03 Javascript
小程序清理本地缓存的方法
2018/08/17 Javascript
angular中两种表单的区别(响应式和模板驱动表单)
2018/12/06 Javascript
手把手带你封装一个vue component第三方库
2019/02/14 Javascript
Vue CLI 3.x 自动部署项目至服务器的方法
2019/04/02 Javascript
如何在微信小程序里面退出小程序的方法
2019/04/28 Javascript
小程序中设置缓存过期的实现方法
2020/01/14 Javascript
一则python3的简单爬虫代码
2014/05/26 Python
Python、Javascript中的闭包比较
2015/02/04 Python
Python中的defaultdict模块和namedtuple模块的简单入门指南
2015/04/01 Python
Python的ORM框架中SQLAlchemy库的查询操作的教程
2015/04/25 Python
Python实现的手机号归属地相关信息查询功能示例
2017/06/08 Python
Python中表达式x += y和x = x+y 的区别详解
2017/06/20 Python
python画柱状图--不同颜色并显示数值的方法
2018/12/13 Python
python 通过SSHTunnelForwarder隧道连接redis的方法
2019/02/19 Python
python抓取搜狗微信公众号文章
2019/04/01 Python
windows下Python安装、使用教程和Notepad++的使用教程
2019/10/06 Python
使用opencv中匹配点对的坐标提取方式
2020/06/04 Python
CSS3实现自定义Checkbox特效实例代码
2017/04/24 HTML / CSS
html标签之Object和EMBED标签详解
2013/07/04 HTML / CSS
俄罗斯珠宝市场的领导者之一:Бронницкий ювелир
2019/10/02 全球购物
高中生毕业自我鉴定范文
2013/12/22 职场文书
自考生自我评价分享
2014/01/18 职场文书
铁路个人事迹材料
2014/01/30 职场文书
党员公开承诺书2015
2015/01/21 职场文书
工作失职自我检讨书
2015/05/05 职场文书
亮剑观后感500字
2015/06/05 职场文书