真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

SpringBoot中怎樣獲取微信用戶信息

這篇文章將為大家詳細(xì)講解有關(guān)SpringBoot中怎樣獲取微信用戶信息,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

成都創(chuàng)新互聯(lián)成立與2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元薛城做網(wǎng)站,已為上家服務(wù),為薛城各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108

獲取公眾號用戶信息實(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 openIdInfo = weiXinService.getOpenIdInfo(code);    String errcode = (String)openIdInfo.get("errcode");    if(StringUtils.isEmpty(errcode)){      //第四步:拉取用戶信息(需scope為 snsapi_userinfo)根據(jù)access_token和OpenId      Map 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 getOpenIdInfo(String code){        String getAccessTokenUrl = concatGetOpenIdInfoURL(code);    String json = postRequestForWechat(getAccessTokenUrl);    Map 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 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(){}.getType());    return map;  }

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

/**   * 獲取微信用戶信息通過 access_token 和 openid   * @param map   * @return   */  public Map getWeiXinUserInfo(Map map) {        String getUserInfoUrl = concatGetWeiXinUserInfoURL(map);    String json = getRequestForWechat(getUserInfoUrl);    Map userInfoMap = jsonToMap(json);        return userInfoMap;  }    private String concatGetWeiXinUserInfoURL(Map 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 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。

關(guān)于SpringBoot中怎樣獲取微信用戶信息就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


本文題目:SpringBoot中怎樣獲取微信用戶信息
本文路徑:http://weahome.cn/article/gecdjs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部