PHP-Version QQ-Anmeldeport
In diesem Artikel wird hauptsächlich die PHP-Version des QQ-Login-Ports vorgestellt. Ich hoffe, dass er für alle hilfreich ist.
Aufgrund der Beliebtheit inländischer QQ-Benutzer versuchen große Websites jetzt ihr Bestes, um QQ-Anmeldeports bereitzustellen. Werfen wir einen Blick auf die PHP-Version als Referenz
/** * QQ互联 oauth * @author dyllen * */ class Oauth { //取Authorization Code Url const PC_CODE_URL = 'https://graph.qq.com/oauth2.0/authorize'; //取Access Token Url const PC_ACCESS_TOKEN_URL = 'https://graph.qq.com/oauth2.0/token'; //取用户 Open Id Url const OPEN_ID_URL = 'https://graph.qq.com/oauth2.0/me'; //用户授权之后的回调地址 public $redirectUri = null; // App Id public $appid = null; //App Key public $appKey = null; //授权列表 //字符串,多个用逗号隔开 public $scope = null; //授权code public $code = null; //续期access token的凭证 public $refreshToken = null; //access token public $accessToken = null; //access token 有效期,单位秒 public $expiresIn = null; //state public $state = null; public $openid = null; //construct public function __construct($config=[]) { foreach($config as $key => $value) { $this->$key = $value; } } /** * 得到获取Code的url * @throws \InvalidArgumentException * @return string */ public function codeUrl() { if (!$this->redirectUri) { throw new \Exception('parameter $redirectUri must be set.'); } $query = [ 'response_type' => 'code', 'client_id' => $this->appid, 'redirect_uri' => $this->redirectUri, 'state' => $this->getState(), 'scope' => $this->scope, ]; return self::PC_CODE_URL . '?' . http_build_query($query); } /** * 取access token * @throws Exception * @return boolean */ public function getAccessToken() { $params = [ 'grant_type' => 'authorization_code', 'client_id' => $this->appid, 'client_secret' => $this->appKey, 'code' => $this->code, 'redirect_uri' => $this->redirectUri, ]; $url = self::PC_ACCESS_TOKEN_URL . '?' . http_build_query($params); $content = $this->getUrl($url); parse_str($content, $res); if ( !isset($res['access_token']) ) { $this->thrwoError($content); } $this->accessToken = $res['access_token']; $this->expiresIn = $res['expires_in']; $this->refreshToken = $res['refresh_token']; return true; } /** * 刷新access token * @throws Exception * @return boolean */ public function refreshToken() { $params = [ 'grant_type' => 'refresh_token', 'client_id' => $this->appid, 'client_secret' => $this->appKey, 'refresh_token' => $this->refreshToken, ]; $url = self::PC_ACCESS_TOKEN_URL . '?' . http_build_query($params); $content = $this->getUrl($url); parse_str($content, $res); if ( !isset($res['access_token']) ) { $this->thrwoError($content); } $this->accessToken = $res['access_token']; $this->expiresIn = $res['expires_in']; $this->refreshToken = $res['refresh_token']; return true; } /** * 取用户open id * @return string */ public function getOpenid() { $params = [ 'access_token' => $this->accessToken, ]; $url = self::OPEN_ID_URL . '?' . http_build_query($params); $this->openid = $this->parseOpenid( $this->getUrl($url) ); return $this->openid; } /** * get方式取url内容 * @param string $url * @return mixed */ public function getUrl($url) { $ch = curl_init(); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE); curl_setopt($ch, CURLOPT_URL, $url); $response = curl_exec($ch); curl_close($ch); return $response; } /** * post方式取url内容 * @param string $url * @param array $keysArr * @param number $flag * @return mixed */ public function postUrl($url, $keysArr, $flag = 0) { $ch = curl_init(); if(! $flag) curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE); curl_setopt($ch, CURLOPT_POST, TRUE); curl_setopt($ch, CURLOPT_POSTFIELDS, $keysArr); curl_setopt($ch, CURLOPT_URL, $url); $ret = curl_exec($ch); curl_close($ch); return $ret; } /** * 取state * @return string */ protected function getState() { $this->state = md5(uniqid(rand(), true)); //state暂存在缓存里面 //自己定义 //。。。。。。。。。 return $this->state; } /** * 验证state * @return boolean */ protected function verifyState() { //。。。。。。。 } /** * 抛出异常 * @param string $error * @throws \Exception */ protected function thrwoError($error) { $subError = substr($error, strpos($error, "{")); $subError = strstr($subError, "}", true) . "}"; $error = json_decode($subError, true); throw new \Exception($error['error_description'], (int)$error['error']); } /** * 从获取openid接口的返回数据中解析出openid * @param string $str * @return string */ protected function parseOpenid($str) { $subStr = substr($str, strpos($str, "{")); $subStr = strstr($subStr, "}", true) . "}"; $strArr = json_decode($subStr, true); if(!isset($strArr['openid'])) { $this->thrwoError($str); } return $strArr['openid']; } }
Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein.
Verwandte Empfehlungen:
php implementiert die Erkennungs- und Vervollständigungsfunktion für das End-Tag in HTML-Tags
Fähigkeiten zur Konvertierung von PHP-Strings
PHP implementiert die Batch-Upload-Funktion für bestimmte Suffixdateien
Das obige ist der detaillierte Inhalt vonPHP-Version QQ-Anmeldeport. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

OAuth in PHP: Erstellen eines JWT-Autorisierungsservers Mit dem Aufkommen mobiler Anwendungen und dem Trend zur Trennung von Front-End und Back-End ist OAuth zu einem unverzichtbaren Bestandteil moderner Webanwendungen geworden. OAuth ist ein Autorisierungsprotokoll, das die Ressourcen der Benutzer vor unbefugtem Zugriff schützt, indem es standardisierte Prozesse und Mechanismen bereitstellt. In diesem Artikel erfahren Sie, wie Sie mit PHP einen auf JWT (JSONWebTokens) basierenden OAuth-Autorisierungsserver erstellen. JWT ist eine Art von

PHP und OAuth: Implementierung der Microsoft-Login-Integration Mit der Entwicklung des Internets müssen immer mehr Websites und Anwendungen Benutzer dabei unterstützen, sich über Konten von Drittanbietern anzumelden, um eine bequeme Registrierungs- und Login-Erfahrung zu ermöglichen. Das Microsoft-Konto ist eines der weltweit am häufigsten verwendeten Konten, und viele Benutzer möchten sich mit einem Microsoft-Konto bei Websites und Anwendungen anmelden. Um die Microsoft-Anmeldeintegration zu erreichen, können wir das OAuth-Protokoll (Open Authorization) verwenden. OAuth ist ein offenes Standardautorisierungsprotokoll, das es Benutzern ermöglicht, Anwendungen von Drittanbietern zu autorisieren, in ihrem Namen zu handeln

Mit der Popularität des mobilen Internets erfordern immer mehr Anwendungen, dass sich Benutzer authentifizieren und autorisieren. OAuth2 ist ein beliebtes Authentifizierungs- und Autorisierungsframework, das Anwendungen einen standardisierten Mechanismus zur Implementierung dieser Funktionen bietet. LaravelPassport ist eine benutzerfreundliche, sichere und sofort einsatzbereite OAuth2-Serverimplementierung, die PHP-Entwicklern leistungsstarke Tools zum Erstellen der OAuth2-Authentifizierung und -Autorisierung bietet. In diesem Artikel wird die Verwendung von LaravelPassport vorgestellt

So führen Sie die GoogleDrive-Integration mit PHP und OAuth durch. GoogleDrive ist ein beliebter Cloud-Speicherdienst, der es Benutzern ermöglicht, Dateien in der Cloud zu speichern und sie mit anderen Benutzern zu teilen. Über GoogleDriveAPI können wir PHP verwenden, um Code zur Integration in GoogleDrive zu schreiben, um das Hochladen, Herunterladen, Löschen und andere Vorgänge von Dateien zu implementieren. Um GoogleDriveAPI verwenden zu können, müssen wir uns über OAuth authentifizieren

OAuth2 ist ein weit verbreitetes offenes Standardprotokoll, um Anwendungen von Drittanbietern wie sozialen Netzwerken wie Google, Facebook und Twitter Zugriff auf Benutzerressourcen zu gewähren, ohne Benutzernamen und Passwörter direkt an diese zu übertragen. In PHP können Sie vorgefertigte OAuth2-Bibliotheken verwenden, um den OAuth2-Fluss einfach zu implementieren, oder Sie können Ihre eigene Bibliothek erstellen, um ihn zu implementieren. In diesem Artikel konzentrieren wir uns auf die Verwendung der vorgefertigten OAuth2-Bibliothek und die Verwendung von OAuth darüber

OAuth2-Authentifizierungsmethode und Implementierung in PHP Mit der Entwicklung des Internets müssen immer mehr Anwendungen mit Plattformen von Drittanbietern interagieren. Um die Privatsphäre und Sicherheit der Benutzer zu schützen, verwenden viele Plattformen von Drittanbietern das OAuth2-Protokoll zur Implementierung der Benutzerauthentifizierung. In diesem Artikel stellen wir die OAuth2-Authentifizierungsmethode und -Implementierung in PHP vor und fügen entsprechende Codebeispiele bei. OAuth2 ist ein Autorisierungsframework, das es Benutzern ermöglicht, Anwendungen von Drittanbietern ohne Angabe von Gründen den Zugriff auf ihre Ressourcen bei einem anderen Dienstanbieter zu autorisieren

OAuth2.0 ist ein Protokoll, das zur Autorisierung von Drittanwendungen auf Benutzerressourcen verwendet wird. Es wird mittlerweile häufig im Internetbereich verwendet. Mit der Entwicklung des Internetgeschäfts müssen immer mehr Anwendungen das OAuth2.0-Protokoll unterstützen. In diesem Artikel wird die beste Möglichkeit zur Implementierung des OAuth2.0-Protokolls mit PHP vorgestellt. 1. Grundkenntnisse von OAuth2.0 Bevor wir die Implementierung von OAuth2.0 einführen, müssen wir einige Grundkenntnisse von OAuth2.0 verstehen. Autorisierungstyp OAuth2.0-Protokoll ermittelt

Da die Verwendung von APIs immer weiter verbreitet wird, wird der Schutz der Sicherheit und Skalierbarkeit von APIs immer wichtiger. OAuth2 hat sich zu einem weit verbreiteten API-Sicherheitsprotokoll entwickelt, das Anwendungen den Zugriff auf geschützte Ressourcen durch Autorisierung ermöglicht. Zur Implementierung der OAuth2-Authentifizierung bietet LaravelPassport eine einfache und flexible Möglichkeit. In diesem Artikel erfahren Sie, wie Sie die APIOAuth2-Authentifizierung mit LaravelPassport implementieren. Lar
