UserCenter.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\model\GoodsOrder;
  4. use app\common\model\UserCollect;
  5. use app\common\model\UserCouponList;
  6. use app\common\model\UserLevel;
  7. use app\common\model\UserTrack;
  8. use app\common\validate\UserVali;
  9. use think\Db;
  10. use app\common\model\UserBank;
  11. use app\common\model\User;
  12. /**
  13. * @title 会员个人中心
  14. * @controller UserCenter
  15. * @group base
  16. */
  17. class UserCenter extends Base
  18. {
  19. public function initialize()
  20. {
  21. parent::initialize();
  22. parent::checkLogin();
  23. }
  24. /**
  25. * @title 获取个人信息
  26. * @desc 个人信息
  27. * @author qc
  28. * @url /api/User_center/getUserInfo
  29. * @method GET
  30. * @tag 个人信息
  31. * @header name:Authorization require:1 desc:Token
  32. * @return name:phone type:int default:-- desc:手机号
  33. * @return name:name type:string default:-- desc:昵称
  34. * @return name:password type:string default:-- desc:密码
  35. * @return name:headimg type:string default:-- desc:头像地址
  36. * @return name:sex type:int default:1 desc:性别(1男2女)
  37. * @return name:true_name type:string default:-- desc:真实姓名
  38. * @return name:invite_code type:string default:-- desc:邀请码
  39. * @return name:birthday type:string default:-- desc:出生日期
  40. * @return name:province_name type:string default:-- desc:省
  41. * @return name:city_name type:string default:-- desc:市
  42. * @return name:counties_name type:string default:-- desc:县区
  43. * @return name:bind_wechat type:string default:-- desc:绑定微信号
  44. * @return name:true_name type:string default:-- desc:真实姓名
  45. * @return name:id_card type:string default:-- desc:身份证号
  46. * @return name:is_auth type:int default:-- desc:是否认证(0否1是)
  47. * @return name:auth_at type:string default:-- desc:认证时间
  48. * @return name:card_front type:string default:-- desc:身份证正面
  49. * @return name:card_back type:string default:-- desc:身份证背面
  50. * @return name:level_name type:string default:-- desc:等级名称
  51. * @return name:partner_lev type:int default:-- desc:分销商等级id(0不是分销商)
  52. * @return name:is_agency type:int default:-- desc:是否是区域代理(0不是)
  53. * @return name:fans type:int default:-- desc:粉丝数量
  54. * @return name:collect type:int default:-- desc:收藏量
  55. * @return name:coupon_num type:int default:-- desc:券数量
  56. * @return name:track_num type:int default:-- desc:足迹条数
  57. * @return name:wallet type:array default:-- desc:钱包
  58. * @return name:wallet.integral type:int default:-- desc:积分
  59. * @return name:wallet.growth type:int default:-- desc:经验值(成长值)
  60. * @return name:wallet.money type:float default:-- desc:佣金
  61. * @return name:order_stat type:array default:-- desc:订单统计
  62. * @return name:order_stat.no_pay type:int default:-- desc:未支付订单
  63. * @return name:order_stat.no_deliver type:int default:-- desc:未发货
  64. * @return name:order_stat.no_receive type:int default:-- desc:未收货
  65. * @return name:order_stat.no_comment type:int default:-- desc:未评论
  66. *
  67. */
  68. public function getUserInfo()
  69. {
  70. $field = 'id,phone,password,name,level_id,pay_password,headimg,openid,true_name,sex,invite_code,birthday,province_name,city_name,counties_name,bind_wechat,id_card,card_front,card_back,auth_at,is_agency,partner_lev';
  71. $user_info = User::with('wallet')->field($field)->where('id',$this->user_id)->find()->toArray();
  72. $user_info['level_name'] = UserLevel::where('id',$user_info['level_id'])->value('name');
  73. $user_info['fans'] = User::where('pid',$user_info['id'])->count();
  74. $user_info['collect'] = UserCollect::where('user_id',$user_info['id'])->count();
  75. $user_info['coupon_num'] = UserCouponList::where(['user_id'=>$user_info['id'],'status'=>0])->count();
  76. $user_info['track_num'] = UserTrack::where(['user_id'=>$user_info['id']])->count();
  77. $order_stat = [];
  78. $order_stat['no_pay'] = GoodsOrder::where(['user_id'=>$this->user_id,'status'=>0])->count();
  79. $order_stat['no_deliver'] = GoodsOrder::where(['user_id'=>$this->user_id,'status'=>1])->count();
  80. $order_stat['no_receive'] = GoodsOrder::where(['user_id'=>$this->user_id,'status'=>2])->count();
  81. $order_stat['no_comment '] = GoodsOrder::where(['user_id'=>$this->user_id,'status'=>3])->count();
  82. if(empty($user_info)) $this->error('用户信息不正确');
  83. $this->success('获取成功',['detail'=>$user_info,'order_stat'=>$order_stat]);
  84. }
  85. /**
  86. * @title 编辑个人信息
  87. * @desc 编辑个人信息
  88. * @author qc
  89. * @url /api/User_center/updateUserInfo
  90. * @method POST
  91. * @tag 编辑信息
  92. * @header name:Authorization require:1 desc:Token
  93. * @param name:name type:string default:-- desc:昵称
  94. * @param name:headimg type:string default:-- desc:头像地址
  95. * @param name:sex type:int default:1 desc:性别(1男2女)
  96. * @param name:birthday type:string default:1 desc:出生日期
  97. * @param name:address type:string default:1 desc:地址(山东省-临沂市-兰山区)
  98. */
  99. public function updateUserInfo()
  100. {
  101. $headimg = input('post.headimg');
  102. $name = trim(input('post.name',''));
  103. $sex = trim(input('post.sex',1));
  104. $birthday = input('post.birthday');
  105. $address = input('post.address');
  106. $update_data= [];
  107. $update_data['name'] = $name;
  108. $update_data['headimg'] = $headimg;
  109. $update_data['sex'] = $sex;
  110. $update_data['birthday'] = $birthday;
  111. if($address){
  112. $add_arr = explode('-',$address);
  113. $update_data['province_name'] = $add_arr[0];
  114. $update_data['city_name'] = $add_arr[1];
  115. $update_data['counties_name'] = $add_arr[2];
  116. }
  117. if($name){
  118. $check_member = Db::name('store_member')->where('name',$name)->where('id','<>',$this->user_id)->count();
  119. if($check_member) $this->error('该用户名已被占用');
  120. }
  121. Db::name('store_member')->where('id',$this->user_id)->update($update_data);
  122. $field = 'phone,name,headimg';
  123. $user_info = Db::name('store_member')->field($field)->where('id',$this->user_id)->find();
  124. $this->success('编辑成功',$user_info);
  125. }
  126. /**
  127. * @title 绑定手机号
  128. * @desc 绑定手机号
  129. * @author qc
  130. * @url /api/User_center/modifyPhone
  131. * @method POST
  132. * @header name:Authorization require:1 desc:Token
  133. * @param name:phone type:int require:1 default:-- desc:手机号
  134. * @param name:code type:int require:1 default:-- desc:手机号验证码
  135. * @return name:phone type:int default:-- desc:手机号
  136. * @return name:name type:string default:-- desc:昵称
  137. * @return name:headimg type:string default:-- desc:头像地址
  138. * @return name:true_name type:string default:-- desc:真实姓名
  139. * @return name:id_card type:string default:-- desc:身份证号
  140. * @return name:is_auth type:int default:-- desc:是否认证(0否1是)
  141. */
  142. public function modifyPhone()
  143. {
  144. $uid = $this->user_id;
  145. $phone = input('post.phone');
  146. $code = input('post.code');
  147. if(empty($phone) || empty($code) ) $this->error('参数错误');
  148. $field = 'id,phone,name,headimg,status,openid,true_name,id_card,is_auth';
  149. $user_info = Db::name('store_member')->field($field)->where('id',$this->user_id)->find();
  150. if($user_info['phone'] == $phone)$this->error('更换手机号与绑定手机号一致!');
  151. $check_code = $this->checkPhoneCode($phone,$code);
  152. if(!$check_code) $this->error('验证码错误');
  153. //判断手机号是否已注册
  154. $member_id = Db::name('store_member')
  155. ->where('phone','=',$phone)->where('is_deleted','=',0)->where('id','<>',$this->user_id)->value('id');
  156. if($member_id) $this->error('手机号已注册过');
  157. Db::name('store_member')->where('id',$uid)->update(['phone'=>$phone]);
  158. $user_info['phone'] = $phone;
  159. $this->updatePhoneCode($check_code);
  160. $this->success('绑定成功',$user_info);
  161. }
  162. /**
  163. * @title 验证已绑定手机号是否正确
  164. * @desc 验证已绑定手机号是否正确
  165. * @author qc
  166. * @url /api/User_center/checkBindPhone
  167. * @method POST
  168. * @header name:Authorization require:1 desc:Token
  169. * @param name:phone type:int require:1 default:-- desc:手机号
  170. * @param name:code type:int require:1 default:-- desc:手机号验证码
  171. */
  172. public function checkBindPhone()
  173. {
  174. $phone = input('post.phone');
  175. $code = input('post.code');
  176. if(empty($phone) || empty($code) ) $this->error('参数错误');
  177. $field = 'id,phone,name,headimg,status,openid,true_name,id_card,is_auth';
  178. $user_info = Db::name('store_member')->field($field)->where('id',$this->user_id)->find();
  179. if($user_info['phone'] != $phone) $this->error('该手机号与当前账户不一致!');
  180. $check_code = $this->checkPhoneCode($phone,$code);
  181. if(!$check_code) $this->error('验证码错误');
  182. $this->updatePhoneCode($check_code);
  183. $this->success('验证通过');
  184. }
  185. /**
  186. * @title 更换或设置登录密码
  187. * @desc 更换或设置登录密码
  188. * @author qc
  189. * @url /api/User_center/modifyPassword
  190. * @method POST
  191. * @header name:Authorization require:1 desc:Token
  192. * @param name:phone type:int require:1 default:-- desc:手机号
  193. * @param name:code type:int require:1 default:-- desc:手机号验证码
  194. * @param name:password type:string default:-- desc:密码
  195. */
  196. public function modifyPassword()
  197. {
  198. $uid = $this->user_id;
  199. $phone = input('post.phone');
  200. $code = input('post.code');
  201. $password = input('post.password');
  202. if(empty($phone) || empty($code) || empty($password) ) $this->error('参数错误');
  203. $field = 'id,phone';
  204. $user_info = Db::name('store_member')->field($field)->where('id',$this->user_id)->find();
  205. if(!$user_info['phone']) $this->error('请先绑定手机号');
  206. if($user_info['phone'] != $phone) $this->error('与绑定手机号不一致');
  207. $check_code = $this->checkPhoneCode($phone,$code);
  208. if(!$check_code) $this->error('验证码错误');
  209. $validate = new UserVali();
  210. if (!$validate->scene('reset_password')->check(['phone'=>$phone,'password'=>$password])) {
  211. $this->error($validate->getError());
  212. }
  213. $encryption_password = encrypt_password($password);
  214. Db::name('store_member')->where('id',$uid)->update(['password'=>$password,'encryption_password'=>$encryption_password]);
  215. $this->updatePhoneCode($check_code);
  216. $this->success('更换成功');
  217. }
  218. /**
  219. * @title 更换或设置提现密码
  220. * @desc 更换或设置提现密码
  221. * @author qc
  222. * @url /api/User_center/setPayPassword
  223. * @method POST
  224. * @header name:Authorization require:1 desc:Token
  225. * @param name:phone type:int require:1 default:-- desc:手机号
  226. * @param name:code type:int require:1 default:-- desc:手机号验证码
  227. * @param name:pay_password type:string default:-- desc:密码
  228. */
  229. public function setPayPassword()
  230. {
  231. $uid = $this->user_id;
  232. $phone = input('post.phone');
  233. $code = input('post.code');
  234. $pay_password = input('post.pay_password');
  235. if(empty($phone) || empty($code) || empty($password) ) $this->error('参数错误');
  236. $field = 'id,phone';
  237. $user_info = Db::name('store_member')->field($field)->where('id',$this->user_id)->find();
  238. if(!$user_info['phone']) $this->error('请先绑定手机号');
  239. if($user_info['phone'] != $phone) $this->error('与绑定手机号不一致');
  240. $check_code = $this->checkPhoneCode($phone,$code);
  241. if(!$check_code) $this->error('验证码错误');;
  242. Db::name('store_member')->where('id',$uid)->update(['pay_password'=>encrypt_password($pay_password)]);
  243. $this->updatePhoneCode($check_code);
  244. $this->success('更换成功');
  245. }
  246. /**
  247. * @title 实名认证
  248. * @desc 实名认证
  249. * @author qc
  250. * @method POST
  251. * @tag 实名认证
  252. * @url /api/User_center/userCertification
  253. * @header name:Authorization require:1 desc:Token
  254. * @param name:true_name type:string require:1 default:-- desc:真实姓名
  255. * @param name:id_card type:string require:1 default:-- desc:身份证号
  256. * @param name:card_front type:string require:1 default:-- desc:身份证正面
  257. * @param name:card_back type:string require:1 default:-- desc:身份证反面
  258. */
  259. public function userCertification()
  260. {
  261. $true_name = input('post.true_name');
  262. $id_card = input('post.id_card');
  263. $card_front = input('post.card_front');
  264. $card_back = input('post.card_back');
  265. $is_auth =User::where('id',$this->user_id)->value('is_auth');
  266. if($is_auth) $this->error('已认证');
  267. $get_age = get_age($id_card);
  268. if($get_age < 18)$this->error('未满18周岁!');
  269. $res = user_certification($id_card,$true_name);
  270. if(!$res) $this->error('认证失败');
  271. User::where('id',$this->user_id)->update(['is_auth'=>1,'true_name'=>$true_name,'card_front'=>$card_front,'card_back'=>$card_back,'id_card'=>$id_card,'auth_at'=>date('Y-m-d H:i:s')]);
  272. $this->success('认证成功');
  273. }
  274. /**
  275. * @title 注销会员
  276. * @desc 注销会员
  277. * @author qc
  278. * @method POST
  279. * @url /api/User_center/cancelUserInfo
  280. * @header name:Authorization require:1 desc:Token
  281. */
  282. public function cancelUserInfo()
  283. {
  284. Db::name('store_member')->where('id',$this->user_id)->update(['is_deleted'=>1]);
  285. $this->success('注销成功');
  286. }
  287. /**
  288. * @title 获取我绑定的支付宝账户
  289. * @desc 获取我绑定的支付宝账户
  290. * @author qc
  291. * @method GET
  292. * @url /api/User_center/getMyAliAccount
  293. * @return name:birthday type:string default:-- desc:出生日期
  294. * @return name:real_name type:string default:-- desc:姓名
  295. * @return name:card_no type:string default:-- desc:账号
  296. */
  297. public function getMyAliAccount()
  298. {
  299. $ali_account = UserBank::field('id,real_name,card_no')->where(['user_id'=>$this->user_id,'type'=>1,'is_deleted'=>0])->find();
  300. $ali_account ? $this->success('ok',['account'=>$ali_account->toArray()]) : $this->error('还没有绑定支付宝账户');
  301. }
  302. /**
  303. * @title 更改或绑定支付宝账户
  304. * @desc 更改或绑定支付宝账户
  305. * @author qc
  306. * @method POST
  307. * @url /api/User_center/bindAliAccount
  308. * @param name:phone type:string require:1 default:-- desc:手机号
  309. * @param name:code type:string require:1 default:-- desc:验证码
  310. * @param name:real_name type:string require:1 default:-- desc:真实姓名
  311. * @param name:card_no type:string require:1 default:-- desc:账号
  312. */
  313. public function bindAliAccount()
  314. {
  315. $phone = input('post.phone');
  316. $code = input('post.code');
  317. $real_name = input('post.real_name');
  318. $card_no = input('post.card_no');
  319. $check_code = $this->checkPhoneCode($phone,$code);
  320. if(!$check_code) $this->error('验证码错误');
  321. $ali_account = UserBank::where(['user_id'=>$this->user_id,'type'=>1,'is_deleted'=>0])->find();
  322. if(!$ali_account){
  323. $account_data =[
  324. 'user_id' => $this->user_id,
  325. 'real_name' => $real_name,
  326. 'bank_name' => '支付宝账号',
  327. 'card_no' => $card_no,
  328. 'create_time' => date('Y-m-d H:i:s'),
  329. ];
  330. UserBank::create($account_data);
  331. }else{
  332. $account_data =[
  333. 'user_id' => $this->user_id,
  334. 'real_name' => $real_name,
  335. 'bank_name' => '支付宝账号',
  336. 'card_no' => $card_no,
  337. 'update_time' => date('Y-m-d H:i:s'),
  338. ];
  339. UserBank::update($account_data,['id'=>$ali_account->id]);
  340. }
  341. $this->success('绑定成功');
  342. }
  343. /**
  344. * @title 更改或绑定银行卡
  345. * @desc 更改或绑定银行卡
  346. * @author qc
  347. * @method POST
  348. * @url /api/User_center/bindBankAccount
  349. * @param name:account_id type:string require:1 default:-- desc:记录id(修改时必传)
  350. * @param name:phone type:string require:1 default:-- desc:手机号
  351. * @param name:code type:string require:1 default:-- desc:验证码
  352. * @param name:real_name type:string require:1 default:-- desc:真实姓名
  353. * @param name:card_no type:string require:1 default:-- desc:账号
  354. * @param name:bank_name type:string require:1 default:-- desc:所属银行
  355. */
  356. public function bindBankAccount()
  357. {
  358. $phone = input('post.phone');
  359. $code = input('post.code');
  360. $real_name = input('post.real_name');
  361. $card_no = input('post.card_no');
  362. $bank_name = input('post.bank_name');
  363. $account_id = input('post.account_id');
  364. $check_code = $this->checkPhoneCode($phone,$code);
  365. if(!$check_code) $this->error('验证码错误');
  366. if(!$account_id){
  367. $account_data =[
  368. 'user_id' => $this->user_id,
  369. 'type' => 2,
  370. 'real_name' => $real_name,
  371. 'bank_name' => $bank_name,
  372. 'card_no' => $card_no,
  373. 'create_time' => date('Y-m-d H:i:s'),
  374. ];
  375. UserBank::create($account_data);
  376. }else{
  377. $account_data =[
  378. 'user_id' => $this->user_id,
  379. 'real_name' => $real_name,
  380. 'bank_name' => $bank_name,
  381. 'card_no' => $card_no,
  382. 'update_time' => date('Y-m-d H:i:s'),
  383. ];
  384. UserBank::update($account_data,['id'=>$account_id]);
  385. }
  386. $this->success('绑定成功');
  387. }
  388. /**
  389. * @title 获取绑定银行卡详情
  390. * @desc 获取绑定银行卡详情
  391. * @author qc
  392. * @method GET
  393. * @url /api/User_center/getBandAccountDetail
  394. * @param name:account_id type:string require:1 default:-- desc:id
  395. * @return name:real_name type:string require:1 default:-- desc:真实姓名
  396. * @return name:card_no type:string require:1 default:-- desc:账号
  397. * @return name:bank_name type:string require:1 default:-- desc:所属银行
  398. */
  399. public function getBandAccountDetail()
  400. {
  401. $account_id = input('get.account_id');
  402. $account_info = UserBank::field('id,real_name,card_no,bank_name')->where(['user_id'=>$this->user_id,'id'=>$account_id,'is_deleted'=>0])->find();
  403. $account_info ? $this->success('ok',['account'=>$account_info->toArray()]) : $this->error('没找到记录');
  404. }
  405. /**
  406. * @title 获取绑定银行卡列表
  407. * @desc 获取绑定银行卡列表
  408. * @author qc
  409. * @method GET
  410. * @url /api/User_center/getBankAccountList
  411. * @return name:real_name type:string require:1 default:-- desc:真实姓名
  412. * @return name:card_no type:string require:1 default:-- desc:账号
  413. * @return name:bank_name type:string require:1 default:-- desc:所属银行
  414. */
  415. public function getBankAccountList()
  416. {
  417. $list = UserBank::field('id,real_name,card_no,bank_name')->where(['user_id'=>$this->user_id,'type'=>2,'is_deleted'=>0])->order('id desc')->select();
  418. $this->success('ok',['list'=>$list ? $list->toArray() : []]);
  419. }
  420. }