api.js 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. const sm4 = require('../js/SM4');
  2. const SM4Exten = require('../js/SM4Exten');
  3. const miniprogramsm4 = require("../miniprogram_npm/miniprogram-sm-crypto/index").sm4;
  4. const secretId = "D2BCF8DE-AA24-4BF6-9C34-C8DD325E412B"; //小程序应用ID
  5. const Secret = "6C680A47B87740138DFB299FC69A64E1"; //小程序应用密钥
  6. const api_root = 'http://192.168.0.202:5006/'
  7. const CurrentBuId = '12345678-9abc-def0-1234-56789abcdef0';
  8. function request(path, method = 'GET', data = null) {
  9. var WachatID = wx.getStorageSync('WachatID')
  10. return new Promise((resolve, reject) => {
  11. var sign_method = "HMAC_SM4";
  12. var url = api_root + path;
  13. var nonce = generateRandomString();
  14. const timestamp = Date.now();
  15. console.log('data :' + data);
  16. let jsonString = (data != null && method != 'GET') ? JSON.stringify(data) : '';
  17. console.log('request :' + jsonString);
  18. var stringToSign = "sign_method=" + sign_method +
  19. "&secret_id=" + secretId +
  20. "&nonce=" + nonce +
  21. "&timestamp=" + timestamp;
  22. if (jsonString != '') {
  23. stringToSign += "&" + jsonString
  24. }
  25. const resultArray = path.split('?');
  26. if (resultArray.length == 2) {
  27. stringToSign += "&" + resultArray[1]
  28. }
  29. console.log('加密串 :' + stringToSign);
  30. if(path == 'api/Site/GetSiteInfo') console.log('获取站点信息加密串 :' + stringToSign);
  31. let key = stringToHex(Secret); //key转16进制
  32. key = getFirst32Chars(key); //截取前16位
  33. let signature = miniprogramsm4.encrypt(stringToSign, key) //sm4加密
  34. //signature = signature.toUpperCase();
  35. signature = stringToBase64(signature); //加密字符串转base64
  36. console.log('signature :' + signature);
  37. wx.request({
  38. header: {
  39. "sign_method": sign_method,
  40. "secret_id": secretId,
  41. "nonce": nonce,
  42. "timestamp": timestamp,
  43. "signature": signature,
  44. "CurrentBuId": CurrentBuId,
  45. "WachatID": WachatID
  46. },
  47. url: url,
  48. method: method,
  49. data: data,
  50. success: res => {
  51. console.log("success");
  52. resolve(res);
  53. },
  54. fail: res => {
  55. console.log("request fail");
  56. resolve(res);
  57. },
  58. })
  59. });
  60. }
  61. //字符串转base64
  62. function stringToBase64(str) {
  63. // 定义Base64字符集
  64. const base64Chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
  65. // 将字符串转换为UTF-8字节数组
  66. let utf8Bytes = [];
  67. for (let i = 0; i < str.length; i++) {
  68. let charCode = str.charCodeAt(i);
  69. if (charCode < 128) { // 1字节字符
  70. utf8Bytes.push(charCode);
  71. } else if (charCode < 2048) { // 2字节字符
  72. utf8Bytes.push((charCode >> 6) | 192);
  73. utf8Bytes.push((charCode & 63) | 128);
  74. } else if (charCode < 65536) { // 3字节字符
  75. utf8Bytes.push((charCode >> 12) | 224);
  76. utf8Bytes.push(((charCode >> 6) & 63) | 128);
  77. utf8Bytes.push((charCode & 63) | 128);
  78. } else { // 4字节字符
  79. utf8Bytes.push((charCode >> 18) | 240);
  80. utf8Bytes.push(((charCode >> 12) & 63) | 128);
  81. utf8Bytes.push(((charCode >> 6) & 63) | 128);
  82. utf8Bytes.push((charCode & 63) | 128);
  83. }
  84. }
  85. let base64Str = '';
  86. let paddingCount = 0;
  87. // 处理每3个字节(24位),转换为4个Base64字符
  88. for (let i = 0; i < utf8Bytes.length; i += 3) {
  89. let byte1 = utf8Bytes[i];
  90. let byte2 = i + 1 < utf8Bytes.length ? utf8Bytes[i + 1] : 0;
  91. let byte3 = i + 2 < utf8Bytes.length ? utf8Bytes[i + 2] : 0;
  92. let chunk = (byte1 << 16) | (byte2 << 8) | byte3;
  93. let char1 = base64Chars[(chunk >> 18) & 63];
  94. let char2 = base64Chars[(chunk >> 12) & 63];
  95. let char3 = i + 1 < utf8Bytes.length ? base64Chars[(chunk >> 6) & 63] : '=';
  96. let char4 = i + 2 < utf8Bytes.length ? base64Chars[chunk & 63] : '=';
  97. base64Str += char1 + char2 + char3 + char4;
  98. // 计算需要填充的'='号数量
  99. if (i + 2 >= utf8Bytes.length) {
  100. paddingCount = (utf8Bytes.length - i) % 3;
  101. }
  102. }
  103. return base64Str;
  104. }
  105. //截取字符串
  106. function getFirst32Chars(str) {
  107. if (typeof str !== 'string') {
  108. throw new Error('Input must be a string');
  109. }
  110. // 如果字符串长度小于等于32,则返回整个字符串;否则返回前32个字符
  111. return str.length <= 32 ? str : str.slice(0, 32);
  112. }
  113. //字符串转16进制
  114. function stringToHex(str) {
  115. let hex = '';
  116. for (let i = 0; i < str.length; i++) {
  117. // 获取字符的字符编码
  118. const charCode = str.charCodeAt(i);
  119. // 将字符编码转换为16进制,并确保始终为两位数(不足两位前面补0)
  120. const hexValue = charCode.toString(16).padStart(2, '0');
  121. hex += hexValue;
  122. }
  123. return hex;
  124. }
  125. function generateRandomString(minLength = 6, maxLength = 10) {
  126. // 定义字符集
  127. const charset = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
  128. // 生成随机长度
  129. const length = Math.floor(Math.random() * (maxLength - minLength + 1)) + minLength;
  130. let result = '';
  131. for (let i = 0; i < length; i++) {
  132. // 随机选择一个字符
  133. const randomIndex = Math.floor(Math.random() * charset.length);
  134. result += charset[randomIndex];
  135. }
  136. return result;
  137. }
  138. // //获取站点信息
  139. // function request_getSite(data) {
  140. // return request('api/Nozzle/GetNozzleInfo?Nozzleid='+ data, "GET",data);
  141. // }
  142. //支付
  143. function request_wechatPay(data) {
  144. return request('api/Transactions/UnifiedOrder?trxid=' + data, "POST", data);
  145. }
  146. //获取站点信息与用户信息
  147. function request_GetSiteInfo() {
  148. return request('api/Site/GetSiteInfo', "GET");
  149. }
  150. //小程序用户查询未支付订单
  151. function request_GetMiniProgramTransactionsUnpaidQuery(data) {
  152. return request('api/Transactions/GetMiniProgramTransactionsUnpaidQuery', "GET", data);
  153. }
  154. //小程序用户根据抢号查询未支付订单
  155. function request_GetMiniProgramTransactionsUnpaidNozzle(data) {
  156. return request('api/Transactions/GetMiniProgramTransactionsUnpaidNozzle?NozzleId=' + data, "GET", data);
  157. }
  158. //小程序登录
  159. function request_Wechatlogin(data) {
  160. return request('api/Auth/Wechatlogin?code=' + data, "GET", data);
  161. }
  162. //获取历史订单
  163. function request_WXFindOrders(dateTime,pageNum,lineCount) {
  164. return request('api/Transactions/WXFindOrders?dateTime='+ dateTime + '&pageNum='+ pageNum+ '&lineCount='+ lineCount, "GET");
  165. }
  166. //添加用户信息
  167. function request_AddMiniprogramUser(data) {
  168. return request('api/Site/AddMiniprogramUser', "POST", data);
  169. }
  170. //向fcc发起油枪授权
  171. function request_NozzleAuthorization(data) {
  172. return request('api/Nozzle/NozzleAuthorization?trxid=' + data, "GET", data);
  173. }
  174. //向fcc发起取消油枪授权
  175. function request_CancelNozzleAuthorization(data) {
  176. return request('api/Nozzle/CancelNozzleAuthorization?trxid=' + data, "GET", data);
  177. }
  178. //退款
  179. function request_RefundTrx(data) {
  180. return request('api/Transactions/RefundTrx', "POST", data);
  181. }
  182. //根据油枪id获取油枪信息
  183. function request_GetNozzleInfo(data) {
  184. return request('api/Nozzle/GetFuelNozzleInfoById', 'GET', data)
  185. }
  186. //发送消息模板
  187. function request_sendMessage(data) {
  188. return request('api/Transactions/SendMessage','POST',data)
  189. }
  190. export default {
  191. request_GetSiteInfo,
  192. request_wechatPay,
  193. request_Wechatlogin,
  194. request_AddMiniprogramUser,
  195. request_NozzleAuthorization,
  196. request_CancelNozzleAuthorization,
  197. request_GetMiniProgramTransactionsUnpaidQuery,
  198. request_GetMiniProgramTransactionsUnpaidNozzle,
  199. request_AddMiniprogramUser,
  200. request_RefundTrx,
  201. request_GetNozzleInfo,
  202. request_WXFindOrders,
  203. request_sendMessage
  204. }