Microsoft Entra Sample Api Request

php版简单microsoft entra应用,包括oauth2登录鉴权获取token,api请求

Usage

composer require zatxm/microsoft-entra

1、请求授权代码

/** * 请求授权代码 */ use ZatxmMicrosoftEntraOAuth; $oauth = new OAuth([ 'clientId' => 'xxxx', //应用程序ID 'clientSecret' => 'xxxx', //应用程序秘钥 'scope' => 'openid profile offline_access user.read', //权限内容 'oauthRedirectUri' => 'http://localhost:9003', //配置的回调地址 // 鉴权接口地址,默认为以下三个可以不传 'oauthAuthority' => 'https://login.microsoftonline.com/common', 'oauthAuthorizeEndpoint' => '/oauth2/v2.0/authorize', 'oauthTokenEndpoint' => '/oauth2/v2.0/token' ]); // 应该执行跳转此url,它会要求你登录、授权并跳转到回调url // 跳转到回调url,您应该验证state,state可以通过下面获取 // 回调会返回code,一般10分钟有效,您应该用它来获取token // 您应该可以存储code和以下的tag,因为他们可用与获取token $authUrl = $oauth->getAuthorizationUrl(); // tag会返回如['state'=>'xx', 'codeVerifier'=>'xx', 'codeChallenge'=>'xx']; $tag = $oauth->getTag();

2、获取access token

/** * 获取access token */ use ZatxmMicrosoftEntraOAuth; $oauth = new OAuth([ 'clientId' => 'xxxx', //应用程序ID 'clientSecret' => 'xxxx', //应用程序秘钥 'scope' => 'openid profile offline_access user.read', //权限内容 'oauthRedirectUri' => 'http://localhost:9003', //配置的回调地址 ]); // 微软回调返回的code值,有效期一般10分钟 $authorizationCode = 'xx'; // 可以通过上步的tag取得 $codeVerifier = 'xx'; $accessTokenArr = $oauth->getAccessToken($authorizationCode, $codeVerifier); $accessToken = $accessTokenArr['access_token']; //可能有error错误码

3、请求entra应用api如graph

/** * 发送邮件 */ use ZatxmMicrosoftEntraEntraApi; $accessToken = 'xx'; //上步获取的access token $graphApiEndpoint = 'https://graph.microsoft.com/v1.0'; //接口地址,可以不传默认就是这个 $api = new EntraApi($accessToken, $graphApiEndpoint); $api->setAccessToken('xxxx'); //可以设置新的token $params = [ 'message' => [ 'subject' => '邮件标题', 'body' => [ 'contentType' => 'html', 'content' => '邮件内容' ], 'toRecipients' => [['emailAddress'=>['address'=>'xxxx']]] ], 'saveToSentItems' => true ]; $res = $api->go('/me/sendMail', $params, 'POST');

4、access token过期可以通过刷新token重新获取

/** * 刷新获取access token */ use ZatxmMicrosoftEntraOAuth; $oauth = new OAuth([ 'clientId' => 'xxxx', //应用程序ID 'clientSecret' => 'xxxx', //应用程序秘钥 'scope' => 'openid profile offline_access user.read', //权限内容 'oauthRedirectUri' => 'http://localhost:9003', //配置的回调地址 ]); $refreshToken = 'xx'; //refresh_token $accessTokenArr = $oauth->getAccessTokenRefresh($refreshToken); $accessToken = $accessTokenArr['access_token']; //可能有error错误码

License

MIT

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。
3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考学习用!
4、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。