You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

encryption.js 5.6KB

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