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.9KB

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