Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

encryption.js 4.7KB

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