Files
huangjingfen/pro_v3.5.1/app/controller/api/v2/wechat/Routine.php
panchengyong c1e74d8e68 chore(php): 统一 ScottPan 文件头与注释域名替换
- 按 docs/renew-code-comment.md 将 PHP 文件头改为带边框的 Author 注释\n- 注释中的 crmeb.com 替换为 uj345.cn(代码字符串中的外链未改)\n- 新增 docs/renew-code-comment.md 说明

Made-with: Cursor
2026-03-29 11:22:58 +08:00

216 lines
7.1 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
// +----------------------------------------------------------------------
// | Author: ScottPan Team
// +----------------------------------------------------------------------
namespace app\controller\api\v2\wechat;
use app\Request;
use app\services\wechat\RoutineServices;
use crmeb\services\CacheService;
use think\annotation\Inject;
/**
* Class Routine
* @package app\api\controller\v2\wechat
*/
class Routine
{
/**
* @var RoutineServices
*/
#[Inject]
protected RoutineServices $services;
/**
* 返回用户信息的缓存key返回是否强制绑定手机号
* @param $code
* @param $spread_code
* @param $spread_spid
* @return \think\Response
*/
public function authType($code, $spread_code = '', $spread_spid = '')
{
if (!$code) return app('json')->fail('参数有误');
$data = $this->services->authType($code, $spread_spid, $spread_code);
return app('json')->success($data);
}
/**
* 根据缓存获取token
* @param $key
* @return \think\Response
*/
public function authLogin($key)
{
if (!$key) return app('json')->fail('参数有误');
$data = $this->services->authLogin($key);
return app('json')->success($data);
}
/**
* @param $key
* @param $phone
* @param $captcha
* @param $spread_code
* @param $spread_spid
* @param $code
* @return \think\Response
* @throws \Psr\SimpleCache\InvalidArgumentException
*/
public function phoneLogin($key = '', $phone = '', $captcha = '', $spread_code = '', $spread_spid = '', $code = '')
{
//验证验证码
$verifyCode = CacheService::get('code_' . $phone);
if (!$verifyCode)
return app('json')->fail('请先获取验证码');
$verifyCode = substr($verifyCode, 0, 6);
if ($verifyCode != $captcha) {
return app('json')->fail('验证码错误');
}
CacheService::delete('code_' . $phone);
$data = $this->services->phoneLogin($key, $phone, $spread_spid, $spread_code, $code);
return app('json')->success($data);
}
/**
* 小程序绑定手机号
* @param $code
* @param $iv
* @param $encryptedData
* @return \think\Response
*/
public function bindingPhone($code = '', $iv = '', $encryptedData = '')
{
if (!$code || !$iv || !$encryptedData) return app('json')->fail('参数有误');
$this->services->bindingPhone($code, $iv, $encryptedData);
return app('json')->success(410016);
}
/**
* 小程序授权登录
* @param Request $request
* @return mixed
* @throws \Psr\SimpleCache\InvalidArgumentException
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function auth(Request $request)
{
[$code, $spread_spid, $spread_code, $iv, $encryptedData] = $request->postMore([
['code', ''],
['spread_spid', 0],
['spread_code', ''],
['iv', ''],
['encryptedData', ''],
], true);
$token = $this->services->newAuth($code, $spread_spid, $spread_code, $iv, $encryptedData);
if ($token) {
if (isset($token['key']) && $token['key']) {
return app('json')->successful('授权成功,请绑定手机号', $token);
} else {
return app('json')->successful('登录成功!', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]);
}
} else
return app('json')->fail('获取用户访问token失败!');
}
/**
* 静默授权
* @param $code
* @param $spread
* @return mixed
*/
public function silenceAuth($code, $spread_code = '', $spread_spid = '')
{
$token = $this->services->silenceAuth($code, (int)$spread_code, (int)$spread_spid);
if ($token && isset($token['key'])) {
return app('json')->success('授权成功,请绑定手机号', $token);
} else if ($token) {
return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]);
} else
return app('json')->fail('登录失败');
}
/**
* 静默授权 不登录
* @param $code
* @param $spread
* @return mixed
*/
public function silenceAuthNoLogin($code, $spread_code = '', $spread_spid = '')
{
$token = $this->services->silenceAuth($code, (int)$spread_code, (int)$spread_spid, true);
if ($token && isset($token['auth_login'])) {
return app('json')->success('授权成功');
} else if ($token) {
return app('json')->success('登录成功', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]);
} else
return app('json')->fail('登录失败');
}
/**
* 静默授权
* @param $code
* @param $spread
* @return mixed
*/
public function silenceAuthBindingPhone($code = '', $spread_code = '', $spread_spid = '', $phone = '', $captcha = '')
{
//验证验证码
$verifyCode = CacheService::get('code_' . $phone);
if (!$verifyCode)
return app('json')->fail('请先获取验证码');
$verifyCode = substr($verifyCode, 0, 6);
if ($verifyCode != $captcha) {
CacheService::delete('code_' . $phone);
return app('json')->fail('验证码错误');
}
CacheService::delete('code_' . $phone);
$token = $this->services->silenceAuthBindingPhone($code, $spread_code, $spread_spid, $phone);
if ($token) {
return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]);
} else
return app('json')->fail('登录失败');
}
/**
* 授权获取小程序用户手机号 直接绑定
* @param $code
* @param $iv
* @param $encryptedData
* @return mixed
*/
public function authBindingPhone($code = '', $iv = '', $encryptedData = '', $spread_code = '', $spread_spid = '', $key = '')
{
if (!$code || !$iv || !$encryptedData)
return app('json')->fail('参数有误');
$token = $this->services->authBindingPhone($code, $iv, $encryptedData, $spread_code, $spread_spid, $key);
if ($token) {
return app('json')->success('登录成功', $token);
} else
return app('json')->fail('登录失败');
}
/**
* 更新用户信息
* @param $userInfo
* @return mixed
*/
public function updateInfo(Request $request, $userInfo)
{
if (!$userInfo) {
return app('json')->fail('参数有误');
}
$uid = (int)$request->uid();
$re = $this->services->updateUserInfo($uid, $userInfo);
if ($re) {
return app('json')->success('更新成功');
} else
return app('json')->fail('更新失败');
}
}