You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

encryption.js 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. import {
  2. ksort
  3. } from "../util/ksort.js";
  4. import {
  5. md5
  6. } from "../util/md5.js";
  7. import {
  8. sha1
  9. } from "../util/sha1.js";
  10. import {
  11. sm4Key
  12. } from "../network/api.js";
  13. import {
  14. SM4Util
  15. } from '../util/sm4.js'
  16. const s4 = new SM4Util()
  17. const _signCode = "etc123456"; //签名码
  18. function pad2(n) {
  19. return n < 10 ? "0" + n : n;
  20. }
  21. //获取时间ymdHis
  22. function getDate() {
  23. var date = new Date();
  24. return (
  25. date.getFullYear().toString() +
  26. pad2(date.getMonth() + 1) +
  27. pad2(date.getDate()) +
  28. pad2(date.getHours()) +
  29. pad2(date.getMinutes()) +
  30. pad2(date.getSeconds()) +
  31. pad2(date.getMilliseconds())
  32. );
  33. }
  34. /**
  35. * 获取随机数
  36. */
  37. function generateMixed(n) {
  38. var chars = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
  39. var res = "";
  40. for (var i = 0; i < n; i++) {
  41. var id = Math.ceil(Math.random() * 8);
  42. res += chars[id];
  43. }
  44. return res;
  45. }
  46. //签名
  47. function sign(data, signCode) {
  48. data = ksort(data);
  49. var signStr = "";
  50. var requestId = false;
  51. for (let k in data) {
  52. if (k != "sign") {
  53. if (k == "requestId") {
  54. requestId = data[k];
  55. }
  56. signStr += k + "=" + data[k] + "&";
  57. }
  58. }
  59. signStr += "signCode=" + signCode;
  60. // console.log("signStr*************"+signStr);
  61. if (!requestId) {
  62. return false;
  63. }
  64. signStr = md5(signStr);
  65. signStr = signStr.toUpperCase();
  66. // console.log('MD5**************' + signStr);
  67. signStr += requestId;
  68. // console.log('requestId**************' + signStr);
  69. signStr = sha1(signStr);
  70. signStr = signStr.toUpperCase();
  71. // console.log('SHA1**************' + signStr);
  72. return signStr;
  73. }
  74. //arrayToJsonString array 转json字符串
  75. export function arrayToJsonString(array) {
  76. var json = {};
  77. for (var i in array) {
  78. if (array[i] instanceof Array) {
  79. json[i] = {};
  80. for (var o in array[i]) {
  81. if (array[i][o] instanceof Array) {
  82. json[i][o] = {};
  83. for (var q in array[i][o]) {
  84. if (array[i][o][q] instanceof Array) {
  85. json[i][o][q] = {};
  86. for (var w in array[i][o][q]) {
  87. json[i][o][q][w] = array[i][o][q][w];
  88. }
  89. } else {
  90. json[i][o][q] = array[i][o][q];
  91. }
  92. }
  93. } else {
  94. json[i][o] = array[i][o];
  95. }
  96. }
  97. } else {
  98. json[i] = array[i];
  99. }
  100. }
  101. return JSON.stringify(json);
  102. }
  103. /**
  104. *json字符串转换成json对象
  105. */
  106. export function stringToJson(data) {
  107. return JSON.parse(data);
  108. }
  109. //array转json对象
  110. export function arrayToJson(array) {
  111. return stringToJson(arrayToJsonString(array));
  112. }
  113. //时间格式化
  114. export function formatTime(date) {
  115. const year = date.getFullYear();
  116. const month = date.getMonth() + 1;
  117. const day = date.getDate();
  118. const hour = date.getHours();
  119. const minute = date.getMinutes();
  120. const second = date.getSeconds();
  121. return `${[year, month, day].map(formatNumber).join("-")}T${[
  122. hour,
  123. minute,
  124. second,
  125. ]
  126. .map(formatNumber)
  127. .join(":")}`;
  128. }
  129. function formatNumber(n) {
  130. n = n.toString();
  131. return n[1] ? n : `0${n}`;
  132. }
  133. function textToBase64(text, key, iv) {
  134. const keyBytes = new TextEncoder().encode(key);
  135. const ivBytes = new TextEncoder().encode(iv);
  136. const textBytes = new TextEncoder().encode(text);
  137. const encrypted = sm4.encrypt(textBytes, keyBytes, {
  138. mode: 'cbc',
  139. iv: ivBytes
  140. });
  141. console.log('输出内容', encrypted)
  142. const base64 = uni.arrayBufferToBase64(encrypted);
  143. return base64;
  144. }
  145. //调用中台参数
  146. export function encryption(ifCode, subdata, type) {
  147. var requestData = new Array();
  148. requestData["ifCode"] = ifCode;
  149. requestData["appId"] = "52030131"; // || "admin001"
  150. requestData["signType"] = "MD5"; // || "NONE"
  151. requestData["encryptType"] = "SM4";
  152. requestData["reqId"] = requestData["appId"] + "_" + getDate() + "_" + generateMixed(5);
  153. requestData["timestamp"] = formatTime(new Date());
  154. requestData["bizContent"] = s4.encryptData_CBC(subdata, sm4Key)
  155. requestData["sign"] = md5(
  156. "bizContent=" + requestData["bizContent"] +
  157. "&signType=" + requestData["signType"] +
  158. "&encryptType=" + requestData["encryptType"] +
  159. "&timestamp=" + requestData["timestamp"] +
  160. "&ifCode=" + requestData["ifCode"]
  161. );
  162. let endData = arrayToJson(requestData);
  163. return endData;
  164. }