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 相关文章推荐
Javascript 实现TreeView CheckBox全选效果
Jan 11 Javascript
40款非常有用的 jQuery 插件推荐(系列一)
Dec 21 Javascript
js获得指定控件输入光标的坐标兼容IE,Chrome,火狐等多种主流浏览器
May 21 Javascript
使用jQuery解决IE与FireFox下createElement方法的差异
Nov 14 Javascript
学习JavaScript设计模式之状态模式
Jan 08 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
May 17 Javascript
使用Angular.js开发的注意事项
Oct 19 Javascript
Bootstrap CSS布局之列表
Dec 15 Javascript
基于jQuery实现咖啡订单管理简单应用
Feb 10 Javascript
详解vue表单验证组件 v-verify-plugin
Apr 19 Javascript
浅析vue中常见循环遍历指令的使用 v-for
Apr 18 Javascript
基于Vue+Webpack拆分路由文件实现管理
Nov 16 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
浅析PHP水印技术
2007/02/14 PHP
PHP EOT定界符的使用详解
2008/09/30 PHP
Codeigniter实现多文件上传并创建多个缩略图
2014/06/12 PHP
yii实现级联下拉菜单的方法
2014/07/31 PHP
Thinkphp搜索时首页分页和搜索页保持条件分页的方法
2014/12/05 PHP
最常用的12种设计模式小结
2011/08/09 Javascript
一个页面放2段图片滚动代码出现冲突的问题如何解决
2012/12/21 Javascript
基于jQuery实现拖拽图标到回收站并删除功能
2015/11/25 Javascript
JavaScript代码里的判断小结
2016/08/22 Javascript
一个极为简单的requirejs实现方法
2016/10/20 Javascript
JavaScript中捕获/阻止捕获、冒泡/阻止冒泡方法
2016/12/07 Javascript
angularjs ocLazyLoad分步加载js文件实例
2017/01/17 Javascript
jQuery中Chosen三级联动功能实例代码
2017/03/07 Javascript
vue项目持久化存储数据的实现代码
2018/10/01 Javascript
对angularjs框架下controller间的传值方法详解
2018/10/08 Javascript
详解js模板引擎art template数组渲染的方法
2018/10/09 Javascript
nodejs 使用nodejs-websocket模块实现点对点实时通讯
2018/11/28 NodeJs
微信小程序实现身份证取景框拍摄
2020/09/09 Javascript
微信小程序实现下拉加载更多商品
2020/12/29 Javascript
详解Python中expandtabs()方法的使用
2015/05/18 Python
pyinstaller打包单个exe后无法执行错误的解决方法
2019/06/21 Python
python使用QQ邮箱实现自动发送邮件
2020/06/22 Python
selenium与xpath之获取指定位置的元素的实现
2021/01/26 Python
CSS3使用transition属性实现过渡效果
2018/04/18 HTML / CSS
阿拉伯世界最大的电子商务网站:Souq沙特阿拉伯
2016/10/28 全球购物
美国社交购物市场:MassGenie
2019/02/18 全球购物
澳大利亚礼品卡商店:Gift Card Store
2019/06/24 全球购物
《母鸡》教学反思
2014/02/25 职场文书
个人委托书格式
2014/04/04 职场文书
梅花魂教学反思
2014/04/25 职场文书
应聘教师自荐书
2014/06/16 职场文书
农林经济管理专业自荐信
2014/09/01 职场文书
2014年行政部工作总结
2014/11/19 职场文书
2019班干部竞选演讲稿范本!
2019/07/08 职场文书
如何利用map实现Nginx允许多个域名跨域
2021/03/31 Servers
Python实现简繁体转换
2021/06/07 Python