Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

encryption.js 4.5KB

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