functions.php 11 KB

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