UserCenter.php 19 KB

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