So konfigurieren Sie die WeChat-OAuth-Authentifizierung für Captive Portals
Dieser technische Leitfaden erklärt, wie Sie die WeChat-OAuth-Authentifizierung für Captive Portals konfigurieren. Er beschreibt detailliert die erforderlichen Plattform-Registrierungen, den OAuth 2.0-Ablauf, die Auswahl des Scopes sowie die Mechanismen zur Netzwerk-Durchsetzung, die für die sichere Erfassung von First-Party-Daten chinesischer Besucher erforderlich sind.
Diesen Leitfaden anhören
Podcast-Transkript ansehen

执行摘要
当中国访客连接到您的 WiFi 时,如果登录页面仅提供电子邮件或 Facebook 登录,会立即产生使用阻碍。微信拥有 13.8 亿月活跃用户,将其配置为身份提供商可以消除这一障碍。本指南将阐述如何为 Captive Portal 实现微信 OAuth 2.0 认证,详细介绍必要的平台注册、OAuth 流程以及将成功登录转化为网络访问所需的网络强制执行机制。我们将涵盖企业级硬件的技术实现,以及 GDPR 和《个人信息保护法》(PIPL)下的合规要求。
技术架构
Captive Portal 会拦截来自未认证设备的 HTTP 流量,并将其重定向到托管在门户服务器上的登录页面。当您集成微信 OAuth 时,即是在此流程中插入了一个第三方身份提供商。

具体交互步骤如下:
- 访客连接到 SSID。
- 无线接入点(AP)或无线控制器检测到缺乏已认证的会话,并将 HTTP 流量重定向到 Captive Portal URL。
- 访客选择微信登录。
- 门户服务器将浏览器重定向到微信的授权端点(
open.weixin.qq.com),并传递AppID、redirect_uri、response_type=code和scope。 - 微信处理身份验证。如果访客在微信内置浏览器中使用
snsapi_base作用域,此过程将静默进行。 - 微信携带临时授权码重定向回门户的
redirect_uri。 - 门户服务器通过调用
api.weixin.qq.com/sns/oauth2/access_token,用该授权码换取访问令牌。 - 微信返回
access_token、refresh_token以及用户的openid。
平台注册要求
实现微信登录需要在正确的开发者平台上进行注册。微信运营着两个不同的平台,选择错误的平台会导致集成失败。
微信公众平台
对于在微信内置浏览器中为访客提供服务的 Captive Portal,您需要在微信公众平台(mp.weixin.qq.com)上注册一个服务号。订阅号缺少必要的 OAuth 网页授权权限。服务号同时支持 snsapi_base 和 snsapi_userinfo 作用域。
微信开放平台
对于从微信外部的标准移动浏览器(例如 Android 上的 Chrome 或 iOS 上的 Safari)访问的 Captive Portal,您需要一个在开放平台(open.weixin.qq.com)注册的网站应用。这使用 snsapi_login 作用域,并呈现一个供用户使用其微信应用扫描的二维码。
大多数企业部署都需要进行这两种注册,以覆盖所有访问方式。
作用域选择与数据收集
作用域参数决定了微信返回给您门户服务器的数据。这一决定会同时影响用户摩擦和数据隐私合规性。

snsapi_base
此作用域仅返回 OpenID,即您公众号内用户的唯一标识符。它不需要用户授权提示,从而使身份验证对用户无感。这对于您已拥有其个人资料的回访访客,或者对于将零摩擦置于新数据收集之上的场所来说是最佳选择。
snsapi_userinfo
此作用域返回 OpenID 以及用户的微信昵称、头像、性别、语言设置和城市。它需要一个明确的授权页面,从而引入了摩擦。在需要建立个人资料的首次访客注册中,请使用此作用域,并配合符合 GDPR 的授权层。
网络强制执行集成
获取 OAuth 令牌可以证明身份,但它并不能打开网络。您必须使用标准协议将成功的身份验证转化为网络访问。
RADIUS 授权变更 (CoA)
在 IEEE 802.1X 和 RFC 3576 中定义的 RADIUS CoA 允许门户服务器在 OAuth 成功后向网络控制器发送请求。然后,控制器将设备从未经身份验证的 VLAN 移动到访客 VLAN。这是包括 Cisco Meraki、HPE Aruba、Ruckus 和 Juniper Mist 在内的企业级硬件的标准配置。
MAC 地址旁路
或者,门户服务器将设备的 MAC 地址注册为已授权客户端,然后控制器允许其访问。虽然实现起来更简单,但由于 MAC 地址可以被伪造,因此安全性较低。
Purple 的云覆盖技术可自动完成此转换,在微信 OAuth 完成后向底层硬件(包括 Ubiquiti UniFi、Cambium、Extreme 和 Fortinet)发送相应的信号。
合规与安全考量
GDPR 与 PIPL 对齐
如果您为欧洲访客提供服务,GDPR 适用于通过微信 OAuth 收集的数据。如果您为中国访客提供服务,则适用中国《个人信息保护法》(PIPL)。这两个框架都要求处理具有合法基础、明确的目的限制和数据最小化。相比 snsapi_userinfo,snsapi_base 作用域更容易符合数据最小化原则。
CSRF 防护
OAuth 请求中的 state 参数可防止跨站请求伪造。您必须生成一个加密随机的 state 值,将其存储在用户会话中,并在微信重定向返回时对其进行验证。
重定向 URI 验证
微信会根据在平台上注册的授权域名验证 redirect_uri。如果您的门户服务器使用不同的子域名、路径或使用 HTTP 代替 HTTPS,则 OAuth 流程将失败并报错 40029。
有关保护网络的更多信息,请参阅我们的 Enterprise WiFi Security: A Complete Guide for 2026 。
Schlüsseldefinitionen
snsapi_base
Ein WeChat-OAuth-Scope, der nur die OpenID des Benutzers zurückgibt, ohne eine Einverständniserklärung anzuzeigen.
Wird verwendet, wenn IT-Teams wiederkehrende Besucher geräuschlos authentifizieren möchten, ohne Reibungsverluste beim Login zu verursachen.
snsapi_userinfo
Ein WeChat-OAuth-Scope, der die OpenID zusammen mit demografischen Daten (Spitzname, Geschlecht, Stadt) zurückgibt und die ausdrückliche Zustimmung des Benutzers erfordert.
Wird bei der Erstregistrierung verwendet, wenn Marketingteams ein Besucherprofil erstellen möchten.
OpenID
Eine eindeutige Kennung für einen bestimmten Benutzer innerhalb eines bestimmten WeChat Official Accounts.
Wird als Primärschlüssel in der Portal-Datenbank verwendet, um das Besucherverhalten und wiederkehrende Besuche zu verfolgen.
RADIUS CoA
Change of Authorisation. Ein in RFC 3576 definierter Mechanismus, der es einem Server ermöglicht, den Autorisierungsstatus einer aktiven Sitzung zu ändern.
Wird vom Portal-Server verwendet, um dem Wireless-Controller nach erfolgreicher WeChat-Authentifizierung mitzuteilen, dass der Netzwerkzugriff gewährt werden soll.
PIPL
Personal Information Protection Law. Chinas umfassende Datenschutzverordnung.
Muss neben der GDPR berücksichtigt werden, wenn der Consent-Flow für chinesische Besucher, die den WeChat-Login nutzen, gestaltet wird.
AppID and AppSecret
Die von WeChat bereitgestellten Anmeldedaten zur Identifizierung und Authentifizierung Ihrer Anwendung.
Das AppSecret muss sicher auf dem Portal-Server verbleiben und darf niemals im clientseitigen Code offengelegt werden.
State Parameter
Eine kryptografisch zufällige Zeichenfolge, die in der OAuth-Anfrage übergeben und bei der Rückkehr validiert wird.
Unerlässlich zur Verhinderung von Cross-Site-Request-Forgery-Angriffen (CSRF) auf das Captive Portal.
MAC Address Bypass
Eine Methode zur Gewährung des Netzwerkzugriffs durch Autorisierung der Hardwareadresse des Geräts, anstatt eine 802.1X-Authentifizierung zu erfordern.
Eine Alternative zu RADIUS CoA für einfachere Netzwerkeinrichtungen, wenn auch weniger sicher.
Ausgearbeitete Beispiele
Eine Luxus-Einzelhandelsmarke in London möchte chinesischen Käufern einen WeChat-Login anbieten. Sie möchte demografische Daten erfassen, um ihren Kundenstamm besser zu verstehen, ist jedoch besorgt über die GDPR-Konformität und hohe Absprungraten am Portal.
Der Einzelhändler sollte ein Service-Konto auf der WeChat Official Accounts Platform registrieren. Er muss das Portal so konfigurieren, dass bei der ersten Verbindung der Scope snsapi_userinfo verwendet wird, um demografische Daten (Spitzname, Geschlecht, Stadt) zu erfassen. Um die GDPR-Konformität zu gewährleisten, muss die Portalseite vor der WeChat-Weiterleitung ein klares, bewusstes Opt-in anzeigen, das genau erklärt, welche Daten erfasst werden und warum. Bei wiederkehrenden Käufern sollte das Portal die MAC-Adresse erkennen und snsapi_base für eine stille, reibungslose Re-Authentifizierung nutzen.
Ein Stadion stellt ein neues WiFi-Netzwerk mit HPE Aruba-Controllern bereit. Sie haben WeChat-OAuth konfiguriert und das Portal empfängt erfolgreich das Access-Token, aber das Gerät des Besuchers bleibt auf der Captive Portal-Seite hängen und kann nicht auf das Internet zugreifen.
Der Integration fehlt ein Mechanismus zur Netzwerk-Durchsetzung. Der Portal-Server hat zwar die Identität des Benutzers über WeChat verifiziert, aber dem HPE Aruba-Controller nicht signalisiert, den Zugriff freizugeben. Der Portal-Server muss so konfiguriert werden, dass er eine RADIUS Change of Authorisation (CoA)-Nachricht an den Controller sendet, um diesen anzuweisen, die MAC-Adresse des Benutzers von der Pre-Authentifizierungsrolle in die authentifizierte Gastrolle zu überführen.
Übungsfragen
Q1. Sie stellen ein Captive Portal in einer Einzelhandelskette bereit. Tests zeigen, dass Benutzer, die das Portal in Safari unter iOS öffnen, beim Auswählen des WeChat-Logins eine Fehlermeldung erhalten, während Benutzer, die das Portal über einen Link in einer WeChat-Nachricht öffnen, sich erfolgreich authentifizieren. Was ist die wahrscheinliche Ursache?
Hinweis: Berücksichtigen Sie den Unterschied zwischen dem WeChat-In-App-Browser und Standard-Mobilbrowsern.
Musterlösung anzeigen
Die implementierung stützt sich wahrscheinlich ausschließlich auf ein Service-Konto, das auf der Official Accounts Platform registriert ist, welche OAuth nur innerhalb des WeChat-In-App-Browsers unterstützt. Um Safari unter iOS zu unterstützen, müssen Sie auch eine Website-Anwendung auf der WeChat Open Platform registrieren und eine User-Agent-Erkennung implementieren, um Safari-Benutzer zum QR-Code-Ablauf weiterzuleiten.
Q2. Die Protokolle Ihres Portal-Servers zeigen häufige 40029 'invalid code'-Fehler, die während des Access-Token-Austauschs von der WeChat-API zurückgegeben werden. Welche Konfiguration sollten Sie zuerst überprüfen?
Hinweis: Denken Sie darüber nach, wie WeChat die Quelle der Authentifizierungsanfrage validiert.
Musterlösung anzeigen
Sie sollten die Konfiguration der redirect_uri überprüfen. WeChat validiert die Redirect-URI streng gegen die in der Entwicklerkonsole registrierte autorisierte Domain. Wenn das Portal eine andere Subdomain verwendet oder HTTPS nicht nutzt, lehnt WeChat den Code-Austausch ab.
Q3. Ein Veranstaltungsort-Betreiber möchte Besucherdaten erfassen, besteht jedoch auf einem völlig reibungslosen Login-Prozess. Er verlangt, dass Sie den WeChat-Login so konfigurieren, dass der Spitzname und die Stadt des Besuchers erfasst werden, ohne dass ein Zustimmungsfenster angezeigt wird. Wie reagieren Sie?
Hinweis: Überprüfen Sie die Funktionen der verschiedenen OAuth-Scopes.
Musterlösung anzeigen
Sie müssen dem Betreiber mitteilen, dass dies technisch unmöglich ist. Die Erfassung demografischer Daten wie Spitzname und Stadt erfordert den Scope snsapi_userinfo, der zwingend ein WeChat-Zustimmungsfenster auslöst. Um einen völlig reibungslosen Ablauf zu gewährleisten, müssen Sie snsapi_base verwenden, was geräuschlos funktioniert, aber nur die OpenID zurückgibt.
Weiterlesen in dieser Reihe
B2B Captive Portals gestalten: Erfassung von registrierten Namen und Unternehmensdaten
Dieser Leitfaden bietet IT-Managern und Betreibern von Veranstaltungsorten ein herstellerneutrales technisches Framework für das Design von B2B Captive Portals. Er beschreibt im Detail, wie Registrierungsfelder strukturiert werden sollten, um registrierte Namen und Unternehmensdaten zu erfassen, um hohe Ausfüllraten zu gewährleisten, während gleichzeitig die GDPR-Konformität gewahrt und Account-Level-Intelligence aufgebaut wird.
Captive Portal Architektur: Sicherheit, Umleitung und Best Practices
Ein definitives technisches Referenzdokument zur Captive Portal-Architektur in Unternehmen. Dieser Leitfaden beleuchtet Netzwerkisolierung, DNS-Umleitung, RADIUS-Authentifizierung und Sicherheitskonformität für IT-Entscheider, die sichere, datenreiche Gäste-WiFi-Netzwerke bereitstellen.
Optimierung von B2B Captive Portals: Erfassung von Firmennamen und professionellen Daten
Dieser Leitfaden erklärt, wie IT-Manager, Netzwerkarchitekten und Leiter des Standortbetriebs B2B Captive Portals konfigurieren können, um professionelle Daten – Firmennamen, Berufsbezeichnungen und geschäftliche E-Mail-Adressen – direkt beim WiFi-Login zu erfassen. Er deckt die gesamte technische Architektur ab, von der VLAN-Isolierung und RADIUS-Authentifizierung bis hin zur CRM-Integration mit Salesforce und HubSpot, inklusive integrierter GDPR- und CCPA-Konformität. Standorte, die dies richtig implementieren, verwandeln ihr Gäste-WiFi-Netzwerk in eine First-Party-Datenquelle und ein automatisiertes System zur Lead-Generierung.