


WeChat erhält mehrere globale access_token-Konflikte, was zur Ungültigkeit führt? (Lösung)
Token läuft standardmäßig in 7200 Sekunden ab. Wenn ein zweiter Ort ebenfalls denselben Token anfordert, läuft der erste Token innerhalb von 5 Minuten ab. Mit anderen Worten: Wenn die Zeit bei meiner zweiten Anfrage zu kurz ist, kommt es zu einem Konflikt.
Ich habe gerade die WeChat-Entwicklung gelernt und mein Code-Schreiben ist nicht perfekt. Ich habe nur beurteilt, ob die Lebensdauer größer als 7200 ist. Ich habe jemanden sagen sehen, dass der Messwert jede Minute beurteilt werden kann. Ich frage mich, ob Sie Optimierungsvorschläge für meinen Code haben. Vielen Dank
<code>function getWxAccessToken(){ if ( $_SESSION['access_token'] && $_SESSION['expire_time'] > time() ) { //未过期 return $_SESSION['access_token']; }else { $appid = "wx3bbf9ae731a6eb07"; $appsecret = "2b14a75fa48825ef3c76c8949b5e030f"; $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$appsecret; $res =$this->https_request($url,'get','json'); $access_token = $res["access_token"]; //将重新获取到的access_token存到session里 $_SESSION['access_token']=$access_token; $_SESSION['expire_time']=time()+7200; return $access_token; } } </code>
Der Konflikt ist eine Methode unter demselben Controller, und jeder Aufruf verwendet
<code> $access_token=$this->getWxAccessToken(); </code>
Die Fehlermeldung lautet wie folgt
<code>array(2) { ["errcode"] => int(40001) ["errmsg"] => string(81) "invalid credential, access_token is invalid or not latest hint: [pd4MfA0688vr40!]" } </code>
Ich habe gesehen, was der Beamte gesagt hat.
Die offizielle Bedeutung von 0,0 besteht darin, keine Geschäftslogik zum Aktualisieren des Tokens zu verwenden. Was ich geschrieben habe, scheint die Verwendung von Geschäftslogik zum Aktualisieren des Tokens zu sein Zentrale Steuerung durch Dritte?
Geben Sie den absoluten Pfad der Methode in den QR-Code-Generator ein und scannen Sie ihn. Dieses Debugging-Ergebnis fühlt sich korrekter an als der direkte Zugriff über den Browser.
In den meisten Fällen ist das Programm grundsätzlich in Ordnung, wenn der Browser beim Öffnen 40001 meldet
Antwortinhalt:
Token läuft standardmäßig in 7200 Sekunden ab. Wenn ein zweiter Ort ebenfalls denselben Token anfordert, läuft der erste Token innerhalb von 5 Minuten ab. Mit anderen Worten: Wenn die Zeit bei meiner zweiten Anfrage zu kurz ist, kommt es zu einem Konflikt.
Ich habe gerade die WeChat-Entwicklung gelernt und mein Code-Schreiben ist nicht perfekt. Ich habe nur beurteilt, ob die Lebensdauer größer als 7200 ist. Ich habe jemanden sagen sehen, dass der Messwert jede Minute beurteilt werden kann. Ich frage mich, ob Sie Optimierungsvorschläge für meinen Code haben. Vielen Dank
<code>function getWxAccessToken(){ if ( $_SESSION['access_token'] && $_SESSION['expire_time'] > time() ) { //未过期 return $_SESSION['access_token']; }else { $appid = "wx3bbf9ae731a6eb07"; $appsecret = "2b14a75fa48825ef3c76c8949b5e030f"; $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$appsecret; $res =$this->https_request($url,'get','json'); $access_token = $res["access_token"]; //将重新获取到的access_token存到session里 $_SESSION['access_token']=$access_token; $_SESSION['expire_time']=time()+7200; return $access_token; } } </code>
Der Konflikt ist eine Methode unter demselben Controller, und jeder Aufruf verwendet
<code> $access_token=$this->getWxAccessToken(); </code>
Die Fehlermeldung lautet wie folgt
<code>array(2) { ["errcode"] => int(40001) ["errmsg"] => string(81) "invalid credential, access_token is invalid or not latest hint: [pd4MfA0688vr40!]" } </code>
Ich habe gesehen, was der Beamte gesagt hat.
Die offizielle Bedeutung von 0,0 besteht darin, keine Geschäftslogik zum Aktualisieren des Tokens zu verwenden. Was ich geschrieben habe, scheint die Verwendung von Geschäftslogik zum Aktualisieren des Tokens zu sein Zentrale Steuerung durch Dritte?
Geben Sie den absoluten Pfad der Methode in den QR-Code-Generator ein und scannen Sie ihn. Dieses Debugging-Ergebnis fühlt sich korrekter an als der direkte Zugriff über den Browser.
In den meisten Fällen ist das Programm grundsätzlich in Ordnung, wenn der Browser beim Öffnen 40001 meldet
Es wird empfohlen, access_token in der Datenbank zu speichern, damit alle Unternehmen dasselbe Token verwenden, sodass nicht jeder Geschäftslogikpunkt unabhängig voneinander access_token anfordert.
Das offizielle Dokument bedeutet, dass, wenn die Geschäftslogik in mehreren ist Da der Zugriffstoken und die Ablaufzeit auf jedem Server in der Sitzung gespeichert werden, wird die Sitzung nicht zwischen den Servern geteilt, was dazu führt, dass das Unternehmen auf jedem Server eine Anfrage initiiert, wenn der Zugriffstoken auf einem der Server nicht abgelaufen ist anderer Server Das access_token wurde erneut angefordert, wodurch das access_token auf dem ersten Server ungültig wurde, und dann wurde das abgelaufene access_token zum Anfordern von Diensten verwendet, was zu einem instabilen Dienst führte
Verwenden Sie den zentralen Steuerungsserver, um das access_token zu speichern, damit der Dienst funktioniert vereinheitlicht und es kommt nicht zu Konflikten zwischen Unternehmen, wodurch die Datenkonsistenz gewährleistet ist
Das access_token ist für alle Anrufe gleich. Es ist nicht erforderlich, die Sitzung zu speichern. Normalerweise wird es im Cache abgelegt, andernfalls können Sie es einfach in die Datenbank einfügen.
Gehen Sie bei jeder Verwendung zur Datenbank. Wenn es innerhalb des Gültigkeitszeitraums liegt, verwenden Sie es direkt. Wenn es ungültig ist, rufen Sie es erneut ab und fügen Sie es in die Datenbank ein.
Die Sitzung ist benutzerbasiert, sodass Sie sie aktualisieren können, sobald jeder Benutzer sie besucht.
Es wird empfohlen, es im Cache oder in der Datenbank abzulegen und regelmäßig zu aktualisieren.

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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Das Arbeiten mit der Datenbank in CakePHP ist sehr einfach. In diesem Kapitel werden wir die CRUD-Operationen (Erstellen, Lesen, Aktualisieren, Löschen) verstehen.

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

Die Anmeldung bei CakePHP ist eine sehr einfache Aufgabe. Sie müssen nur eine Funktion verwenden. Sie können Fehler, Ausnahmen, Benutzeraktivitäten und von Benutzern durchgeführte Aktionen für jeden Hintergrundprozess wie Cronjob protokollieren. Das Protokollieren von Daten in CakePHP ist einfach. Die Funktion log() wird bereitgestellt

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c
