微信小程序靜默登錄的實(shí)現(xiàn)代碼
1.通過 wx.login獲取 登錄憑證(code)
wx.login({ success: function (res) { console.log(res.code); } })
2.在此處獲得
appid 和 secret :https://developers.weixin.qq.com/sandbox
如圖
3.小程序端
http://127.0.0.1:8080/jeecg-boot 這一段是自己的訪問路徑
//app.js App({ globalData: { appid: '', appsecret: '',// openid: '' } onLaunch: function () { var that =this; // 登錄 wx.login({ success: function (res) { console.log(res.code) wx.request({ url: 'http://127.0.0.1:8080/jeecg-boot/hwork/hworkLog/GetOpenIdServlet', data: { appid: that.globalData.appid, secret: that.globalData.appsecret, js_code: res.code, grant_type: 'authorization_code' }, method: 'POST', header: { 'Content-Type': 'application/x-www-form-urlencoded' }, success: function (res) { console.log(res) //轉(zhuǎn)json var j= JSON.parse(res.data.result) //獲取到openid that.globalData.openid = j.openid; } }) } }) } })
4.后臺代碼
工具類
package org.jeecg.modules.hworkorder.util; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.HttpURLConnection; import java.net.URL; public class WeChatService { /** * 調(diào)用對方接口方法 * @param path 對方或第三方提供的路徑 * @param data 向?qū)Ψ交虻谌桨l(fā)送的數(shù)據(jù),大多數(shù)情況下給對方發(fā)送JSON數(shù)據(jù)讓對方解析 */ public static String interfaceUtil(String path,String data) { String openId=""; try { URL url = new URL(path); //打開和url之間的連接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); PrintWriter out = null; //請求方式 // conn.setRequestMethod("POST"); // //設(shè)置通用的請求屬性 conn.setRequestProperty("accept", "*/*"); conn.setRequestProperty("connection", "Keep-Alive"); conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"); //設(shè)置是否向httpUrlConnection輸出,設(shè)置是否從httpUrlConnection讀入,此外發(fā)送post請求必須設(shè)置這兩個 //最常用的Http請求無非是get和post,get請求可以獲取靜態(tài)頁面,也可以把參數(shù)放在URL字串后面,傳遞給servlet, //post與get的 不同之處在于post的參數(shù)不是放在URL字串里面,而是放在http請求的正文內(nèi)。 conn.setDoOutput(true); conn.setDoInput(true); //獲取URLConnection對象對應(yīng)的輸出流 out = new PrintWriter(conn.getOutputStream()); //發(fā)送請求參數(shù)即數(shù)據(jù) out.print(data); //緩沖數(shù)據(jù) out.flush(); //獲取URLConnection對象對應(yīng)的輸入流 InputStream is = conn.getInputStream(); //構(gòu)造一個字符流緩存 BufferedReader br = new BufferedReader(new InputStreamReader(is)); String str = ""; while ((str = br.readLine()) != null) { openId=str; System.out.println(str); } //關(guān)閉流 is.close(); //斷開連接,最好寫上,disconnect是在底層tcp socket鏈接空閑時才切斷。如果正在被其他線程使用就不切斷。 //固定多線程的話,如果不disconnect,鏈接會增多,直到收發(fā)不出信息。寫上disconnect后正常一些。 conn.disconnect(); System.out.println("完整結(jié)束"); } catch (Exception e) { e.printStackTrace(); } return openId; } public static String GetOpenID(String appid,String appsecret,String Code) { //臨時登錄憑證 String URL = "https://api.weixin.qq.com/sns/jscode2session?appid="+appid+"&secret="+appsecret+"&js_code="+Code+"&grant_type=authorization_code"; String openId=interfaceUtil(URL, ""); return openId; } }
@RestController @RequestMapping("/hwork/hworkLog") @Slf4j public class hworkLogContrller { @RequestMapping(value = "/GetOpenIdServlet", method = RequestMethod.POST) public Result<String> GetOpenIdServlet(HttpServletRequest request, HttpServletResponse response){ Result<String> result=new Result<String>(); response.setContentType("text/html;charset=utf-8"); /* 設(shè)置響應(yīng)頭允許ajax跨域訪問 */ response.setHeader("Access-Control-Allow-Origin", "*"); /* 星號表示所有的異域請求都可以接受, */ response.setHeader("Access-Control-Allow-Methods", "GET,POST"); //轉(zhuǎn)成json數(shù)據(jù) String appid=request.getParameter("appid"); String secret=request.getParameter("secret"); String js_code=request.getParameter("js_code"); if(appid!=null&&appid!=""&&secret!=null&&secret!=""&&js_code!=null&&js_code!=""){ WeChatService getOpenId=new WeChatService(); String openId=getOpenId.GetOpenID(appid,secret,js_code); result.setResult(openId); result.setMessage("后臺收到并返回"); }else{ result.setMessage("參數(shù)為空"); result.setSuccess(false); } return result; } }
到這里 就能得到openid了
總結(jié)
以上所述是小編給大家介紹的微信小程序靜默登入的實(shí)現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
上一篇:JavaScript復(fù)制變量三種方法實(shí)例詳解
欄 目:JavaScript
下一篇:微信小程序新聞網(wǎng)站詳情頁實(shí)例代碼
本文標(biāo)題:微信小程序靜默登錄的實(shí)現(xiàn)代碼
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9242.html
您可能感興趣的文章
- 04-02java吃豆人代碼 js吃豆人
- 04-02微信挑一挑java代碼 微信挑一挑java代碼怎么做
- 01-10小程序簡單兩欄瀑布流效果的實(shí)現(xiàn)
- 01-10微信小程序批量上傳圖片到七牛(推薦)
- 01-10微信小程序跨頁面數(shù)據(jù)傳遞事件響應(yīng)實(shí)現(xiàn)過程解析
- 01-10微信小程序按順序同步執(zhí)行的兩種方式
- 01-10ES6常用小技巧總結(jié)【去重、交換、合并、反轉(zhuǎn)、迭代、計算等】
- 01-10微信小程序?qū)崿F(xiàn)簽字功能
- 01-10JS實(shí)現(xiàn)關(guān)閉小廣告特效
- 01-10javascript實(shí)現(xiàn)點(diǎn)擊星星小游戲


閱讀排行
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報,JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?