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

springboot對(duì)接第三方微信授權(quán)及獲取用戶的頭像和昵稱等等

 更新時(shí)間:2021年01月26日 10:32:29   作者:^_^鐵  
這篇文章主要介紹了springboot對(duì)接第三方微信授權(quán)及獲取用戶的頭像和昵稱等等,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

大家好,我是小鐵,鐵鐵最近太忙了。一直再不停的敲啊敲。
今天來點(diǎn)第三方的干貨(微信授權(quán))
底下的這張圖是微信授權(quán)的流程圖。

1.流程圖

在這里插入圖片描述

2.發(fā)送請(qǐng)求

講一下:微信授權(quán)分為兩種,一種是靜默授權(quán),另一種是非靜默授權(quán)。具體的話可以看一下微信授權(quán)文檔微信官方文檔

在這里插入圖片描述

看著這么多的字,不光你煩,小鐵看著也是煩的很啊。
我大概的說一下,授權(quán)有兩種授權(quán)方式
1)靜默授權(quán),大概的意思就是說,你只能拿code換openid 剩下的都換不了(scope=snsapi_base)并且自動(dòng)跳轉(zhuǎn)到回調(diào)頁面(給用戶的感覺是直接跳轉(zhuǎn)到回調(diào)頁面)
2)非靜默授權(quán),大概意思就是說,你能拿code換openid和access_token等等一些信息啥的(scope=snsapi_userinfo)但是需要用戶點(diǎn)擊

總結(jié):只要openid你就靜默授權(quán),但是你還想獲取用戶的頭像啥的你就非靜默授權(quán)(官方也是墨跡,說了那么多廢話。。。。)

注意:這個(gè)是前端的事情,如果你們前端是一個(gè)小白的話,請(qǐng)告訴他這個(gè)點(diǎn)。如果是個(gè)大佬的話 估計(jì)也不用你告訴了,我上面說的那么多廢話,根本不關(guān)咱們java什么事情??!

3.Java授權(quán)

別生氣,我上面說的全都需要注意的。如果你耐心的看到了這里,那么你的幸福就來臨了。下面說的才是咱們java的發(fā)送請(qǐng)求啥的。

第一步:咱們先封裝一個(gè)get請(qǐng)求(你直接封一個(gè)工具類就行了,如果你有,就當(dāng)小鐵沒說)

public static String sendGet(String url, String param) {
    String result = "";
    BufferedReader in = null;
    try {
      String urlNameString = url + "?" + param;
      URL realUrl = new URL(urlNameString);
      // 打開和URL之間的連接
      URLConnection connection = realUrl.openConnection();
      // 設(shè)置通用的請(qǐng)求屬性
      connection.setRequestProperty("accept", "*/*");
      connection.setRequestProperty("connection", "Keep-Alive");
      connection.setRequestProperty("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
      // 建立實(shí)際的連接
      connection.connect();
      // 獲取所有響應(yīng)頭字段
      Map<String, List<String>> map = connection.getHeaderFields();
      // 遍歷所有的響應(yīng)頭字段
      for (String key : map.keySet()) {
        System.out.println(key + "--->" + map.get(key));
      }
      // 定義 BufferedReader輸入流來讀取URL的響應(yīng)
      in = new BufferedReader(new InputStreamReader(
          connection.getInputStream()));
      String line;
      while ((line = in.readLine()) != null) {
        result += line;
      }
    } catch (Exception e) {
      System.out.println("發(fā)送GET請(qǐng)求出現(xiàn)異常!" + e);
      e.printStackTrace();
    }
    // 使用finally塊來關(guān)閉輸入流
    finally {
      try {
        if (in != null) {
          in.close();
        }
      } catch (Exception e2) {
        e2.printStackTrace();
      }
    }
    return result;
  }

第二步:就到了咱們發(fā)送請(qǐng)求的時(shí)候了
需要的參數(shù)
1)code(前端給你傳過來)
2)appId 去微信公眾號(hào)里去看去
3)secret 同上 微信公眾平臺(tái)

在這里插入圖片描述

在這里插入圖片描述

夠詳細(xì)吧,這都告訴你了。想查看secret只能重置除非你能想起來之前設(shè)置的是什么??!

這個(gè)是咱們發(fā)送請(qǐng)求需要的所有參數(shù)

在這里插入圖片描述

來,咱們看代碼

 @Override
  public String WeChatAuthorization(String jsCode) {
   try {
     String url = "https://api.weixin.qq.com/sns/oauth2/access_token";
     String appid = WxConstant.appId; //appid
     String secret = WxConstant.secret; //secret
     String grant_type = "authorization_code";
     String param = "appid="+appid+"&secret="+secret+"&code="+jsCode+"&grant_type="+grant_type;
     String sr = WxUtil.sendGet(url,param);
     JSONObject json = new JSONObject(sr);
     String openid = (String) json.get("openid");
     String accessToken = (String) json.get("access_token");
     return openid;
  }catch(Exception e){
  	e.printStackTrace();
  }
  return null;
 }

我刪除了好多(怕你們看不明白),這個(gè)就是獲取openid和accessToken 但是我只返回了openid。(直接粘過去,改吧改吧就能用了)。

來,咱們繼續(xù)看。拿到accessToken和openid了 咱們還要拿到用戶的頭像和昵稱
來咱們繼續(xù)看微信文檔

在這里插入圖片描述

這些事需要的參數(shù),access_token 和 openid 是咱們剛才授權(quán)獲取到的參數(shù),lang的話就用zh_CN就可以

@Override
  public Map WeChatUserInfo(String accessToken, String openid) {
    try {
      String url = "https://api.weixin.qq.com/sns/userinfo";
      String param = "access_token="+accessToken+"&openid="+openid+"&lang=zh_CN";
      String sr = WxUtil.sendGet(url,param);
      JSONObject json = new JSONObject(sr);
      Map<String,String> map = new HashedMap();
      String headimgurl = (String)json.get("headimgurl");
      String nickName = (String)json.get("nickname");
      map.put("headimgurl",headimgurl);
      map.put("nickName",nickName);
      return map;
    } catch (JSONException e) {
      e.printStackTrace();
    }
    return null;
  }

到此這篇關(guān)于springboot對(duì)接第三方微信授權(quán)及獲取用戶的頭像和昵稱等等的文章就介紹到這了,更多相關(guān)springboot第三方微信授權(quán)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法

    IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法

    這篇文章主要介紹了IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法,本文分步驟給大家介紹兩種方式講解如何調(diào)試出窗口,需要的朋友可以參考下
    2023-04-04
  • Java下Struts框架中的ActionForm類詳解

    Java下Struts框架中的ActionForm類詳解

    這篇文章主要介紹了Java下Struts框架中的ActionForm類詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Java實(shí)現(xiàn)時(shí)間片輪轉(zhuǎn)調(diào)度算法的示例代碼

    Java實(shí)現(xiàn)時(shí)間片輪轉(zhuǎn)調(diào)度算法的示例代碼

    時(shí)間片輪轉(zhuǎn)調(diào)度是一種最古老,最簡(jiǎn)單,最公平且使用最廣的算法,這篇文章主要為大家介紹了如何利用Java實(shí)現(xiàn)這一算法,需要的可以參考一下
    2023-07-07
  • hibernate通過session實(shí)現(xiàn)增刪改查操作實(shí)例解析

    hibernate通過session實(shí)現(xiàn)增刪改查操作實(shí)例解析

    這篇文章主要介紹了hibernate通過session實(shí)現(xiàn)增刪改查操作實(shí)例解析,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • Java面試題沖刺第二天--Redis篇

    Java面試題沖刺第二天--Redis篇

    這篇文章主要為大家分享了最有價(jià)值的三道java面試題,涵蓋內(nèi)容全面,包括數(shù)據(jù)結(jié)構(gòu)和算法相關(guān)的題目、經(jīng)典面試編程題等,感興趣的小伙伴們可以參考一下
    2021-07-07
  • SpringBoot實(shí)現(xiàn)設(shè)置動(dòng)態(tài)定時(shí)任務(wù)的方法詳解

    SpringBoot實(shí)現(xiàn)設(shè)置動(dòng)態(tài)定時(shí)任務(wù)的方法詳解

    這篇文章主要介紹了SpringBoot實(shí)現(xiàn)設(shè)置動(dòng)態(tài)定時(shí)任務(wù)的方法詳解,SpringBoot是一個(gè)快速開發(fā)的Java框架,而動(dòng)態(tài)定時(shí)任務(wù)是指可以在運(yùn)行時(shí)動(dòng)態(tài)添加、修改和刪除定時(shí)任務(wù)的功能,需要的朋友可以參考下
    2023-10-10
  • Java 設(shè)計(jì)模式原則之迪米特法則詳解

    Java 設(shè)計(jì)模式原則之迪米特法則詳解

    這篇文章主要介紹了Java 設(shè)計(jì)模式原則之迪米特法則詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 源碼解析帶你了解LinkedHashMap

    源碼解析帶你了解LinkedHashMap

    大多數(shù)情況下,只要不涉及線程安全問題,Map基本都可以使用HashMap,不過HashMap有一個(gè)問題,就是迭代HashMap的順序并不是HashMap放置的順序,也就是無序。HashMap的這一缺點(diǎn)往往會(huì)帶來困擾,所以LinkedHashMap就閃亮登場(chǎng)了,這篇文章通過源碼解析帶你了解LinkedHashMap
    2021-09-09
  • maven打包成第三方j(luò)ar包且把pom依賴包打入進(jìn)來的方法

    maven打包成第三方j(luò)ar包且把pom依賴包打入進(jìn)來的方法

    這篇文章主要介紹了maven打包成第三方j(luò)ar包且把pom依賴包打入進(jìn)來的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • MyBatis 中 ${}和 #{}的正確使用方法(千萬不要亂用)

    MyBatis 中 ${}和 #{}的正確使用方法(千萬不要亂用)

    這篇文章主要介紹了MyBatis 中 ${}和 #{}的正確使用方法,本文給大家提到了MyBatis 中 ${}和 #{}的區(qū)別,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07

最新評(píng)論