入境游旅游网站建设商家入驻型网站建设
入境游旅游网站建设,商家入驻型网站建设,电子商城网站建站客,怎么看网站pv1.登录页面#xff0c;显示二维码 当我们打开网页微信时#xff0c;会看到一个用于扫码登录的二维码#xff0c;所以我们要模拟该页面给我们的页面也弄一个二维码 通过查看网页代码我们发现#xff0c;这个二维码的标签为 这个src属性的最后一段每次访问都是不同的#xf…1.登录页面显示二维码 当我们打开网页微信时会看到一个用于扫码登录的二维码所以我们要模拟该页面给我们的页面也弄一个二维码 通过查看网页代码我们发现这个二维码的标签为 这个src属性的最后一段每次访问都是不同的我们发现每次访问该页面时会向后端发送请求获得这个随机字符串 这个请求的结果为 所以该请求获取的结果就是我们想要的随机字符串那么我们也可以向这个url发送请求获取随机字符串并利用随机字符串拼接地址获取二维码图片 from flask import Flask, request, render_template, session
import time
import requests
import re
app Flask(__name__)
app.debug True
app.secret_key ksjgsapp.route(/login, methods[GET, POST])
def login():if request.method GET:ctime str(int(time.time() * 1000)) # url最后的内容其实是时间戳经过处理的结果qcode_url https://login.wx.qq.com/jslogin?appidwx782c26e4c19acffbredirect_urihttps%3A%2F%2Fwx.qq.com%2Fcgi-bin%2Fmmwebwx-bin%2Fwebwxnewloginpagefunnewlangzh_CN_{}.format(ctime)ret requests.get(qcode_url)qcode re.findall(uuid (.*);, ret.text)[0]session[qcode] qcodereturn render_template(login.html, qcodeqcode)else:passif __name__ __main__:app.run() login页面 !DOCTYPE html
html langzh-CN
headmeta charsetUTF-8meta http-equivx-ua-compatible contentIEedgemeta nameviewport contentwidthdevice-width, initial-scale1title微信登录/title
/head
body
h1微信登录/h1
img srchttps://login.weixin.qq.com/qrcode/{{qcode}} alt
script src/static/jquery-3.2.1.min.js/script/body
/html 这样我们访问时就能看到二维码了 扫码后二维码变成用户头像 看到二维码后如果我们进行了扫码那么页面上的二维码会立刻变成用户的头像但是此时我们并没有看到页面向后端发送请求为什么后端能让前端的页面发生变化呢我们通过浏览器的network选项发现其实当页面加载完成后浏览器会不停的向后端的一个url发送 请求这个请求发送到后端后就被夯住了这个时间在25秒左右如果没有人扫码那么请求会结束浏览器继续发送如果有人扫码了那么后端会立刻向浏览器返回相关信息浏览器就可以将页面的二维码改变为用户的头像了这种持续发送请求的方式称为长轮询 我们在页面加载完成后也模拟这个长轮询 login页面 !DOCTYPE html
html langzh-CN
headmeta charsetUTF-8meta http-equivx-ua-compatible contentIEedgemeta nameviewport contentwidthdevice-width, initial-scale1title微信登录/title
/head
body
h1微信登录/h1
img srchttps://login.weixin.qq.com/qrcode/{{qcode}} alt
script src/static/jquery-3.2.1.min.js/script
script$(function () {check_login()});function check_login() {$.ajax({url: /check_login,type: GET,dataType: JSON,success:function (arg) {if (arg.code 201){$(img).attr(src, arg.src);check_login()} else if(arg.code 200){location.href /index}else{check_login()}}})}
/script
/body
/html 前端页面加载完成后就开始向后端发送ajax长轮询根据后端返回的内容判断是否继续发送轮询还是进行跳转如果有人扫码了那么就将扫码人的头像替换页面上的二维码并继续轮询直到扫码人点击确认则进行跳转没人扫码则一直进行长轮询 后端 from flask import Flask, request, render_template, session, jsonify
import time
import requests
import re
from bs4 import BeautifulSoupapp Flask(__name__)
app.debug True
app.secret_key ksjgsdef xml_parser(text):errorret0/retmessage/messageskeycrypt_ef73b06b_bd2d7a9918de33c9fc59b3b518a5314f/skeywxsid5gfJFQAjurnuD3t/wxsidwxuin2507632864/wxuinpass_ticketn3hBG1Aky%2FORERALnTUhkjRrAaho%2BX6vu8%2B9Z3gPrsmnWmKqs5a%2BFe%2FehjeweCeP/pass_ticketisgrayscale1/isgrayscale/error dic {}soup BeautifulSoup(text, html.parser)div soup.find(nameerror)for item in div.find_all(recursiveFalse):dic[item.name] item.textreturn dicapp.route(/login, methods[GET, POST])
def login():if request.method GET:ctime str(int(time.time() * 1000)) # url最后的内容其实是时间戳经过处理的结果qcode_url https://login.wx.qq.com/jslogin?appidwx782c26e4c19acffbredirect_urihttps%3A%2F%2Fwx.qq.com%2Fcgi-bin%2Fmmwebwx-bin%2Fwebwxnewloginpagefunnewlangzh_CN_{}.format(ctime)ret requests.get(qcode_url)qcode re.findall(uuid (.*);, ret.text)[0]session[qcode] qcodereturn render_template(login.html, qcodeqcode)else:passapp.route(/check_login)
def check_login():ctime str(int(time.time() * 1000))qcode session.get(qcode)check_url https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicontrueuuid{}tip0r-1052355888_{}.format(qcode, ctime)ret requests.get(check_url)response {code: 408} # 如果没人扫码则返回的code为408if code201 in ret.text: # 如果有人扫码了则会返回201并且会返回用户的头像的srcresponse[code] 201response[src] re.findall(userAvatar (.*);, ret.text)[0]elif code200 in ret.text: # 有人扫码后前端页面仍然会发送长轮询直到扫码的人点击确认登录会返回200redirect_uri re.findall(redirect_uri(.*);, ret.text)[0] # 此时会返回跳转地址# 向redirect_uri地址发送请求获取凭证相关信息redirect_uri redirect_uri funnewversionv2 # 这个跳转地址并不全我们需要自己补充ticket_ret requests.get(redirect_uri) # 向跳转地址发送请求获取登录凭证ticket_dict xml_parser(ticket_ret.text) # 这个登录凭证是一个xml的格式我们通过一个函数将他转换成字典session[ticket_dict] ticket_dict # 将登录凭证存入session方便后面使用response[code] 200return jsonify(response)app.route(/index)
def index():return 登录成功if __name__ __main__:app.run() 获取用户信息 当确认登录后会返回跳转地址浏览器会向这个跳转地址发送get请求获取一个凭证(类似于cookiexml格式)获取这个凭证后浏览器会接着发送一个post请求请求内容就是凭证内的相关内容这个post请求就能获取用户的信息最近联系人等信息 我们这里通过index函数来发送这个post请求 app.route(/index)
def index():用户数据的初始化https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxinit?r-1039465096langzh_CNpass_ticketq9TOX4RI4VmNiHXW9dUUl1oMzoQK2X2f3H3kn0VYm5YGNwUMO2THYMznv8DSXqp0:return:ticket_dict session.get(ticket_dict)init_url https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxinit?r-1039465096langzh_CNpass_ticket{0}.format(ticket_dict.get(pass_ticket))data_dict {BaseRequest:{DeviceID:e750865687999321,Sid:ticket_dict.get(wxsid),Uin:ticket_dict.get(wxuin),Skey:ticket_dict.get(skey),}}init_ret requests.post(urlinit_url,jsondata_dict)init_ret.encoding utf-8user_dict init_ret.json()print(user_dict)# for user in user_dict[ContactList]:# print(user.get(NickName))return render_template(index.html,user_dictuser_dict) 首先从session中获取我们处理后得到的凭证字典然后发送post请求这里发送的数据为json格式post请求的返回内容就是用户相关数据的字典我们可以通过ret.json()直接获取这个字典相当于经过json.loads然后将相关的内容渲染到页面上 index页面 !DOCTYPE html
html langzh-cn
headmeta charsetUTF-8meta http-equivX-UA-Compatible contentIEedgemeta nameviewport contentwidthdevice-width, initial-scale1titleTitle/title
/head
bodyh1欢迎登录{{user_dict.User.NickName}}/h1h3最近联系人/h3ul{% for user in user_dict.ContactList%}li{{user.NickName}}/li{% endfor %}/ul
/body
/html 转载于:https://www.cnblogs.com/weiwu1578/articles/9010561.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/87415.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!