• 19 年写的

    import hashlib
    import base64
    from public.api_common import api_sign,project_type
    from public.log import logger
    # mylog=logger('验签模块').get_logger()
    class checkSign:
        # 初始化传入dict
        def __init__(self, dict):
            # mylog.info(f"请求参数:{dict}")
            # 不改变传入的data=>直接对字典进行复制
            data = dict.copy()
            self.dict = data
    
        def check_dict(self):
            # 首先判断字典是否空,为空直接加密
            if not self.dict:
                string = ''
                if project_type != 3:
                    return {"X-MPMALL-Sign": self.__sign(string)}
                else:
                    return {"X-Sign": self.__sign(string)}
            else:
                # 非空字典,过滤value为空和嵌套字典、列表
                for k, v in list(self.dict.items()):
                    if v == '' or v is None:
                        self.dict.pop(k)
                    for k, v in list(self.dict.items()):
                        if type(
                                self.dict[k]).__name__ == 'dict'or type(
                                self.dict[k]).__name__ == 'list':
                            self.dict.pop(k)
                # 对字典进行ASCII码排序
                new_list = sorted(self.dict.items())
                alist = []
                for i in new_list:
                    data = '&' + str(i[0]) + '=' + str(i[1])
                    alist.append(data)
                new_string = ''.join(alist)
                if project_type != 3:
                    return {"X-MPMALL-Sign": self.__sign(new_string)}
                else:
                    return {"X-Sign": self.__sign(new_string)}
        # 私有方法,生成签名
    
        def __sign(self, string):
            if string:
                sign = string[1:] + '&key=' + api_sign  # 测试环境
                m = hashlib.md5()
                m.update(sign.encode("utf8"))
                encodeStr = m.hexdigest()
                base_code = base64.b64encode(encodeStr.encode('utf-8'))
                print(api_sign)
                return str(base_code, 'utf-8')
            else:
                sign = 'key=' + api_sign
                m = hashlib.md5()
                m.update(sign.encode("utf8"))
                encodeStr = m.hexdigest()
                base_code = base64.b64encode(encodeStr.encode('utf-8'))
                return str(base_code, 'utf-8')
    
  • F12 就可以了

  • 赞👍🏻等一个接口关联功能

  • 一般接口的 response headers 里面的 Content-Disposition 会有 filename,可以用这个;又或者自己重新自定义文件名,接口名 + 时间戳,一般就不会重复了

  • FunLine 数据工厂开源 at 2024年01月16日
    1. 注释写起来不算麻烦吧,反正都是可以 cv,看了团队其他人写的,参数最多也就 4 个
    2. 至于维护,就算接口自动化平台分离出来的造数脚本,也要一直维护,少不了这事
    3. 如果不想写注释的话,其实可以新加个功能,在页面自定义新增,那种我觉得更加复杂,譬如这下面的(图源另一小组开发的数据工厂) 以上个人见解~
  • FunLine 数据工厂开源 at 2024年01月08日

    测试人员的

  • 总结得不错,但是太多斜体,看得费劲😂

  • 裁员 ing.jpg

  • 大佬能指点一下方向吗 at 2023年11月20日

    有能力就转开发吧

  • A 佬牛逼!