Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

encryption.js 5.2KB

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