functions.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. <?php
  2. /**
  3. * Here is your custom functions.
  4. */
  5. use Firebase\JWT\JWT;
  6. use Firebase\JWT\Key;
  7. /* @登录失效码*/
  8. define('USER_INVALID', 4008);
  9. /* @无权限码*/
  10. define('USER_AUTH', 4009);
  11. /* @错误码*/
  12. define('ERROR', 400);
  13. /* @成功码*/
  14. define('SUCCESS', 0);
  15. function error($msg = '请求成功', $data = [], $code = ERROR)
  16. {
  17. $result = [
  18. 'code' => $code,
  19. 'message' => $msg,
  20. 'time' => time(),
  21. 'data' => $data,
  22. ];
  23. $result = encrypt($result);
  24. return json($result);
  25. }
  26. function adminerror($msg = '请求成功', $data = [], $code = ERROR)
  27. {
  28. $result = [
  29. 'code' => $code,
  30. 'message' => $msg,
  31. 'time' => time(),
  32. 'data' => $data,
  33. ];
  34. return json($result);
  35. }
  36. function success($data = [], $msg = '请求成功', $code = 200, $count = 0)
  37. {
  38. $result = [
  39. 'code' => $code,
  40. 'message' => $msg,
  41. 'data' => $data,
  42. 'count' => $count
  43. ];
  44. $result = encrypt($result);
  45. return json($result);
  46. }
  47. function adminsuccess($data = [], $msg = '请求成功', $code = 200, $count = 0)
  48. {
  49. $result = [
  50. 'code' => $code,
  51. 'message' => $msg,
  52. 'data' => $data,
  53. 'count' => $count
  54. ];
  55. return json($result);
  56. }
  57. /** 加密
  58. * @param $data
  59. * @return void
  60. */
  61. function jwtEncode($data)
  62. {
  63. return JWT::encode($data, getenv('JWT_PRIVATEKEY'), 'HS256');
  64. }
  65. /** 解密
  66. * @param $data
  67. * @return void
  68. */
  69. function jwtDecode($data)
  70. {
  71. try {
  72. $data = JWT::decode($data, new Key(getenv('JWT_PRIVATEKEY'), 'HS256'));
  73. } catch (\Exception $exception) {
  74. throw new \Exception('验证失败');
  75. }
  76. return $data;
  77. }
  78. /** 钱包名称
  79. * @param $value
  80. * @return array[]|mixed
  81. */
  82. function moldType($value = '')
  83. {
  84. $arr = [
  85. [
  86. 'value' => 1,
  87. 'name' => '我的资产',
  88. ], [
  89. 'value' => 2,
  90. 'name' => '推荐奖',
  91. ], [
  92. 'value' => 3,
  93. 'name' => '持股数量',
  94. ],
  95. [
  96. 'value' => 4,
  97. 'name' => '持股总价值',
  98. ]
  99. , [
  100. 'value' => 5,
  101. 'name' => '股权分红',
  102. ]
  103. ];
  104. if ($value) {
  105. $data = collect($arr)->where('value', $value)->first();
  106. return $data['name'];
  107. } else {
  108. return $arr;
  109. }
  110. }
  111. /** 产品类型
  112. * @param $type
  113. * @return string
  114. */
  115. function cardNumberType($type = '')
  116. {
  117. if ($type == 1) {
  118. return '股权产品';
  119. } else {
  120. return '无';
  121. }
  122. }
  123. /**钱包字段
  124. * @param $value
  125. * @return array[]|mixed
  126. */
  127. //我的资产
  128. define('moldType1', 1);
  129. define('moldTypefild1', 'money');
  130. //推荐奖
  131. define('moldType2', 2);
  132. define('moldTypefild2', 'money_one');
  133. //持股数量
  134. define('moldType3', 3);
  135. define('moldTypefild3', 'money_two');
  136. //持股总价值
  137. define('moldType4', 4);
  138. define('moldTypefild4', 'money_four');
  139. //股权分红
  140. define('moldType5', 5);
  141. define('moldTypefild5', 'money_five');
  142. function moldTypefild($value = '')
  143. {
  144. $arr = [
  145. [
  146. 'value' => 1,
  147. 'name' => 'money',
  148. ], [
  149. 'value' => 2,
  150. 'name' => 'money_one',
  151. ], [
  152. 'value' => 3,
  153. 'name' => 'money_two',
  154. ],
  155. [
  156. 'value' => 4,
  157. 'name' => 'money_four',
  158. ],
  159. [
  160. 'value' => 5,
  161. 'name' => 'money_five',
  162. ]
  163. ];
  164. if ($value) {
  165. $data = collect($arr)->where('value', $value)->first();
  166. return $data['name'];
  167. } else {
  168. return $arr;
  169. }
  170. }
  171. /** 流水类型 */
  172. /** 注册奖励 */
  173. define('streamType1', 1);
  174. /** 签到 */
  175. define('streamType2', 2);
  176. /** 邀请*/
  177. define('streamType3', 3);
  178. /** 提现 */
  179. define('streamType4', 4);
  180. /** 购买 */
  181. define('streamType5', 5);
  182. /** 提现驳回 */
  183. define('streamType6', 6);
  184. /** 平台充值 */
  185. define('streamType7', 7);
  186. /** 平台扣款 */
  187. define('streamType8', 8);
  188. /** 产品分红 */
  189. define('streamType9', 9);
  190. /** 产品分佣 */
  191. define('streamType10', 10);
  192. /** 实名奖励 */
  193. define('streamType11', 11);
  194. /** 抽奖 */
  195. define('streamType12', 12);
  196. /** 数据恢复 */
  197. define('streamType13', 13);
  198. /** 转账 */
  199. define('streamType14', 14);
  200. /** 产品赠送 */
  201. define('streamType15', 15);
  202. /** 兑换 */
  203. define('streamType16', 16);
  204. /** 出售股权 */
  205. define('streamType17', 17);
  206. function streamType($value = '')
  207. {
  208. $arr = [
  209. [
  210. 'value' => 1,
  211. 'name' => '注册奖励',
  212. ],
  213. [
  214. 'value' => 2,
  215. 'name' => '签到',
  216. ],
  217. [
  218. 'value' => 3,
  219. 'name' => '邀请',
  220. ],
  221. [
  222. 'value' => 4,
  223. 'name' => '提现',
  224. ],
  225. [
  226. 'value' => 5,
  227. 'name' => '购买',
  228. ],
  229. [
  230. 'value' => 6,
  231. 'name' => '提现驳回',
  232. ],
  233. [
  234. 'value' => 7,
  235. 'name' => '平台充值',
  236. ],
  237. [
  238. 'value' => 8,
  239. 'name' => '平台扣款',
  240. ],
  241. [
  242. 'value' => 9,
  243. 'name' => '产品结息',
  244. ],
  245. [
  246. 'value' => 10,
  247. 'name' => '产品分佣',
  248. ],
  249. [
  250. 'value' => 11,
  251. 'name' => '实名奖励',
  252. ],
  253. [
  254. 'value' => 12,
  255. 'name' => '抽奖获得',
  256. ],
  257. [
  258. 'value' => 13,
  259. 'name' => '数据恢复',
  260. ],
  261. [
  262. 'value' => 14,
  263. 'name' => '转账',
  264. ],
  265. [
  266. 'value' => 15,
  267. 'name' => '产品赠送',
  268. ],
  269. [
  270. 'value' => 16,
  271. 'name' => '兑换',
  272. ],
  273. [
  274. 'value' => 17,
  275. 'name' => '出售股权',
  276. ]
  277. ];
  278. if ($value) {
  279. $data = collect($arr)->where('value', $value)->first();
  280. return $data['name'];
  281. } else {
  282. return $arr;
  283. }
  284. }
  285. /** 获取未来时间 */
  286. function futureDay($day)
  287. {
  288. return date('Y-m-d', strtotime("+$day days")) . ' 23:59:59';
  289. }
  290. /** 后台登录名称 */
  291. function adminName()
  292. {
  293. return md5(getenv('PROJECT') . date('Ymd'));
  294. }
  295. function imgtxt($html)
  296. {
  297. if (empty($html)) {
  298. return $html;
  299. }
  300. // 要替换的目标字符串
  301. $target = getenv('IMG');
  302. // 正则表达式匹配所有<img>标签
  303. $pattern = '/<img[^>]+/i';
  304. // 正则表达式匹配src属性
  305. $src_pattern = '/src="([^"]+)/i';
  306. // 执行替换
  307. $replaced_html = preg_replace_callback($pattern, function ($matches) use ($src_pattern, $target) {
  308. // 匹配src属性
  309. preg_match($src_pattern, $matches[0], $src_matches);
  310. // 如果找到了src属性,则替换它
  311. if (isset($src_matches[1])) {
  312. // 构造新的<img>标签
  313. if (strpos($src_matches[1], 'http') !== false) {
  314. } else {
  315. return str_replace($src_matches[1], imageToBase64($src_matches[1]), $matches[0]);
  316. }
  317. }
  318. // 如果没有找到src属性,直接返回原始<img>标签
  319. return $matches[0];
  320. }, $html);
  321. // 输出替换后的HTML内容
  322. return $replaced_html;
  323. }
  324. function uuid()
  325. {
  326. $uuid = \support\Db::table('wa_users')->orderByDesc('uuid')->value('uuid');
  327. return bcadd($uuid, bcadd(mt_rand(100, 999), date('d')));
  328. }
  329. /**
  330. * 生成银行卡号
  331. * @param $length
  332. * @return string
  333. */
  334. function generateBankAccountNumber($length = 19)
  335. {
  336. $prefix = '6221'; // 定义账号前缀,如银行标识
  337. $suffixLength = $length - strlen($prefix); // 计算后缀的长度
  338. $suffix = substr(mt_rand(100000000000000, 999999999999999), 0, $suffixLength); // 随机生成后缀
  339. return $prefix . $suffix;
  340. }
  341. /**
  342. * 生成证 书编号
  343. * @return string
  344. * @throws \Random\RandomException
  345. */
  346. function generateCertificateNumber($length = 12)
  347. {
  348. $prefix = 'JZYH'; // 定义账号前缀,如银行标识
  349. $suffixLength = $length - strlen($prefix); // 计算后缀的长度
  350. $suffix = substr(mt_rand(100000000000000, 999999999999999), 0, $suffixLength); // 随机生成后缀
  351. return $prefix . $suffix;
  352. }
  353. /**
  354. * 生成随机字母
  355. * @param $length
  356. * @return string
  357. */
  358. function RandomAlphaNum($length = 4)
  359. {
  360. $randomString = '';
  361. for ($i = 0; $i < $length; $i ++) {
  362. $randomString .= chr(rand(65, 90)); // 生成大写字母 'A' 到 'Z'
  363. // 如果需要包含小写字母,取消下面这行的注释
  364. // $randomString .= chr(rand(97, 122)); // 生成小写字母 'a' 到 'z'
  365. }
  366. return $randomString;
  367. }
  368. function encrypt($data)
  369. {
  370. $info = openssl_encrypt (json_encode ($data, JSON_UNESCAPED_UNICODE), 'AES-128-ECB', getenv ("JWT_AESKEY"), OPENSSL_RAW_DATA) ;
  371. return base64_encode ($info);
  372. }
  373. function imageToBase64($imagePath)
  374. {
  375. if (file_exists('./public'.$imagePath) && !empty($imagePath)) {
  376. // $image = file_get_contents('./public'.$imagePath);
  377. // $base64 = base64_encode($image);
  378. // return 'data:image/jpeg;base64,' . $base64; // 这里假设图片为JPEG格式,根据实际需要修改
  379. return getenv('IMG').$imagePath;
  380. } else {
  381. return '';
  382. }
  383. }