Python版实现微信公众号扫码登陆


Posted in Javascript onMay 28, 2020

基于python 实现公众扫码登陆

前提 申请公众号服务,配置相关信息,并在相关平台进行配置,就这么多东西

Python版实现微信公众号扫码登陆

实现逻辑,使用临时临时二维码,带参数的二维码扫码登陆

流程,用户已经扫码关注,在登陆页面直接扫码登陆,

用户未关注,则需要点击关注后,直接登录,

我们使用带参数的场景值来区别是哪个用户进行扫码登陆

场景值用户可以自定义,但是必须是唯一的,我用的时间戳

我现在要做的功能,有账户绑定需求,并且是前后端分离的情况下,

流程1

当用户已经关注过,并且绑定账号,直接扫码登陆,
当用户已经关注过,未绑定,需要扫码后,跳转到绑定手机号页面,绑定后,进行登录,
当用户取消关注,相当于解绑,进行扫码后,重新到绑定页面,进行扫码登陆,当然也要,对绑定已经绑定过的手机号惊醒判断。

代码如下

接口1 带参数的场景值生成的二维码

def get_wxcode(request):
  """
  公众号扫码登陆
  获取带参数二维码

  参数:

    返回值:
       {
   "formError": {},
   "delta_time": 951,
   "errorCode": 0,
   "params": {
   "scene_id": "512"
   },
   "message": "",
   "data": {
   "url": "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQEi8TwAAAAAAAAAAS5odHRwOi8vd2VpeGluLnFxLmNvbS9xLzAyUFNnZ2RNRlU5Y1QxWkJqZDF1Y1QAAgTlmMReAwSAOgkA",
   "sceneid": "2500", # 唯一扫码场景值,用来判断哪个用户进行扫码登陆
   "type": "get"
   }
  }
  """
  try:
    scene_id = str(int((time.time())))
    access_token = get_access_token()
    if access_token:
      user_info_url = u'https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=' + access_token
      params = {
        'expire_seconds': 604800,
        'action_name': 'QR_STR_SCENE',
        'action_info': {"scene": {"scene_str": scene_id}},
      }
      params = json.dumps(params)
      userinfo = requests.post(user_info_url, data=params).json()
      ticket = userinfo['ticket']
      # except:
      #   raise FieldError("ticket", "ticket获取异常")
      data = {
        "type": 'get',
        'url': 'https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=' + ticket,
        'sceneid':scene_id
      }
      return data
    else:
      raise FieldError("微信", "微信公共号正在维护中,给你带来的不便,敬请原谅")
  except:
    raise FieldError("微信", "微信公共号正在维护中,给你带来的不便,敬请原谅")

接口返回有url 和sceneid URL直接就是一个二维码,前端可以直接拿来展示,sceneid 是返回前端,让前端进行保存,来进行判断用户是否扫码,因为 微信服务,目前不支持sessionid 的缓存,所以需要我们自行缓存,我使用的将场景值存入redis

2 前端展示出来二维后,用户开始扫码,点击关注后,微信服务就用户信息,回调给我们在微信公众填的服务器地址,如图片

Python版实现微信公众号扫码登陆

现在我们开始写回调地址的代码:

微信关注,类型是事件 来发送,具体类型看文档

1 先通过于微信通信验证,是get 请求

Python版实现微信公众号扫码登陆

获取用户信息是post 请求

event 属于关注事件

Python版实现微信公众号扫码登陆

Python版实现微信公众号扫码登陆

我们可以access_token 获取用户信息,将用户信息保存,并将 场景值 eventkey 存入Redis 我设置的过期时间为1个小时
致此微信回调结束,3接口2 ,开始判断用户是否进行扫码关注,我们需要前端给后端传一个场景值,我们通过从redis 的场景值来获取存入数据的用户信息,如果已经存入,则用户扫码成功,直接登录,用户的openid 是唯一的

如果用户信息,获取,则用户并没有进行扫码,这个获取状态的接口,需要一轮询的方式进行查看 可以5s 进行一次

def get_public_wx_status(request):
  '''
  参数
   scene_id 场景值   必传   判断是哪个用户 扫码
  轮询查看 公众号 是否扫码关注,扫码关注是否绑定手机号

  :param request:
  :return:
    {
   "formError": {},
   "delta_time": 713,
   "errorCode": 0,
   "params": {},
   "message": "",
   "data": {
   "focus_state": 1,  # 微信关注的状态 1 已扫码关注  0 未关注
   "state": 0  # 关注后,是否绑定手机号 0 未绑定 1 已绑定,直接登录
   }
  }
  '''


  post_info = request.POST
  scene_id = post_info.get("scene_id", '')
  if not scene_id:
    raise FieldError('scene_id','scene_id不能为空')
  openid = redis_conn.get(scene_id)
  if openid == None:
    return {'focus_state': 0}
  else:
    uid = redis_conn.get(str(openid))
    if uid == None:
      return {'focus_state':0}
    else:
      user = UserWxInfo.objects.get(openid=openid)
      if user.focus_state == 1:
        state = 1
        _ = User.objects.get(uid=user.uid)
        request.apisession["uid"] = user.uid
        request.apisession["pwd_updatetime"] = _.pwd_updatetime
        ip = ''
        if request.META.has_key('HTTP_X_FORWARD_FOR'):
          ip = request.META['HTTP_X_FORWARD_FOR']
        else:
          ip = request.META['REMOTE_ADDR']
        UserLoginLog(uid=user.uid, ip=ip).save()

      else:
        state = 0
      return {
        'focus_state':1,
        'state':state
      }

到此这篇关于Python版实现微信公众号扫码登陆的文章就介绍到这了,更多相关Python公众号扫码登陆内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js中设置元素class的三种方法小结
Aug 28 Javascript
基于Arcgis for javascript实现百度地图ABCD marker的效果
Sep 12 Javascript
jQuery制作图片旋转效果
Feb 02 Javascript
JS实现的tab切换选项卡效果示例
Feb 28 Javascript
JS实现unicode和UTF-8之间的互相转换互转
Jul 05 Javascript
深入理解Vue官方文档梳理之全局API
Nov 22 Javascript
JavaScript中的高级函数
Jan 04 Javascript
微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析
Aug 16 Javascript
vue 使用高德地图vue-amap组件过程解析
Sep 07 Javascript
jquery.tagsinput.js实现记录checkbox勾选的顺序
Sep 21 jQuery
vue element-ui el-date-picker限制选择时间为当天之前的代码
Nov 07 Javascript
JavaScript实现与web通信的方法详解
Aug 07 Javascript
基于aotu.js实现微信自动添加通讯录中的联系人功能
May 28 #Javascript
原生js实现五子棋游戏
May 28 #Javascript
Vue微信公众号网页分享的示例代码
May 28 #Javascript
纯JS实现五子棋游戏
May 28 #Javascript
js实现简单五子棋游戏
May 28 #Javascript
js实现双人五子棋小游戏
May 28 #Javascript
vue实现五子棋游戏
May 28 #Javascript
You might like
初学者入门:细述PHP4的核心Zend
2006/09/05 PHP
php猜单词游戏
2015/09/29 PHP
PHP使用SMTP邮件服务器发送邮件示例
2018/08/28 PHP
laravel5.6 框架操作数据 Eloquent ORM用法示例
2020/01/26 PHP
Array, Array Constructor, for in loop, typeof, instanceOf
2011/09/13 Javascript
了解jQuery技巧来提高你的代码(个人觉得那个jquery的手册很不错)
2012/02/10 Javascript
简约JS日历控件 实例代码
2013/07/12 Javascript
javascript简单实现滑动菜单效果的方法
2015/07/27 Javascript
微信小程序 开发工具快捷键整理
2016/10/31 Javascript
微信小程序 天气预报开发实例代码源码
2017/01/20 Javascript
angularjs 的数据绑定实现原理
2018/07/02 Javascript
纯javascript前端实现base64图片下载(兼容IE10+)
2018/09/14 Javascript
JavaScript的Proxy可以做哪些有意思的事儿
2019/06/15 Javascript
Vue实现将数据库中带html标签的内容输出(原始HTML(Raw HTML))
2019/10/28 Javascript
[48:02]Ti4循环赛第三日 VG vs Liquid和NEWBEE vs DK
2014/07/12 DOTA
开始着手第一个Django项目
2015/07/15 Python
python 容器总结整理
2017/04/04 Python
利用pandas合并多个excel的方法示例
2019/10/10 Python
Python内置加密模块用法解析
2019/11/25 Python
python不同系统中打开方法
2020/06/23 Python
matplotlib基础绘图命令之bar的使用方法
2020/08/13 Python
解决canvas转base64/jpeg时透明区域变成黑色背景的方法
2016/10/23 HTML / CSS
Avène雅漾美国官方网站:敏感肌肤护理专家
2016/10/24 全球购物
Luxplus瑞典:香水和美容护理折扣
2018/01/28 全球购物
Abbott Lyon官网:女士手表、珠宝及配件
2020/12/26 全球购物
普通大学毕业生自荐信
2013/11/04 职场文书
公司财务总监岗位职责
2013/12/14 职场文书
新闻专业个人求职信
2013/12/19 职场文书
消防安全管理制度
2014/02/01 职场文书
《三袋麦子》教学反思
2014/03/02 职场文书
毕业自我鉴定怎么写
2014/03/25 职场文书
党员弘扬焦裕禄精神思想汇报
2014/09/10 职场文书
三八妇女节标语
2014/10/09 职场文书
工程竣工验收申请报告
2015/05/15 职场文书
三八红旗手先进事迹材料(2016推荐版)
2016/02/25 职场文书
Java常用函数式接口总结
2021/06/29 Java/Android