mirror of
https://gitee.com/koogua/course-tencent-cloud.git
synced 2025-07-13 11:59:11 +08:00
* !6 develop->master 1.1.0 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !7 纠正迁移文件和代码实际使用字段不一致 * 纠正迁移文件和时间代码中字段不一致 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !9 修正插入数据不一致以及后台菜单参数类型报错 * 1.修正插入的管理帐号数据 * 纠正迁移文件和时间代码中字段不一致 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !12 修正退款项目空白以及弹窗自适应 * 修复退款项目空白,以及弹窗高度自适应 * !13 修正退款项目空白以及弹窗自适应 * 修复退款项目空白,以及弹窗高度自适应 * !14 修正点击退款404 * 修复退款项目空白,以及弹窗高度自适应,取消退款内部错误 * 删除文件 LICENSE * add LICENSE. * update app/Http/Admin/Controllers/UploadController.php. 去除重复的signatureAction方法 * !19 v1.2.0阶段性合并 * 增加微信H5支付需要的Referer头信息 * 更新H5支付方式 * 更新H5支付方式 * 更新H5支付方式 * !23 修复添加课时后进入编辑页面500错误 * 修复添加课时后进入编辑页面500错误 * !24 修复添加课时后进入编辑页面500错误 * 修复添加课时后进入编辑页面500错误 * !33 开放登录阶段性合并 * Merge remote-tracking branch 'gitee/xiaochong0302/I280IZ' into xiaocho… * 初步完成开放登录,待线上测试7 * Merge branch 'demo' of gitee.com:koogua/course-tencent-cloud into xiao… * 初步完成开放登录,待线上测试6 * !30 开放登录线上测试5 * !29 开放登录线上测试5 * 初步完成开放登录,待线上测试5 * !28 开放登录线上测试4 * 初步完成开放登录,待线上测试4 * !27 开放登录线上测试3 * 初步完成开放登录,待线上测试3 * !26 开放登录线上测试2 * 初步完成开放登录,待线上测试2 * !25 开放登录线上测试 * 初步完成开放登录,待线上测试 * !22 验证更新h5支付 * Merge remote-tracking branch 'remotes/gitee/develop' into demo * !20 验证更新h5支付 * Merge branch 'develop' of https://gitee.com/koogua/course-tencent-clou… * !16 v1.2.0阶段性合并 * 删除调试断点代码 * 删除重复的signature方法 * Merge branch 'develop' of https://gitee.com/koogua/course-tencent-clou… * demo后台增加统计 * !5 更新版本号1.1.0 * !4 v1.1.0版本develop->demo * Merge branch 'develop' into demo * 1.增加changelog.md * Merge branch 'develop' into demo * Merge branch 'develop' into demo * Merge branch 'develop' into demo * !1 精简优化代码 * Merge branch 'develop' into demo * 合并修改 * !34 修复创建课时相关属性表数据未生成的问题 * 修复创建课时相关属性表数据未生成的问题 * !35 修复腾讯云回调数据结构改变导致的错误 * 修复腾讯云回调数据结构改变导致的错误,缩短vod_event计划任务时间 * !36 修复添加课程后进入列表500错误 * 修复未填充教师和分类的列表错误 * 优化第三方登录,修复注册密码加密问题 * !38 修复课程分类未过滤 * 过滤课程分类 * !39 修复课程分类未过滤 * 过滤课程分类 * !40 修复课程分类未过滤2 * 过滤课程分类 * 过滤课程分类 * !41 修复课程分类未过滤2 * 过滤课程分类 * 过滤课程分类 * 优化开发登录,计划任务执行路径,周期
108 lines
2.2 KiB
PHP
108 lines
2.2 KiB
PHP
<?php
|
||
|
||
namespace App\Services;
|
||
|
||
use GuzzleHttp\Client as HttpClient;
|
||
use Phalcon\Crypt;
|
||
use Phalcon\Di;
|
||
|
||
abstract class OAuth extends Service
|
||
{
|
||
|
||
/**
|
||
* @var string
|
||
*/
|
||
protected $clientId;
|
||
|
||
/**
|
||
* @var string
|
||
*/
|
||
protected $clientSecret;
|
||
|
||
/**
|
||
* @var string
|
||
*/
|
||
protected $redirectUri;
|
||
|
||
/**
|
||
* @var string
|
||
*/
|
||
protected $accessToken;
|
||
|
||
/**
|
||
* @var string
|
||
*/
|
||
protected $openId;
|
||
|
||
public function __construct($clientId, $clientSecret, $redirectUri)
|
||
{
|
||
$this->clientId = $clientId;
|
||
$this->clientSecret = $clientSecret;
|
||
$this->redirectUri = $redirectUri;
|
||
}
|
||
|
||
public function httpGet($uri, $params = [], $headers = [])
|
||
{
|
||
$client = new HttpClient();
|
||
|
||
$options = ['query' => $params, 'headers' => $headers];
|
||
|
||
$response = $client->get($uri, $options);
|
||
|
||
return $response->getBody();
|
||
}
|
||
|
||
public function httpPost($uri, $params = [], $headers = [])
|
||
{
|
||
$client = new HttpClient();
|
||
|
||
$options = ['query' => $params, 'headers' => $headers];
|
||
|
||
$response = $client->post($uri, $options);
|
||
|
||
return $response->getBody();
|
||
}
|
||
|
||
public function getState()
|
||
{
|
||
/**
|
||
* @var $crypt Crypt
|
||
*/
|
||
$crypt = Di::getDefault()->get('crypt');
|
||
|
||
return $crypt->encryptBase64(rand(1000, 9999));
|
||
}
|
||
|
||
public function checkState($state)
|
||
{
|
||
/**
|
||
* 注意事项:
|
||
* callback中的state参数并未做encode处理,参数中含有"+"
|
||
* 获取参数的时候却自动做了decode处理,"+"变成了空格
|
||
*/
|
||
$state = str_replace(' ', '+', $state);
|
||
|
||
/**
|
||
* @var $crypt Crypt
|
||
*/
|
||
$crypt = Di::getDefault()->get('crypt');
|
||
|
||
$value = $crypt->decryptBase64($state);
|
||
|
||
if ($value < 1000 || $value > 9999) {
|
||
throw new \Exception('Invalid OAuth State Value');
|
||
}
|
||
|
||
return true;
|
||
}
|
||
|
||
abstract public function getAuthorizeUrl();
|
||
|
||
abstract public function getAccessToken($code);
|
||
|
||
abstract public function getOpenId($accessToken);
|
||
|
||
abstract public function getUserInfo($accessToken, $openId);
|
||
|
||
}
|