<?php // Step 1: 用戶被重定向到授權URL $authorizationUrl = 'https://example.com/oauth/authorize?client_id=YOUR_CLIENT_ID&redirect_uri=YOUR_REDIRECT_URI&response_type=code'; header('Location: ' . $authorizationUrl); exit; // Step 2: 授權服務器重定向用戶到回調URL,並提供授權碼 $authorizationCode = $_GET['code']; // Step 3: 使用授權碼獲取訪問令牌 $tokenUrl = 'https://example.com/oauth/token'; $tokenData = [ 'grant_type' => 'authorization_code', 'code' => $authorizationCode, 'redirect_uri' => 'YOUR_REDIRECT_URI', 'client_id' => 'YOUR_CLIENT_ID', 'client_secret' => 'YOUR_CLIENT_SECRET', ]; $tokenOptions = [ 'http' => [ 'method' => 'POST', 'header' => 'Content-type: application/x-www-form-urlencoded', 'content' => http_build_query($tokenData) ] ]; $tokenContext = stream_context_create($tokenOptions); $tokenResult = file_get_contents($tokenUrl, false, $tokenContext); $accessToken = json_decode($tokenResult)->access_token; // Step 4: 使用訪問令牌獲取用戶資源$userUrl = 'https://example.com/api/user'; $userOptions = [ 'http' => [ 'method' => 'GET', 'header' => 'Authorization: Bearer ' . $accessToken ] ]; $userContext = stream_context_create($userOptions); $userResult = file_get_contents($userUrl, false, $userContext); $userData = json_decode($userResult); // 處理用戶數據echo 'Welcome, ' . $userData->name; ?>
相關標籤:
API