您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)如何在springboot中對接第三方微信授權(quán),文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
1.流程圖
講一下:微信授權(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è)小白的話,請告訴他這個(gè)點(diǎn)。如果是個(gè)大佬的話 估計(jì)也不用你告訴了,我上面說的那么多廢話,根本不關(guān)咱們java什么事情?。?/strong>
別生氣,我上面說的全都需要注意的。如果你耐心的看到了這里,那么你的幸福就來臨了。下面說的才是咱們java的發(fā)送請求啥的。
第一步:咱們先封裝一個(gè)get請求(你直接封一個(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è)置通用的請求屬性 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請求出現(xiàn)異常!" + e); e.printStackTrace(); } // 使用finally塊來關(guān)閉輸入流 finally { try { if (in != null) { in.close(); } } catch (Exception e2) { e2.printStackTrace(); } } return result; }
第二步:就到了咱們發(fā)送請求的時(shí)候了
需要的參數(shù)
1)code(前端給你傳過來)
2)appId 去微信公眾號(hào)里去看去
3)secret 同上 微信公眾平臺(tái)
夠詳細(xì)吧,這都告訴你了。想查看secret只能重置除非你能想起來之前設(shè)置的是什么?。?/p>
這個(gè)是咱們發(fā)送請求需要的所有參數(shù)
來,咱們看代碼
@Override public String WeChatAuthorization(String jsCode) { try { String url = "https://api.weixin.qq.com/sns/oauth3/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; }
上述就是小編為大家分享的如何在springboot中對接第三方微信授權(quán)了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。