欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot中獲取微信用戶信息的方法

 更新時(shí)間:2019年09月17日 11:24:19   作者:桌前明月  
這篇文章主要介紹了SpringBoot中獲取微信用戶信息的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

不知道你是否參加過拼多多上邀請微信好友砍價(jià)功能,這個(gè)功能實(shí)現(xiàn)首先需要考慮的就是獲取微信用戶的信息。獲取用戶信息就是獲取公眾號下微信用戶的信息,今天我就來講講如何從公眾號下獲取微信用戶信息。

需要聲明一點(diǎn)的是獲取微信公眾號下的用戶信息的權(quán)限是服務(wù)號才有,個(gè)人訂閱號是沒有該權(quán)限的。

獲取公眾號用戶信息實(shí)戰(zhàn)

第一步需要先申請接口測試號并進(jìn)行網(wǎng)頁授權(quán)設(shè)置

訪問如下鏈接進(jìn)行接口測試號申請。

https://developers.weixin.qq.com/doc/offiaccount/Basic_Information/Requesting_an_API_Test_Account.html

選擇接口測試號申請,如下圖所示:


點(diǎn)擊登錄進(jìn)行掃碼登錄,如下圖所示:


登錄后如下圖所示:


在下面的的網(wǎng)頁賬號一欄添加網(wǎng)頁授權(quán)的IP或者域名。

為了方便測試我這里設(shè)置成了回環(huán)地址,最好設(shè)置成具體的 IP 地址或者域名信息。域名和 IP 地址不要添加http或者h(yuǎn)ttps。這里 IP 和域名可以是內(nèi)網(wǎng)地址。

到這里網(wǎng)頁授權(quán)設(shè)置完畢!

第二步是下載微信web開發(fā)者工具,可以在PC 進(jìn)行測試。

https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Web_Developer_Tools.html


傻瓜式一步一步安裝即可。

第三步 看微信操作教程并完成代碼實(shí)現(xiàn)

接下來就是代碼部分編寫了,在開發(fā)前首先需要看一下獲取微信公眾號用戶信息的教程:
通過訪問:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html。獲取微信用戶信息具體操作有如下4步。


第一步:用戶同意授權(quán),獲取code

代碼的操作就是拼接引導(dǎo)用戶進(jìn)行微信授權(quán)地址,然后重定向到微信服務(wù),微信服務(wù)在根據(jù)重定向的 URL 地址并攜帶 code 重定向到我們的服務(wù)器。這一步需要配置有公眾號 appid 和 redirect_uri 。

需要注意的是重定向的地址需要 encode 以下,具體操作如下面代碼所示:

String url = URLEncoder.encode(request.getRequestURL().toString());

具體地址如下圖所示:紅色框位置需要改為我們公眾號 appid 和 redirect_uri 信息,其他的內(nèi)容不用改動。


程序重定向該地址后會讓用戶進(jìn)行授權(quán),如下圖所示:


用戶點(diǎn)擊同意后,微信服務(wù)會根據(jù)重定向地址重定向回我們的服務(wù)中并攜帶code。

第二步就是根據(jù) code 獲取網(wǎng)頁授權(quán) access_token 和 openid。

調(diào)用如下面所示微信 API ,紅色框 code 替換成獲取的 code,其他內(nèi)容不用做任何改動。


第三步:刷新access_token(如果需要)

access_token有效期是7200s,當(dāng)access_token超時(shí)后,可以使用refresh_token進(jìn)行刷新,refresh_token有效期為30天,當(dāng)refresh_token失效之后,需要用戶重新授權(quán)。這步可做可不做,我們這里就繞開這步。

第四步:拉取用戶信息(需scope為 snsapi_userinfo)

關(guān)于網(wǎng)頁授權(quán)的兩種scope的區(qū)別說明

1、以snsapi_base為scope發(fā)起的網(wǎng)頁授權(quán),是用來獲取進(jìn)入頁面的用戶的openid的,并且是靜默授權(quán)并自動跳轉(zhuǎn)到回調(diào)頁的。用戶感知的就是直接進(jìn)入了回調(diào)頁(往往是業(yè)務(wù)頁面)

2、以snsapi_userinfo為scope發(fā)起的網(wǎng)頁授權(quán),是用來獲取用戶的基本信息的。但這種授權(quán)需要用戶手動同意,并且由于用戶同意過,所以無須關(guān)注,就可在授權(quán)后獲取該用戶的基本信息。

根據(jù)第二步獲取的 access_token 和 opendId 獲取微信用戶的信息。調(diào)用如下圖所示微信 API,將獲取的 access_token 和 opendId 替換如下圖中紅色框位置內(nèi)容,其他不用做任何改動。返回的 json 信息就是該公眾好號的用戶信息。

講完操作流程,接下來就是代碼實(shí)現(xiàn)。具體獲取微信用戶信息 Controller 內(nèi)容如下:

@RestController
@RequestMapping("/weixin")
public class WeiXinDemoController {
  @Autowired
  private WeiXinService weiXinService;

  @RequestMapping("/getWeiXinUserInfo")
  public String getWeiXinUserInfo(String code,HttpServletRequest request,HttpServletResponse response,HttpSession session) throws IOException{
    //第一步:用戶同意授權(quán),獲取code
    if (code == null) {
      String url = URLEncoder.encode(request.getRequestURL().toString());
      String authorizeUrl = weiXinService.buildAuthorizeURL(url);
      response.sendRedirect(authorizeUrl);
      return null;
    }
    //第二步:通過code換取網(wǎng)頁授權(quán)access_token和openid
    String htmlInfo = "";
    Map<String, Object> openIdInfo = weiXinService.getOpenIdInfo(code);
    String errcode = (String)openIdInfo.get("errcode");
    if(StringUtils.isEmpty(errcode)){
      //第四步:拉取用戶信息(需scope為 snsapi_userinfo)根據(jù)access_token和OpenId
      Map<String, Object> weiXinUserInfo = weiXinService.getWeiXinUserInfo(openIdInfo);
      String userInfohtml = createUserInfoHtml(weiXinUserInfo);
      return userInfohtml;
    }
    return htmlInfo;
  }
@Component
@ConfigurationProperties(prefix="wx")
public class WeiXinConfig {
  
  private String appID;
  private String mchID;
  private String appsecret;
  private String key;
  
  //省略getter and setter
}

application.properties 配置內(nèi)容如下:

微信核心處理都在 WeiXinService中,微信接口調(diào)用時(shí)通過 RestTemplate來實(shí)現(xiàn)的。

拼接引導(dǎo)用戶進(jìn)行微信授權(quán)地址代碼如下:

  /**
   * 拼接用戶授權(quán)重定向的URL
   * @param url
   * @return
   */
  public String buildAuthorizeURL(String url){
    
    return concatAuthorizeURL(url);
  }
    private String concatAuthorizeURL(String url) {
    StringBuilder authorizeUrl = new StringBuilder(AUTHORIZEURL);
    authorizeUrl.append("?appid=").append(weiXinConfig.getAppID());
    authorizeUrl.append("&redirect_uri=").append(url);
    authorizeUrl.append("&response_type=code");
     //snsapi_base (不彈出授權(quán)頁面,直接跳轉(zhuǎn),只能獲取用戶openid),
     //snsapi_userinfo (彈出授權(quán)頁面,可通過openid拿到昵稱、性別、所在地。并且, 即使在未關(guān)注的情況下,只要用戶授權(quán),也能獲取其信息 )
    authorizeUrl.append("&scope=snsapi_userinfo");
    authorizeUrl.append("&state=").append("STATE");
    authorizeUrl.append("#wechat_redirect");
    return authorizeUrl.toString();
  }

根據(jù) code 獲取網(wǎng)頁授權(quán) access_token 和 openid 代碼如下:

  /**
   * 獲取 access_token 和 openid
   * @param code
   * @return
   */
  public Map<String,Object> getOpenIdInfo(String code){
    
    String getAccessTokenUrl = concatGetOpenIdInfoURL(code);
    String json = postRequestForWechat(getAccessTokenUrl);
    Map<String,Object> map = jsonToMap(json);
    
    return map;
  }
  private String concatGetOpenIdInfoURL(String code) {
    StringBuilder getAccessTokenUrl = new StringBuilder(GE_TACCESSTOKEN_URL);
    getAccessTokenUrl.append("?appid=").append(weiXinConfig.getAppID());
    getAccessTokenUrl.append("&secret=").append(weiXinConfig.getAppsecret());
    getAccessTokenUrl.append("&code=").append(code);
    getAccessTokenUrl.append("&grant_type=authorization_code");
    return getAccessTokenUrl.toString();
  }
  private String postRequestForWechat(String getAccessTokenUrl) {
    ResponseEntity<String> postForEntity = restTemplate.postForEntity(getAccessTokenUrl, null, String.class);
    String json = postForEntity.getBody();
    return json;
  }
    private Map jsonToMap(String json) {
    Gson gons = new Gson();
    Map map = gons.fromJson(json, new TypeToken<Map>(){}.getType());
    return map;
  }

通過 access_token 和 openid 獲取微信用戶信息 代碼如下:

  /**
   * 獲取微信用戶信息通過 access_token 和 openid
   * @param map
   * @return
   */
  public Map getWeiXinUserInfo(Map<String, Object> map) {
    
    String getUserInfoUrl = concatGetWeiXinUserInfoURL(map);
    String json = getRequestForWechat(getUserInfoUrl);
    Map userInfoMap = jsonToMap(json);
    
    return userInfoMap;
  }
    private String concatGetWeiXinUserInfoURL(Map<String, Object> map) {
    String openId = (String) map.get("openid");
    String access_token = (String) map.get("access_token");
    // 繞過檢驗(yàn)授權(quán)憑證(access_token)是否有效
    StringBuilder getUserInfoUrl = new StringBuilder(GE_USERINFO_URL);
    getUserInfoUrl.append("?access_token=").append(access_token);
    getUserInfoUrl.append("&openId=").append(openId);
    getUserInfoUrl.append("&lang=zh_CN");
    
    return getUserInfoUrl.toString();
  }
  private String getRequestForWechat(String getUserInfoUrl) {
    ResponseEntity<String> postForEntity = restTemplate.getForEntity(getUserInfoUrl.toString(), String.class);
    String json = postForEntity.getBody();
    return json;
  }

測試

下載微信web開發(fā)者工具完成后,根據(jù)傻瓜式安裝即可。安裝完成后打開web開發(fā)者工具,如下圖所示選擇公眾號網(wǎng)頁。


輸入 http:127.0.1:8090/sbe2/weixin/getWeiXinUserInfo,就會看到該測試公眾號的用戶信息。


一般情況下我們通過接口測試號配置成測試環(huán)境域名或 IP,測試通過后就可以在服務(wù)號上配置網(wǎng)頁授權(quán)域名,順便在把我們項(xiàng)目配置的 appid 換成服務(wù)號的 appid 即可。具體操作如下:

小結(jié)

獲取微信公眾號用戶信息步驟就是:第一步拼接引導(dǎo)用戶授權(quán)的地址然后根據(jù)該地址重定向到微信服務(wù),第二步獲取授權(quán)code,根據(jù) code 獲取 access_token 和 OpenId,第三步根據(jù) access_token 和 OpenId 獲取微信用戶信息。

我這里介紹最簡三步,正常來講還需要驗(yàn)證access_token 是否有效,這一步也可以通過緩存access_token到Reid中并設(shè)置過期時(shí)間,當(dāng)其失效后刷新access_token。

在這里再三強(qiáng)調(diào)一下,微信提供操作文檔一定要多看幾篇,因?yàn)楹芏嗉?xì)節(jié)都在文檔中進(jìn)行了說明。當(dāng)你把微信提供操作文檔看透,你就會覺得其實(shí)就是個(gè)API 調(diào)用而已。

代碼示例

具體代碼示例請查看我的GitHub 倉庫 springbootexamples 中的 spring-boot-2.x-weixin 查看。

GitHub:https://github.com/zhuoqianmingyue/springbootexamples

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot服務(wù)端數(shù)據(jù)校驗(yàn)過程詳解

    SpringBoot服務(wù)端數(shù)據(jù)校驗(yàn)過程詳解

    這篇文章主要介紹了SpringBoot服務(wù)端數(shù)據(jù)校驗(yàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 詳解Springboot對多線程的支持

    詳解Springboot對多線程的支持

    Spring是通過任務(wù)執(zhí)行器(TaskExecutor)來實(shí)現(xiàn)多線程和并發(fā)編程,使用ThreadPoolTaskExecutor來創(chuàng)建一個(gè)基于線城池的TaskExecutor。這篇文章給大家介紹Springboot對多線程的支持,感興趣的朋友一起看看吧
    2018-07-07
  • Spring Cloud Config工作原理概述

    Spring Cloud Config工作原理概述

    Spring Cloud Config 是 Spring Cloud 生態(tài)系統(tǒng)的一部分,它提供了一種集中化管理應(yīng)用配置的方法,本文給大家介紹Spring Cloud Config工作原理概述,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • 使用@NonNull注解遇到的小問題及解決

    使用@NonNull注解遇到的小問題及解決

    這篇文章主要介紹了使用@NonNull注解遇到的小問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Java分批將List數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫的解決過程

    Java分批將List數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫的解決過程

    這篇文章主要給大家介紹了關(guān)于Java分批將List數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫的解決過程,文中通過代碼示例介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-08-08
  • 全面解析Java支持的數(shù)據(jù)類型及Java的常量和變量類型

    全面解析Java支持的數(shù)據(jù)類型及Java的常量和變量類型

    這篇文章主要介紹了Java支持的數(shù)據(jù)類型及Java的常量和變量類型,是Java入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2016-02-02
  • Java線程中斷interrupt的常用方法

    Java線程中斷interrupt的常用方法

    本文主要介紹了Java線程中斷interrupt的常用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • SpringCloud使用feign調(diào)用錯(cuò)誤的問題

    SpringCloud使用feign調(diào)用錯(cuò)誤的問題

    這篇文章主要介紹了SpringCloud使用feign調(diào)用錯(cuò)誤的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Java中session存儲Users對象實(shí)現(xiàn)記住密碼

    Java中session存儲Users對象實(shí)現(xiàn)記住密碼

    這篇文章主要介紹了Java中session存儲Users對象實(shí)現(xiàn)記住密碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Java+Redis撤銷重做功能實(shí)現(xiàn)

    Java+Redis撤銷重做功能實(shí)現(xiàn)

    這篇文章主要介紹了Java+Redis實(shí)現(xiàn)撤銷重做功能,需要考慮撤銷的最大步數(shù),撤銷之后穿插著其他操作則不能再重做,所以引入分布式鎖Redisson進(jìn)行加鎖處理,防止對圖表的操作有并發(fā)請求導(dǎo)致處理撤銷邏輯混亂,感興趣的朋友跟隨小編一起看看吧
    2023-05-05

最新評論