• 【转】js生成接口请求参数签名加密


    js生成接口请求参数签名加密

    签名算法规则:

    第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。
    第二步,在stringA最后拼接上KEY得到stringSignTemp字符串(即stringSignTemp = stringA + &key=KEY),并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue
    用于签名的密钥KEY值为keysecret
    注意事项:
    a、参数名ASCII码从小到大排序(字典序);
    b、如果参数的值为空(即null或空字符串)不参与签名;
    c、参数名区分大小写;
    d、验证签名时,传送的sign参数不参与签名,将生成的签名与该sign值作校验;

    e、接口可能增加字段,验证签名时必须支持增加的扩展字段;

    将所有参数字段按首字母排序, 拼接成key1 = value1 & key2 = value2的格式,再在末尾拼接上key = appSecret, 再做MD5加密生成sign,方法如下:

    functiongetSign(params, kAppKey, kAppSecret) {
        if (typeof params == "string") {
            return paramsStrSort(params);
        } else if (typeof params == "object") {
            var arr = [];
            for (var i in params) {
                arr.push((i + "=" + params[i]));
            }
            return paramsStrSort(arr.join(("&")));
        }
    }
    
    functionparamsStrSort(paramsStr) {
        var url = paramsStr + "&appKey=" + kAppKey;
        var urlStr = url.split("&").sort().join("&");
        var newUrl = urlStr + '&key=' + kAppSecret;
        return md5(newUrl);
    }

    调用:

    var params = "xid=" + xid + "&type=" + type + "&pageSize=" + pageSize + "&pageNo=" + pageNo;
    var sign = getSign(params, kAppKey, kAppSecret);

    或:

    var paramsObj = { xid: xid, pageSize: pageSize, type: type, pageNo: pageNo };
    var sign = getSign(paramsObj, kAppKey, kAppSecret);

    kAppKey,kAppSecret为常量,一般由后端定义好!签名加密方法依托MD5!

    GitHub地址

    也可以使用 js-md5crypto 进行md5加密

    转自:https://www.cnblogs.com/jone-chen/p/8143285.html

  • 相关阅读:
    互联网协议入门
    C++解决约瑟夫环(史上最清晰)
    C# 最快的逐一打印斐波那契结果数列的算法
    二叉树的遍历(转载)
    C# 多线程join的用法,等待多个子线程结束后再执行主线程
    剖丁解牛式的快速排序分析
    用CTE结合排名函数rank()删除某列值重复的记录
    Http 头部属性详解
    C# 冒泡排序
    设计模式七大原则之依赖倒转原则
  • 原文地址:https://www.cnblogs.com/hycms/p/9333064.html
Copyright © 2020-2023  润新知