Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

encryption.js 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  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. // console.log("signStr*************"+signStr);
  66. if (!requestId) {
  67. return false;
  68. }
  69. signStr = md5(signStr);
  70. signStr = signStr.toUpperCase();
  71. // console.log('MD5**************' + signStr);
  72. signStr += requestId;
  73. // console.log('requestId**************' + signStr);
  74. signStr = sha1(signStr);
  75. signStr = signStr.toUpperCase();
  76. // console.log('SHA1**************' + signStr);
  77. return signStr;
  78. }
  79. //arrayToJsonString array 转json字符串
  80. export function arrayToJsonString(array) {
  81. var json = {};
  82. for (var i in array) {
  83. if (array[i] instanceof Array) {
  84. json[i] = {};
  85. for (var o in array[i]) {
  86. if (array[i][o] instanceof Array) {
  87. json[i][o] = {};
  88. for (var q in array[i][o]) {
  89. if (array[i][o][q] instanceof Array) {
  90. json[i][o][q] = {};
  91. for (var w in array[i][o][q]) {
  92. json[i][o][q][w] = array[i][o][q][w];
  93. }
  94. } else {
  95. json[i][o][q] = array[i][o][q];
  96. }
  97. }
  98. } else {
  99. json[i][o] = array[i][o];
  100. }
  101. }
  102. } else {
  103. json[i] = array[i];
  104. }
  105. }
  106. return JSON.stringify(json);
  107. }
  108. /**
  109. *json字符串转换成json对象
  110. */
  111. export function stringToJson(data) {
  112. let index = data.lastIndexOf("}")
  113. let content = data.substring(0, index + 1);
  114. return JSON.parse(content);
  115. }
  116. //array转json对象
  117. export function arrayToJson(array) {
  118. return stringToJson(arrayToJsonString(array));
  119. }
  120. // 判断是否是微信小程序
  121. export function isWeixin() {
  122. if (getItem("loginSource") == '69af303ba2eb4608a099163f0d2a5dbd') {
  123. return true;
  124. } else {
  125. return false;
  126. }
  127. }
  128. //时间格式化
  129. export function formatTime(date) {
  130. const year = date.getFullYear();
  131. const month = date.getMonth() + 1;
  132. const day = date.getDate();
  133. const hour = date.getHours();
  134. const minute = date.getMinutes();
  135. const second = date.getSeconds();
  136. return `${[year, month, day].map(formatNumber).join("-")}T${[
  137. hour,
  138. minute,
  139. second,
  140. ]
  141. .map(formatNumber)
  142. .join(":")}`;
  143. }
  144. function formatNumber(n) {
  145. n = n.toString();
  146. return n[1] ? n : `0${n}`;
  147. }
  148. function textToBase64(text, key, iv) {
  149. const keyBytes = new TextEncoder().encode(key);
  150. const ivBytes = new TextEncoder().encode(iv);
  151. const textBytes = new TextEncoder().encode(text);
  152. const encrypted = sm4.encrypt(textBytes, keyBytes, {
  153. mode: 'cbc',
  154. iv: ivBytes
  155. });
  156. console.log('输出内容', encrypted)
  157. const base64 = uni.arrayBufferToBase64(encrypted);
  158. return base64;
  159. }
  160. //调用中台参数
  161. // export function encryption(ifCode, subdata, type) {
  162. // var requestData = new Array();
  163. // requestData["ifCode"] = ifCode;
  164. // // requestData["appId"] = "52030131"; // || "admin001"
  165. // requestData["appId"] = "admin001"; // || "admin001"
  166. // requestData["signType"] = "MD5"; // || "NONE"
  167. // // requestData["encryptType"] = "SM4";
  168. // requestData["encryptType"] = "NONE";
  169. // requestData["reqId"] = requestData["appId"] + "_" + getDate() + "_" + generateMixed(5);
  170. // requestData["timestamp"] = formatTime(new Date());
  171. // // requestData["bizContent"] = s4.encryptData_CBC(subdata, sm4Key)
  172. // requestData["bizContent"] = JSON.stringify(subdata)
  173. // requestData["sign"] = md5(
  174. // "bizContent=" + requestData["bizContent"] +
  175. // "&signType=" + requestData["signType"] +
  176. // "&encryptType=" + requestData["encryptType"] +
  177. // "&timestamp=" + requestData["timestamp"] +
  178. // "&ifCode=" + requestData["ifCode"]
  179. // );
  180. // let endData = arrayToJson(requestData);
  181. // return endData;
  182. // }
  183. //调用中台参数
  184. export function encryption(ifCode, subdata, type) {
  185. var requestData = new Array();
  186. // const key = 'WVdSdGFXNHdNREZmTWpBeU16QTRNRE09'
  187. const key = 'TlRJd016QXhNekZmTWpBeU16QTRNekU9'
  188. requestData["ifCode"] = ifCode;
  189. requestData["appId"] = "52030131"; // || "admin001"
  190. // requestData["appId"] = "admin001"; // || "admin001"
  191. requestData["signType"] = "SM3"; // || "NONE"
  192. requestData["encryptType"] = "SM4";
  193. // requestData["encryptType"] = "NONE";
  194. requestData["reqId"] = requestData["appId"] + "_" + getDate() + "_" + generateMixed(5);
  195. requestData["timestamp"] = formatTime(new Date());
  196. requestData["bizContent"] = s4.encryptData_CBC(subdata, sm4Key)
  197. // requestData["bizContent"] = JSON.stringify(subdata)
  198. requestData["accessToken"] = getItem(StorageKeys.Token)
  199. requestData["sign"] = sm3(
  200. "appId=" + requestData["appId"] +
  201. "&bizContent=" + requestData["bizContent"] +
  202. "&signType=" + requestData["signType"] +
  203. "&encryptType=" + requestData["encryptType"] +
  204. "&timestamp=" + requestData["timestamp"] +
  205. "&ifCode=" + requestData["ifCode"] +
  206. "&reqId=" + requestData["reqId"] +
  207. "&accessToken=" + requestData["accessToken"], key
  208. );
  209. let endData = arrayToJson(requestData);
  210. return endData;
  211. }