您好,登錄后才能下訂單哦!
微信第三方登錄有兩種方式:掃碼登錄(微信開放平臺(tái))和公眾號(hào)登錄(微信公眾平臺(tái))
掃碼登錄可以用于PC等跨平臺(tái)應(yīng)用,而公眾平臺(tái)必須在微信app內(nèi)使用,且必須關(guān)注公眾號(hào).
下面以公眾平臺(tái)為例,介紹如何基于Spring Social實(shí)現(xiàn)微信用戶授權(quán)并獲取到用戶信息.(微信開放平臺(tái)類似)
第一步:到微信公眾平臺(tái)后臺(tái)注冊(cè)應(yīng)用并進(jìn)行相關(guān)設(shè)置
微信公眾平臺(tái)后臺(tái)地址: https://mp.weixin.qq.com/
也可以先注冊(cè)一個(gè)測(cè)試號(hào): https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login
用微信掃碼登錄后臺(tái)后可以看到如下頁(yè)面:
其中的"appID"和"appsecret"需要記錄下來,一會(huì)要用到.
滑到下方找到" 網(wǎng)頁(yè)授權(quán)獲取用戶基本信息 ",點(diǎn)擊" 修改 ",將自己測(cè)試服務(wù)器的域名或IP填上去:
修改頁(yè)面:
第二步:添加相關(guān)代碼
我們假設(shè)服務(wù)端是基于springboot。
1.增加spring-social-wechat依賴:
Maven:
<dependency> <groupId>com.ikasoa</groupId> <artifactId>spring-social-wechat</artifactId> <version>1.3.1</version> </dependency>
或者Gradle:
compile 'com.ikasoa:spring-social-wechat:1.3.1'
2.增加配置項(xiàng)目
application.yml:
spring: social: wechatmp: app-id: [appID] app-secret: [appsecret]
或者application.properties:
spring.social.wechatmp.app-id=[appID] spring.social.wechatmp.app-secret=[appsecret]
其中" appID "和" appsecret "可以從微信公眾平臺(tái)后臺(tái)得到.
3.修改Application.java
增加注解@EnableSocial,并引用自動(dòng)配置類(WechatMpAutoConfiguration.class):
Application.java
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.context.annotation.Import; import org.springframework.social.config.annotation.EnableSocial; import org.springframework.social.wechat.autoconfigurer.WechatMpAutoConfiguration; @SpringBootApplication @EnableSocial @Import(WechatMpAutoConfiguration.class) public class Application { public static void main(String[] args) throws Exception { SpringApplication.run(Application.class, args); } }
4.增加SignInAdapter并注冊(cè)ProviderSignInController
SignInAdapter用來處理微信授權(quán)成功后的相關(guān)操作,例如:
WechatSignInAdapter.java
import org.springframework.social.connect.Connection; import org.springframework.social.connect.ConnectionKey; import org.springframework.social.connect.web.SignInAdapter; import org.springframework.social.wechat.api.User; import org.springframework.social.wechat.api.Wechat; import org.springframework.stereotype.Component; import org.springframework.web.context.request.NativeWebRequest; @Component public class WechatSignInAdapter implements SignInAdapter { @Override public String signIn(String openId, Connection<?> connection, NativeWebRequest request) { ConnectionKey key = connection.getKey(); // 通過providerId判斷是否為微信公眾平臺(tái)授權(quán) if ("wechatmp".equalsIgnoreCase(key.getProviderId())) { // 通過微信openId獲取到用戶詳細(xì)信息 User user = ((Wechat)connection.getApi()).userOperations().getUserProfile(openId); // 微信用戶詳細(xì)信息,可以記錄到數(shù)據(jù)庫(kù).這里直接打印到后臺(tái) System.out.println(user); return “/success.htm”; // 返回登錄成功后跳轉(zhuǎn)的url } return “/error.htm”; } }
將WechatSignInAdapter注入到ProviderSignInController中:
...... @Bean public ProviderSignInController providerSignInController(ConnectionFactoryLocator connectionFactoryLocator, UsersConnectionRepository usersConnectionRepository, WechatSignInAdapter wechatSignInAdapter) { ((InMemoryUsersConnectionRepository) usersConnectionRepository).setConnectionSignUp((Connection<?> connection) -> connection.getKey().getProviderUserId()); return new ProviderSignInController(connectionFactoryLocator, usersConnectionRepository, wechatSignInAdapter); } ......
其中InMemoryUsersConnectionRepository是基于內(nèi)存存儲(chǔ)用戶信息的實(shí)現(xiàn)(UsersConnectionRepository),也是默認(rèn)的實(shí)現(xiàn).此外SpringSocial還提供了JDBC的實(shí)現(xiàn)可選.
第三步:啟動(dòng)并測(cè)試
在測(cè)試頁(yè)面里添加一個(gè)微信授權(quán)入口:
...... <form action="/signin/wechatmp" method="POST"> <button type="submit">微信授權(quán)登錄</button> </form> ......
啟動(dòng)springboot,在微信app中打開測(cè)試頁(yè)面點(diǎn)擊測(cè)試button.
測(cè)試頁(yè)面的域名必須與公眾平臺(tái)后臺(tái)" 網(wǎng)頁(yè)授權(quán)獲取用戶基本信息 "中設(shè)置的域名相同.
如果一切順利,服務(wù)端后臺(tái)就會(huì)打印該微信用戶的詳細(xì)信息:
頁(yè)面會(huì)跳轉(zhuǎn)到"/success.htm",也就是在WechatSignInAdapter.signIn中返回的地址.
注意,測(cè)試賬號(hào)需要先關(guān)注微信測(cè)試公眾號(hào)(測(cè)試號(hào)后臺(tái)掃二維碼可以關(guān)注),否則會(huì)報(bào)錯(cuò)"ErrorCode:10006".
微信登錄實(shí)現(xiàn)已全部完成.
關(guān)于 微信開放平臺(tái)登錄 (掃碼登錄)與此類似,需要在 微信開放平臺(tái) 后臺(tái)申請(qǐng)"appID"和"appsecret",并將上面例子中的" wechatmp "改為" wechat "即可.
完整的例子代碼:
spring-social-wechat-sample
關(guān)于Spring Social項(xiàng)目
spring-social
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。