小程序模板網(wǎng)

java開發(fā)者一行代碼搞定微信小程序用戶認(rèn)證

發(fā)布時間:2018-05-09 11:10 所屬欄目:小程序開發(fā)教程

微信小程序開發(fā)最基礎(chǔ)的功能就是用戶的認(rèn)證過程,在使用spring cloud微服務(wù)架構(gòu)進行開發(fā)時為了簡化開發(fā)周期,我們參考Wafer的架構(gòu),實現(xiàn)了java版本的會話服務(wù)器,由于目前wafer1官方已經(jīng)停止更新,Wafer2服務(wù)器端完全托管在騰訊云,不對外公開會話服務(wù)器的實現(xiàn),因此我們開發(fā)了wxss-spring-boot-starter項目,項目實現(xiàn)的會話服務(wù)器接口參考了Wafer2的小程序客戶端wafer2-client-sdk的代碼,目前與其完全兼容(僅登錄接口)。

 

 

使用方法

目前只支持Spring Boot 2.0以上版本。

在您的spring boot項目中引入本項目依賴,然后增加相應(yīng)功能注解和配置即可。

 

maven:


<dependency>
<groupId>com.venusource.ms.base</groupId>
<artifactId>wxss-spring-boot-starter</artifactId>
<version>1.0.0</version>
</dependency>

 

gradle:


compile('com.venusource.ms.base:wxss-spring-boot-starter:1.0.0')

 

會話服務(wù)器

實現(xiàn)參考php版本 wafer-session-server ,使用前請詳細閱讀。
在Spring Boot的入口類中加入@EnableWeChatSessionServer注解即可。如下所示:


package com.venusource.ms.base.wxssdemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import com.venusource.ms.base.wxss.EnableWeChatSessionServer;

@SpringBootApplication
@EnableWeChatSessionServer //啟用會話服務(wù)器
public class WxssSpringBootStarterDemoApplication {

public static void main(String[] args) {
SpringApplication.run(WxssSpringBootStarterDemoApplication.class, args);
}
}

 

在spring的配置文件application.properties中配置小程序的appid和secret,如下所示:


weixin.app.appid= yourappid
weixin.app.secret= yoursecret

 

啟動服務(wù)后,會自動在服務(wù)內(nèi)對外暴露/mina_auth 會話服務(wù)接口。

接口與php版本完全相同,見wafer-session-server。

注:會話服務(wù)會和微信的服務(wù)器進行通信,獲取session_key,需要能訪問外網(wǎng),同時為了安全性會話服務(wù)一般只對內(nèi)部服務(wù)提供服務(wù),不對外暴露接口,因此如果使用Spring Cloud的服務(wù)網(wǎng)關(guān),需要把它忽略。

 

Session數(shù)據(jù)的存儲

默認(rèn)情況下,所有的用戶數(shù)據(jù)存儲在內(nèi)存內(nèi)(不推薦),您需要實現(xiàn)如下接口來存儲自己的數(shù)據(jù):


package com.venusource.ms.base.wxss.service;

import com.venusource.ms.base.wxss.domain.CSessionInfo;

public interface SessionInfoStoreService {
CSessionInfo add(CSessionInfo sessionInfo);
void remove(CSessionInfo sessionInfo);
CSessionInfo update(CSessionInfo sessionInfo);
CSessionInfo get(String skey);
}

在實現(xiàn)類內(nèi)注解@Service即可,系統(tǒng)會自動替換session存儲類型。

 

登錄入口

登錄入口是為wafer2客戶端提供的用戶授權(quán)登錄地址,您可以自己基于上面的會話服務(wù)器單獨開發(fā),也可以在服務(wù)內(nèi)增加注解@EnableWeChatWaferLoginEndpoint,自動提供登錄入口/login,如下所示:


package com.venusource.ms.base.wxssdemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import com.venusource.ms.base.wxss.EnableWeChatWaferLoginEndpoint;


@SpringBootApplication
@EnableWeChatWaferLoginEndpoint //啟用wafer2登錄入口
public class WxssSpringBootStarterDemoApplication {

public static void main(String[] args) {
SpringApplication.run(WxssSpringBootStarterDemoApplication.class, args);
}
}

 

在spring的配置文件application.properties中配置會話服務(wù)器地址,如下所示:


weixin.wafer.authServerUrl = http://ms-session-server/mina_auth/

 

ms-session-server為在Eureka中注冊的服務(wù)名,因為我們使用ribbon作客戶端負載,可以部署多個ms-session-server服務(wù)。

 

業(yè)務(wù)服務(wù)用戶信息

基于Spring Cloud微服務(wù)架構(gòu)開發(fā)時,業(yè)務(wù)服務(wù)需要獲取用戶信息時,starter可提供自動的參數(shù)注入功能,只需要在業(yè)務(wù)服務(wù)內(nèi)增加注解@EnableWeChatUserInfoArgumentInjection即可,如下所示:


package com.venusource.app.oa.microserviceprovideruser;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

import com.venusource.ms.base.wxss.EnableWeChatUserInfoArgumentInjection;

@SpringBootApplication
@EnableDiscoveryClient
@EnableWeChatUserInfoArgumentInjection //啟用微信用戶信息注入。
public class MicroserviceProviderUserApplication {

public static void main(String[] args) {
SpringApplication.run(MicroserviceProviderUserApplication.class, args);
}
}

 

在spring的配置文件application.properties中配置會話服務(wù)器地址,如下所示:


weixin.wafer.authServerUrl = http://ms-session-server/mina_auth/

 

ms-session-server為在Eureka中注冊的服務(wù)名,因為我們使用ribbon作客戶端負載,可以部署多個ms-session-server服務(wù)。

 

在controller的方法參數(shù)中,會自動注入UserInfo類,可以直接獲取登錄用戶的信息,如下所示:


@GetMapping("/product/{id}")
public Product showInfo(@PathParam Long id, UserInfo userInfo) {
String uid = userInfo.getOpenId();
...
}

項目目前代碼還很丑陋,測試還不全面,如您在使用中發(fā)現(xiàn)問題,請及時告訴我們,或直接pull request。

 



易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://22321a.com/wxmini/doc/course/24358.html 復(fù)制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點擊咨詢
QQ在線咨詢