在我的一个电商项目中,需要集成 Mollie 支付网关,并且需要使用 Mollie Connect (OAuth) 来连接商户的 Mollie 账户。这意味着我需要实现 OAuth 2.0 的授权流程,包括获取授权码、交换访问令牌、刷新令牌等等。手动实现这些流程不仅耗时,而且容易出错。
Composer在线学习地址:学习地址
幸运的是,我发现了 mollie/oauth2-mollie-php 这个 Composer 包。它基于 PHP League 的 OAuth 2.0 Client,专门为 Mollie 提供了 OAuth 2.0 的支持。使用它可以大大简化 Mollie Connect 的集成过程。
首先,你需要使用 composer 安装这个包:
composer require mollie/oauth2-mollie-php ^2.0
安装完成后,你就可以使用 \Mollie\OAuth2\Client\Provider\Mollie 类作为 OAuth 2.0 的 provider。以下是一个简单的授权码流程的示例:
$provider = new \Mollie\OAuth2\Client\Provider\Mollie([
'clientId' => 'YOUR_CLIENT_ID',
'clientSecret' => 'YOUR_CLIENT_SECRET',
'redirectUri' => 'https://your-redirect-uri',
]);
// 如果没有授权码,则获取授权码
if (!isset($_GET['code'])) {
// 从 provider 获取授权 URL
$authorizationUrl = $provider->getAuthorizationUrl([
// 可选,如果需要重新请求用户之前拒绝的权限
'approval_prompt' => 'force',
// 可选,权限列表,默认为 'organizations.read'
'scope' => [
\Mollie\OAuth2\Client\Provider\Mollie::SCOPE_ORGANIZATIONS_READ,
\Mollie\OAuth2\Client\Provider\Mollie::SCOPE_PAYMENTS_READ,
],
]);
// 保存 state 到 session
$_SESSION['oauth2state'] = $provider->getState();
// 重定向用户到授权 URL
header('Location: ' . $authorizationUrl);
exit;
}
// 检查 state,防止 CSRF 攻击
elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {
unset($_SESSION['oauth2state']);
exit('Invalid state');
}
else {
try {
// 使用授权码获取 access token
$accessToken = $provider->getAccessToken('authorization_code', [
'code' => $_GET['code']
]);
// 使用 access token 获取用户信息
$resourceOwner = $provider->getResourceOwner($accessToken);
print_r($resourceOwner->toArray());
} catch (\League\OAuth2\Client\Provider\Exception\IdentityProviderException $e) {
// 获取 access token 或用户信息失败
exit($e->getMessage());
}
}除了授权码流程,mollie/oauth2-mollie-php 还支持刷新 access token 和撤销 token。
ECTouch是上海商创网络科技有限公司推出的一套基于 PHP 和 MySQL 数据库构建的开源且易于使用的移动商城网店系统!应用于各种服务器平台的高效、快速和易于管理的网店解决方案,采用稳定的MVC框架开发,完美对接ecshop系统与模板堂众多模板,为中小企业提供最佳的移动电商解决方案。ECTouch程序源代码完全无加密。安装时只需将已集成的文件夹放进指定位置,通过浏览器访问一键安装,无需对已有
使用 mollie/oauth2-mollie-php 极大地简化了 Mollie Connect 的集成过程。它提供了清晰的 API 和示例代码,使得开发者可以专注于业务逻辑的实现,而无需花费大量时间处理 OAuth 2.0 的细节。如果你需要在你的 PHP 应用中集成 Mollie Connect,那么 mollie/oauth2-mollie-php 绝对是一个值得考虑的选择。










