UserService.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 LARAVEL研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: laravel开发员 <laravel.qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services\Common;
  12. use App\Http\Validator\MemberValidator;
  13. use App\Models\MemberModel;
  14. use App\Models\UserModel;
  15. use App\Services\BaseService;
  16. use App\Services\ConfigService;
  17. use App\Services\EmailService;
  18. use App\Services\SmsService;
  19. use App\Services\UsdtWalletService;
  20. use Earnp\GoogleAuthenticator\GoogleAuthenticator;
  21. /**
  22. * 用户管理-服务类
  23. * @author laravel开发员
  24. * @since 2020/11/11
  25. * Class UserService
  26. * @package App\Services\Common
  27. */
  28. class UserService extends BaseService
  29. {
  30. /**
  31. * 构造函数
  32. * @author laravel开发员
  33. * @since 2020/11/11
  34. * UserService constructor.
  35. */
  36. public function __construct()
  37. {
  38. $this->model = new UserModel();
  39. $this->memberModel = new MemberModel();
  40. }
  41. /**
  42. * 静态入口
  43. * @return static|null
  44. */
  45. public static function make()
  46. {
  47. if (!self::$instance) {
  48. self::$instance = (new static());
  49. }
  50. return self::$instance;
  51. }
  52. /**
  53. * 获取用户列表
  54. * @return array
  55. * @since 2020/11/11
  56. * @author laravel开发员
  57. */
  58. public function getList()
  59. {
  60. $param = request()->all();
  61. // 查询条件
  62. $map = [];
  63. // 用户账号
  64. $username = getter($param, "username");
  65. if ($username) {
  66. $map[] = ["username", 'like', "%{$username}%"];
  67. }
  68. // 用户姓名
  69. $realname = getter($param, "realname");
  70. if ($realname) {
  71. $map[] = ['realname', 'like', "%{$realname}%"];
  72. }
  73. // 用户性别
  74. $gender = getter($param, "gender");
  75. if ($gender) {
  76. $map[] = ['gender', '=', $gender];
  77. }
  78. // 用户类型
  79. $userType = getter($param, "user_type");
  80. if ($userType) {
  81. $map[] = ['user_type', '=', $userType];
  82. }
  83. return parent::getList($map); // TODO: Change the autogenerated stub
  84. }
  85. /**
  86. * @param $params
  87. * @param int $pageSize
  88. * @return array
  89. */
  90. public function getDataList($params, $pageSize = 15)
  91. {
  92. $where = ['a.mark' => 1];
  93. $status = isset($params['status'])? $params['status'] : 0;
  94. $userType = isset($params['user_type'])? $params['user_type'] : 1;
  95. $tradeType = isset($params['trade_type'])? $params['trade_type'] : 0;
  96. $parentId = isset($params['parent_id'])? $params['parent_id'] : 0;
  97. if($userType>0){
  98. $where['a.user_type'] = $userType;
  99. }
  100. if($tradeType>0){
  101. $where['m.trade_type'] = $tradeType;
  102. }
  103. if($parentId>0){
  104. $where['m.parent_id'] = $parentId;
  105. }
  106. if($status>0){
  107. $where['a.status'] = $status;
  108. }
  109. $list = $this->model->from('user as a')
  110. ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
  111. ->where($where)
  112. ->where(function ($query) use($params){
  113. $keyword = isset($params['username'])? $params['username'] : '';
  114. if($keyword){
  115. $query->where('a.username','like',"%{$keyword}%")->orWhere('m.username','like',"%{$keyword}%");
  116. }
  117. $realname = isset($params['realname'])? $params['realname'] : '';
  118. if($realname){
  119. $query->where('m.username','like',"%{$realname}%");
  120. }
  121. })
  122. ->select(['a.*','m.usdt_num','m.credit','m.is_online','m.login_time','m.exception_num','m.realname', 'm.username', 'm.idcard','m.idcard_check','m.idcard_front_img','m.idcard_back_img','m.idcard_hand_img','m.credit_score_img','m.trc_address','m.erc_hexaddress'])
  123. ->orderBy('a.create_time','desc')
  124. ->paginate($pageSize > 0 ? $pageSize : 9999999);
  125. $list = $list? $list->toArray() :[];
  126. if($list){
  127. foreach($list['data'] as &$item){
  128. $item['idcard_front_img'] = isset($item['idcard_front_img']) && $item['idcard_front_img']? get_image_url($item['idcard_front_img']) : '';
  129. $item['idcard_back_img'] = isset($item['idcard_back_img']) && $item['idcard_back_img']? get_image_url($item['idcard_back_img']) : '';
  130. $item['idcard_hand_img'] = isset($item['idcard_hand_img']) && $item['idcard_hand_img']? get_image_url($item['idcard_hand_img']) : '';
  131. $item['credit_score_img'] = isset($item['credit_score_img']) && $item['credit_score_img']? get_image_url($item['credit_score_img']) : '';
  132. if($item['login_time'] < time() - 3600){
  133. $item['is_online'] = 2;
  134. }
  135. $item['trc_num'] = '0.00';
  136. $item['trc_usdt_num'] = '0.00';
  137. $item['erc_num'] = '0.00';
  138. $item['erc_usdt_num'] = '0.00';
  139. if($item['user_type'] == 2){
  140. $trcNum = UsdtWalletService::make()->getTrxBalance($item['trc_address'], true);
  141. // $trcNum = 0;
  142. $item['trc_num'] = floatval($trcNum);
  143. $trcUsdtNum = UsdtWalletService::make()->getTrc20Usdt($item['trc_address'], true);
  144. // $trcUsdtNum = 0;
  145. $item['trc_usdt_num'] = floatval($trcUsdtNum);
  146. $ercNum = 0;
  147. // $ercNum = UsdtWalletService::make()->getErcBalance($item['erc_hexaddress'], true);
  148. $item['erc_num'] = floatval($ercNum);
  149. $ercUsdtNum = 0;
  150. // $ercUsdtNum = UsdtWalletService::make()->getErc20Usdt($item['erc_hexaddress'], true);
  151. $item['erc_usdt_num'] = floatval($ercUsdtNum);
  152. $date = isset($params['date']) ? $params['date'] : [];
  153. $item['trade_total'] = TradeOrderService::make()->getTotalByDate($item['user_id'],$date);
  154. $item['advert_total'] = AdvertOrderService::make()->getTotalByDate($item['user_id'],$date);
  155. }
  156. // 获取用户角色列表
  157. $userRoleService = new UserRoleService();
  158. $roleList = $userRoleService->getUserRoleList($item['id']);
  159. $item['roles'] = $roleList;
  160. }
  161. }
  162. return [
  163. 'pageSize'=> $pageSize,
  164. 'total'=>isset($list['total'])? $list['total'] : 0,
  165. 'list'=> isset($list['data'])? $list['data'] : []
  166. ];
  167. }
  168. /**
  169. * 添加或编辑用户
  170. * @return array
  171. * @since 2020/11/11
  172. * @author laravel开发员
  173. */
  174. public function edit()
  175. {
  176. // 请求参数
  177. $data = request()->all();
  178. // 用户名
  179. $username = trim($data['username']);
  180. // 密码
  181. $password = trim($data['password']);
  182. // 添加时设置密码
  183. if (empty($data['id'])) {
  184. $data['password'] = get_password($password . md5($password.'otc'));
  185. // 用户名重复性验证
  186. $count = $this->model
  187. ->where("username", '=', $username)
  188. ->where("mark", "=", 1)
  189. ->count();
  190. if ($count > 0) {
  191. return returnJson("系统中已存在相同的用户名", false);
  192. }
  193. } else {
  194. if($password){
  195. $data['password'] = get_password($password . md5($password.'otc'));
  196. }
  197. // 用户名重复性验证
  198. $count = $this->model
  199. ->where("username", '=', $username)
  200. ->where("id", "<>", $data['id'])
  201. ->where("mark", "=", 1)
  202. ->count();
  203. if ($count > 0) {
  204. return returnJson("系统中已存在相同的用户名", false);
  205. }
  206. // 币商会员账号验证
  207. if($data['user_type'] == 2){
  208. // 用户名重复性验证
  209. $count = $this->memberModel
  210. ->where("username", '=', $username)
  211. ->where("id", "<>", $data['user_id'])
  212. ->where("mark", "=", 1)
  213. ->count();
  214. if ($count > 0) {
  215. return returnJson("系统中已存在相同的会员账号", false);
  216. }
  217. }
  218. }
  219. // 头像处理
  220. $adminId = isset($data['id'])? $data['id'] : 0;
  221. $avatar = isset($data['avatar']) ? trim($data['avatar']) : '';
  222. if (strpos($avatar, "temp")) {
  223. $data['avatar'] = save_image($avatar, 'user');
  224. } else {
  225. $data['avatar'] = str_replace(IMG_URL, "", $data['avatar']);
  226. }
  227. $error = "";
  228. $data['birthday'] = isset($data['birthday'])? $data['birthday'] : '000-00-00';
  229. $data['bond'] = isset($data['bond'])? $data['bond'] : '0';
  230. $data['create_time'] = isset($data['create_time'])? $data['create_time'] : time();
  231. // 谷歌验证码
  232. if(empty($adminId) || empty($data['google_secret'])){
  233. $google = GoogleAuthenticator::CreateSecret();
  234. $data['google_secret'] = isset($google['secret'])? $google['secret'] : '';
  235. }
  236. $this->model->startTrans();
  237. $result = $this->model->edit($data, $error);
  238. if (!$result) {
  239. $this->model->rollBack();
  240. return returnJson($error, false);
  241. }
  242. // 删除已存在的用户角色关系数据
  243. $userRoleService = new UserRoleService();
  244. $userRoleService->deleteUserRole($result);
  245. // 插入用户角色关系数据
  246. $userRoleService->insertUserRole($result, $data['role_ids']);
  247. // 新建币商会员账号
  248. $userId = isset($data['user_id'])? $data['user_id'] : 0;
  249. $ppassword = '123456';
  250. $data = [
  251. 'username'=> $username,
  252. 'realname'=> isset($data['realname'])? $data['realname'] : '',
  253. 'gender'=> isset($data['gender'])? $data['gender'] : 0,
  254. 'parent_id'=> isset($data['parent_id'])? intval($data['parent_id']) : 0,
  255. 'user_type'=> 2,
  256. 'mark'=> 1,
  257. 'status'=> 1,
  258. ];
  259. // 生成trc2.0钱包地址
  260. if(!$userId){
  261. $data['password'] = get_password($ppassword . md5($ppassword.'otc'));
  262. $trcAddress = UsdtWalletService::make()->getTrxAddress();
  263. if($trcAddress){
  264. $data['trc_wif'] = isset($trcAddress['wif'])? $trcAddress['wif'] : '';
  265. $data['trc_hexaddress'] = isset($trcAddress['hexAddress'])? $trcAddress['hexAddress'] : '';
  266. $data['trc_address'] = isset($trcAddress['address'])? $trcAddress['address'] : '';
  267. }else{
  268. $this->model->rollBack();
  269. return returnJson('生成TRC钱包地址失败', false);
  270. }
  271. // 生erc2.0钱包地址
  272. $ercAddress = UsdtWalletService::make()->getErcAddress();
  273. if($ercAddress){
  274. $data['erc_wif'] = isset($ercAddress['wif'])? $ercAddress['wif'] : '';
  275. $data['erc_hexaddress'] = isset($ercAddress['hexAddress'])? $ercAddress['hexAddress'] : '';
  276. $data['erc_address'] = isset($ercAddress['address'])? $ercAddress['address'] : '';
  277. }else{
  278. $this->model->rollBack();
  279. return returnJson('生成ERC钱包地址失败', false);
  280. }
  281. }
  282. $info = $this->memberModel->getInfo($userId);
  283. if($info){
  284. if(!$this->memberModel->where(['id'=> $userId])->update($data)){
  285. $this->model->rollBack();
  286. return returnJson('修改交易员信息失败', false);
  287. }
  288. $this->model->commit();
  289. $this->model->where(['id'=> $adminId])->update(['user_id'=> $userId]);
  290. }else{
  291. if(!$userId = $this->memberModel->edit($data)){
  292. $this->model->rollBack();
  293. return returnJson($userId? '修改交易员信息失败':'创建交易员账号失败', false);
  294. }
  295. $this->model->commit();
  296. // 更新绑定会员账号
  297. $this->model->where(['id'=> $result])->update(['user_id'=> $userId]);
  298. // 用户交易配置
  299. MemberSettingService::make()->getInfo($userId);
  300. }
  301. return returnJson();
  302. }
  303. /**
  304. * 获取用户信息
  305. * @param $id 用户ID
  306. * @return array
  307. * @author laravel开发员
  308. * @since 2020/11/10
  309. */
  310. public function getUserInfo($id)
  311. {
  312. $userInfo = $this->model->getInfo($id);
  313. $userInfo['roles'] = [];
  314. $userInfo['authorities'] = [];
  315. // 权限节点列表
  316. $menuService = new MenuService();
  317. $permissionList = $menuService->getPermissionsList($id);
  318. $userInfo['permissionList'] = $permissionList;
  319. return returnJson("操作成功", true, $userInfo);
  320. }
  321. /**
  322. * 获取当前会员的后台用户信息
  323. * @param $userId
  324. * @return mixed
  325. */
  326. public function getUserInfoByUserId($userId)
  327. {
  328. return $this->model->where(['user_id'=> $userId,'mark'=> 1])->first();
  329. }
  330. /**
  331. * 更新个人资料
  332. * @author laravel开发员
  333. * @since 2020/11/11
  334. */
  335. public function updateUserInfo($userId)
  336. {
  337. // 参数
  338. $param = request()->all();
  339. // 个人信息
  340. $data = [
  341. 'id' => $userId,
  342. 'realname' => $param['realname'],
  343. 'nickname' => $param['nickname'],
  344. ];
  345. // 头像处理
  346. $avatar = isset($param['avatar']) ? $param['avatar'] : "";
  347. if (strpos($avatar, "data:image") !== false) {
  348. $expData = explode(';', $avatar);
  349. $fileInfo = explode('/', $expData[0]);
  350. $fileExt = $fileInfo[1] == 'jpeg' ? 'jpg' : $fileInfo[1];
  351. // 文件存储路径
  352. $filePath = create_image_path("user", $fileExt);
  353. // 获取图片流
  354. $item = explode(',', $avatar);
  355. file_put_contents(ATTACHMENT_PATH . $filePath, base64_decode($item[1]));
  356. $data['avatar'] = $filePath;
  357. } else {
  358. $data['avatar'] = str_replace(IMG_URL, "", $param['avatar']);
  359. }
  360. $result = $this->model->edit($data);
  361. if (!$result) {
  362. return returnJson("更新资料信息失败", false);
  363. }
  364. return returnJson("更新资料信息成功");
  365. }
  366. /**
  367. * 认证资料
  368. */
  369. public function authSubmit($userId)
  370. {
  371. // 参数
  372. $param = request()->all();
  373. // 个人信息
  374. $data = [
  375. 'realname' => $param['realname'],
  376. 'idcard' => $param['idcard'],
  377. 'idcard_check' => 2,
  378. 'update_time' => time(),
  379. ];
  380. if (isset($param['idcard_front_img']) && strpos($param['idcard_front_img'], "temp")) {
  381. $data['idcard_front_img'] = save_image($param['idcard_front_img'], 'member');
  382. } else {
  383. $image = $param['idcard_front_img']? explode('/uploads', $param['idcard_front_img']) : [];
  384. $data['idcard_front_img'] = isset($image[1])? $image[1] : '';
  385. }
  386. if (isset($param['idcard_back_img']) && strpos($param['idcard_back_img'], "temp")) {
  387. $data['idcard_back_img'] = save_image($param['idcard_back_img'], 'member');
  388. } else {
  389. $image = $param['idcard_back_img']? explode('/uploads', $param['idcard_back_img']) : [];
  390. $data['idcard_back_img'] = isset($image[1])? $image[1] : '';
  391. }
  392. if (isset($param['idcard_hand_img']) && strpos($param['idcard_hand_img'], "temp")) {
  393. $data['idcard_hand_img'] = save_image($param['idcard_hand_img'], 'member');
  394. } else if(isset($param['idcard_hand_img'])){
  395. $image = $param['idcard_hand_img']? explode('/uploads', $param['idcard_hand_img']) : [];
  396. $data['idcard_hand_img'] = isset($image[1])? $image[1] : '';
  397. }
  398. if (isset($param['credit_score_img']) && strpos($param['credit_score_img'], "temp")) {
  399. $data['credit_score_img'] = save_image($param['credit_score_img'], 'member');
  400. } else if(isset($param['credit_score_img'])){
  401. $image = $param['credit_score_img']? explode('/uploads', $param['credit_score_img']) : [];
  402. $data['credit_score_img'] = isset($image[1])? $image[1] : '';
  403. }
  404. $info = $this->memberModel->getInfo($userId);
  405. if($info['idcard_check'] == 1){
  406. return returnJson("抱歉您已完成认证,不需再提交资料", false);
  407. }
  408. $this->memberModel->where(['id'=> $userId])->update($data);
  409. return returnJson("提交认证资料成功,请耐心等候审核");
  410. }
  411. /**
  412. * 更新密码
  413. * @param $userId 用户ID
  414. * @return array
  415. * @author laravel开发员
  416. * @since 2020/11/14
  417. */
  418. public function updatePwd($userId)
  419. {
  420. // 获取参数
  421. $param = request()->all();
  422. // 原始密码
  423. $oldPassword = trim(getter($param, "oldPassword"));
  424. if (!$oldPassword) {
  425. return returnJson("旧密码不能为空", false);
  426. }
  427. // 新密码
  428. $newPassword = trim(getter($param, "newPassword"));
  429. if (!$newPassword) {
  430. return returnJson("新密码不能为空", false);
  431. }
  432. $userInfo = $this->model->getInfo($userId);
  433. if (!$userInfo) {
  434. return returnJson("用户信息不存在", false);
  435. }
  436. if ($userInfo['password'] != get_password($oldPassword . md5($oldPassword.'otc'))) {
  437. return returnJson("旧密码输入不正确", false);
  438. }
  439. // 设置新密码
  440. $userInfo['password'] = get_password($newPassword . md5($newPassword.'otc'));
  441. $result = $this->model->edit($userInfo);
  442. if (!$result) {
  443. return returnJson("修改失败", false);
  444. }
  445. return returnJson("修改成功");
  446. }
  447. /**
  448. * 更新交易密码
  449. * @param $userId 用户ID
  450. * @param $adminId 管理ID
  451. * @return array
  452. * @author laravel开发员
  453. * @since 2020/11/14
  454. */
  455. public function updateTradePwd($userId, $adminId)
  456. {
  457. // 获取参数
  458. $param = request()->all();
  459. // 原始密码
  460. $loginPassword = trim(getter($param, "loginPassword"));
  461. if (!$loginPassword) {
  462. return returnJson("登录密码不能为空", false);
  463. }
  464. // 新密码
  465. $newPassword = trim(getter($param, "newPassword"));
  466. if (!$newPassword) {
  467. return returnJson("新密码不能为空", false);
  468. }
  469. $userInfo = $this->model->getInfo($adminId);
  470. $memberInfo = MemberService::make()->getInfo($userId);
  471. if (!$userInfo || empty($memberInfo)) {
  472. return returnJson("用户信息不存在", false);
  473. }
  474. if ($userInfo['password'] != get_password($loginPassword . md5($loginPassword.'otc'))) {
  475. return returnJson("登录密码输入不正确", false);
  476. }
  477. // 设置新密码
  478. $password = get_password($newPassword . md5($newPassword.'otc'));
  479. $result = $this->memberModel->where(['id'=> $userId])->update(['trade_password'=> $password]);
  480. if (!$result) {
  481. return returnJson("交易密码更新设置失败", false);
  482. }
  483. return returnJson("交易密码更新设置成功");
  484. }
  485. /**
  486. * 更新谷歌验证码
  487. * @param $userId 用户ID
  488. * @return array
  489. */
  490. public function updateGoogle($userId)
  491. {
  492. // 获取参数
  493. $param = request()->all();
  494. // 验证码
  495. $code = trim(getter($param, "code"));
  496. $username = trim(getter($param, "username"));
  497. if(empty($username)){
  498. return returnJson("账号参数错误", false);
  499. }
  500. if (!$code) {
  501. return returnJson("验证码不能为空", false);
  502. }
  503. // 验证码
  504. $validator = new MemberValidator();
  505. if(!is_array($validator->check(['mobile'=> $username],'mobile'))){
  506. if(!EmailService::make()->check($username, $code, 'google')){
  507. return returnJson(EmailService::make()->getError(), false);
  508. }
  509. }else{
  510. if(!SmsService::make()->check($username, $code, 'google')){
  511. return returnJson(SmsService::make()->getError(), false);
  512. }
  513. }
  514. //
  515. $googleCode = trim(getter($param, "google_code"));
  516. if (!$googleCode) {
  517. return returnJson("谷歌验证码不能为空", false);
  518. }
  519. $userInfo = $this->model->getInfo($userId);
  520. if (!$userInfo) {
  521. return returnJson("用户信息不存在", false);
  522. }
  523. // 谷歌验证码
  524. $googleSecret = isset($userInfo['google_secret'])? $userInfo['google_secret'] : '';
  525. if(empty($googleSecret)){
  526. return returnJson("您尚未绑定谷歌验证码", false);
  527. }
  528. if (!GoogleAuthenticator::CheckCode($googleSecret, $googleCode)) {
  529. return returnJson("谷歌验证码错误", false);
  530. }
  531. // 设置新谷歌验证码
  532. $google = GoogleAuthenticator::CreateSecret();
  533. $googleSecret = isset($google['secret'])? $google['secret'] : '';
  534. $googleLimitTime = ConfigService::make()->getConfigByCode('google_limit_time');
  535. $googleLimitTime = $googleLimitTime>0? $googleLimitTime : 1;
  536. $result = $this->model->where(['id'=> $userId])->update(['google_secret'=> $googleSecret,'google_verify_time'=> time() + $googleLimitTime*3600]);
  537. if (!$result) {
  538. return returnJson("谷歌验证码更新设置失败", false);
  539. }
  540. return returnJson("谷歌验证码更新设置成功");
  541. }
  542. /**
  543. * 重置密码
  544. * @return array
  545. * @since 2020/11/14
  546. * @author laravel开发员
  547. */
  548. public function resetPwd()
  549. {
  550. // 获取参数
  551. $param = request()->all();
  552. // 用户ID
  553. $userId = getter($param, "id");
  554. if (!$userId) {
  555. return returnJson("用户ID不能为空", false);
  556. }
  557. $userInfo = $this->model->getInfo($userId);
  558. if (!$userInfo) {
  559. return returnJson("用户信息不存在", false);
  560. }
  561. // 设置新密码
  562. $userInfo['password'] = get_password("123456" . md5('123456'.'otc'));
  563. $result = $this->model->edit($userInfo);
  564. if (!$result) {
  565. return returnJson("重置密码失败", false);
  566. }
  567. return returnJson("重置密码成功");
  568. }
  569. }