小程序之~~登录后台代码

微信小程序开发,弄清楚微信这个接口那些参数必须要有,并且各式正确,就能很快掌握。无非就是正确传参数、调用接口、网络访问 

其一,在小程序中可以使用wx.getUserInfo这个接口获取当前打开小程序用户的信息。但是,我们知道小程序就只是前端而已,它的大小最大也就几M而已,
所以在小程序中就仅有一些处理前端展示的逻辑代码,大部分数据交互都是与我们的第三方服务器,它的所有数据都要来源于第三方的服务器,为什么要叫第三方,
我的认为是第二方也就是微信的服务器,也就是小程序所在的微信的服务器。 所以要做小程序,我们就必须把客户的信息存储在我们自己的服务器上,这个时候也就引入正文。
其二,小程序与我们第三方服务器交互,也就是我们需要编写接口,实现小程序的登录,保存用户的信息,在我们的数据库中。
(1)微信小程序调用微信接口wx.login,这时候微信会通过这个接口在success方法中返回参数code,我们学要这个参数去微信服务器换取这个用户的唯一标识openid。
(2)然后在success中发起网络请求,将code发送到我们编写的接口中。
wx.login({ success: function (res) { if (res.code) { //发起网络请求 wx.request({ url:'https://www.zhishidai.net/zsd/zsd/fff/login', data: { code: res.code }, success: function (a) { console.log("获取用户openid") console.log(a.data.obj.openid) that.globalData.openid = a.data.obj.openid } }) } else { console.log('获取用户登录态失败!' + res.errMsg) } } });
(3)接口代码编写,根据传入得code,去微信服务器换取openid
@RequiresUser(required = false)
    @RequestMapping("/login")
    @ResponseBody
    public Result getCode(HttpServletRequest request, HttpSession session){
        //获取用户登录传过来的code String code=request.getParameter("code"); System.out.println("code:"+code); PreCode pre= preCodeManager.findCode();//获取第三方接口调用凭据 System.out.println("第三方接口调用凭据实体:"+pre); String grant_type="authorization_code";//固定值 //使用登录凭证 code 获取 session_key 和 openid。 Map<String,String> map=new HashMap<String,String>(); map.put("appid", appid);//小程序的appid map.put("component_appid",WeChatContants.AppId);//第三方appid map.put("js_code",code);//传入得用户code map.put("grant_type",grant_type); map.put("component_access_token",pre.getComponentAccessToken()); System.out.println("获取openid的url参数map为:"+map); String result=""; try { result= HttpUtils.sendGet(WeChatContants.URL_WEIXIN_LOGIN_CODE,map); System.out.println("获取openid结果为:"+result); } catch (Exception e) { e.printStackTrace(); } //解析返回的json数据,获得OPPID Map<String,String> mps= JsonParse.getJsonStr(result); String openid=mps.get("openid"); String session_key=mps.get("session_key"); Result returnResult = null; if(openid!=null){ /*在此处添加自己的逻辑代码,将openid保存在数据库,或是,使用session_key去微信服务器换取用户头像、昵称等信息。我在这里并没有用到,因此我只保存了用户的openid*/ } return returnResult; }


转载于:https://www.cnblogs.com/Darkqueen/p/9597338.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值