From f3793037f0e56530d9ec79dc48feebf086543fb3 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期五, 25 十月 2024 11:40:33 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
Source/plt-web/plt-web-ui/src/util/func.js | 92 ++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 92 insertions(+), 0 deletions(-)
diff --git a/Source/plt-web/plt-web-ui/src/util/func.js b/Source/plt-web/plt-web-ui/src/util/func.js
index 2eb5052..e342467 100644
--- a/Source/plt-web/plt-web-ui/src/util/func.js
+++ b/Source/plt-web/plt-web-ui/src/util/func.js
@@ -1,7 +1,54 @@
/**
* 閫氱敤宸ュ叿绫�
*/
+import CryptoJS from 'crypto-js'
+
export default class func {
+ /**
+ * 鍗曢�夎〃鏍艰
+ * 鏃堕棿鎴虫牸寮忓寲
+ */
+ static formattedDate(val) {
+ // 鍒涘缓涓�涓� Date 瀵硅薄
+ const date = new Date(val);
+
+ // 鏍煎紡鍖栨椂闂寸殑杈呭姪鍑芥暟
+ const formatNumber = (number) => String(number).padStart(2, '0');
+
+ // 鎻愬彇骞舵牸寮忓寲骞淬�佹湀銆佹棩銆佸皬鏃躲�佸垎閽熷拰绉�
+ const year = date.getFullYear();
+ const month = formatNumber(date.getMonth() + 1); // 鏈堜唤浠�0寮�濮嬶紝闇�瑕�+1
+ const day = formatNumber(date.getDate());
+ const hours = formatNumber(date.getHours());
+ const minutes = formatNumber(date.getMinutes());
+ const seconds = formatNumber(date.getSeconds());
+
+ // 鏍煎紡鍖栦负 YYYY-MM-DD HH:MM:SS
+ return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
+ }
+
+ /**
+ * 鍗曢�夎〃鏍艰
+ * row 褰撳墠琛屾暟鎹�
+ * CrudRef 琛ㄦ牸ref缁戝畾鍊�
+ * lastIndex 鍒ゆ柇浜屾鐐瑰嚮index鏄惁鍜岀涓�娆$偣鍑讳竴鑷�
+ * setLastIndex 鏇存柊lastIndex鍊�
+ * setSelectList 灏嗕笅鎷夋淇濆瓨鏁扮粍缃┖
+ */
+
+ static rowClickHandler(row, CrudRef, lastIndex, setLastIndex, setSelectList) {
+ if (lastIndex === row.$index) {
+ setSelectList();
+ CrudRef.clearSelection();
+ } else {
+ setSelectList();
+ CrudRef.clearSelection();
+ CrudRef.toggleRowSelection(row);
+ }
+
+ setLastIndex(row.$index);
+ }
+
/**
* 涓嶄负绌�
* @param val
@@ -184,5 +231,50 @@
return item[attr] !== array[0][attr];
});
}
+
+ /**
+ * 3des鍔犲瘑
+ * @param message
+ * @param key
+ * @returns {string}
+ */
+ encryptByDES(message, key) {
+ const keyHex = CryptoJS.enc.Utf8.parse(key);
+ const encrypted = CryptoJS.DES.encrypt(message, keyHex, {
+ mode: CryptoJS.mode.ECB,
+ padding: CryptoJS.pad.Pkcs7
+ });
+ return encrypted.toString();
+ }
+
+ /**
+ * HmacMD5鍔犲瘑
+ * @param message
+ * @param key
+ * @returns {string}
+ * @constructor
+ */
+ static HmacMD5(message, key) {
+ const encrypted = CryptoJS.HmacMD5(message, key);
+ return encrypted.toString();
+ }
+
+ /**
+ * aes鍔犲瘑
+ * @param data
+ * @param secretKey
+ * @returns {string}
+ */
+ static encryptData(data, secretKey) {
+ const key = CryptoJS.enc.Utf8.parse(secretKey);
+ const iv = CryptoJS.enc.Utf8.parse(secretKey.substr(0, 16)); // AES block size is 128 bits (16 bytes)
+ const encrypted = CryptoJS.AES.encrypt(data, key, {
+ iv: iv,
+ mode: CryptoJS.mode.CBC,
+ padding: CryptoJS.pad.Pkcs7
+ });
+ return encrypted.toString();
+ }
}
+
--
Gitblit v1.9.3