2018-12-26 23:04:56 +08:00
|
|
|
|
# QWebEngineView
|
|
|
|
|
|
2019-03-12 12:47:56 +08:00
|
|
|
|
- 目录
|
2019-05-22 11:07:42 +08:00
|
|
|
|
- [获取Cookie](#1获取Cookie)
|
|
|
|
|
- [和Js交互操作](#2和Js交互操作)
|
2019-07-09 16:50:40 +08:00
|
|
|
|
- [网页整体截图](#3网页整体截图)
|
2019-08-23 19:41:54 +08:00
|
|
|
|
- [同网站不同用户](#4同网站不同用户)
|
2019-09-24 16:05:33 +08:00
|
|
|
|
- [拦截请求](#5拦截请求)
|
2020-02-18 12:39:33 +08:00
|
|
|
|
- [拦截请求内容](#6拦截请求内容)
|
2019-03-12 12:47:56 +08:00
|
|
|
|
|
2019-03-12 00:08:16 +08:00
|
|
|
|
## 1、获取Cookie
|
2018-12-26 23:04:56 +08:00
|
|
|
|
[运行 GetCookie.py](GetCookie.py)
|
|
|
|
|
|
|
|
|
|
通过`QWebEngineProfile`中得到的`cookieStore`并绑定它的`cookieAdded`信号来得到Cookie
|
|
|
|
|
|
2019-04-27 16:47:05 +08:00
|
|
|
|
![GetCookie](ScreenShot/GetCookie.png)
|
|
|
|
|
|
|
|
|
|
## 2、和Js交互操作
|
|
|
|
|
[运行 JsSignals.py](JsSignals.py)
|
|
|
|
|
|
|
|
|
|
通过`qwebchannel.js`和`QWebChannel.registerObject`进行Python对象和Javascript的交互
|
|
|
|
|
|
|
|
|
|
具体看代码中的注释
|
|
|
|
|
|
2019-07-09 16:50:40 +08:00
|
|
|
|
![JsSignals](ScreenShot/JsSignals.gif)
|
|
|
|
|
|
|
|
|
|
## 3、网页整体截图
|
|
|
|
|
[运行 ScreenShotPage.py](ScreenShotPage.py)
|
|
|
|
|
|
|
|
|
|
1. 方式1:目前通过不完美方法(先调整`QWebEngineView`的大小为`QWebEnginePage`的内容大小,等待一定时间后截图再还原大小)
|
|
|
|
|
2. 方式2:通过js库`html2canvas`对指定元素截图,得到`base64`编码的数据并调用接口函数传递到py代码中
|
|
|
|
|
|
2019-08-23 19:41:54 +08:00
|
|
|
|
![ScreenShotPage](ScreenShot/ScreenShotPage.gif)
|
|
|
|
|
|
|
|
|
|
## 4、同网站不同用户
|
|
|
|
|
[运行 SiteDiffUser.py](SiteDiffUser.py)
|
|
|
|
|
|
|
|
|
|
原理是为每个`QWebEngineView`创建一个`QWebEnginePage`,且使用独立的`QWebEngineProfile`,并配置`persistentStoragePath`不同路径
|
|
|
|
|
|
2019-09-24 16:05:33 +08:00
|
|
|
|
![SiteDiffUser](ScreenShot/SiteDiffUser.gif)
|
|
|
|
|
|
|
|
|
|
## 5、拦截请求
|
|
|
|
|
[运行 BlockRequest.py](BlockRequest.py)
|
|
|
|
|
|
|
|
|
|
通过`QWebEngineUrlRequestInterceptor`中的`interceptRequest`方法对每个请求做拦截过滤
|
|
|
|
|
|
2020-02-18 12:39:33 +08:00
|
|
|
|
![BlockRequest](ScreenShot/BlockRequest.gif)
|
|
|
|
|
|
|
|
|
|
## 6、拦截请求内容
|
|
|
|
|
[运行 BlockRequestData.py](BlockRequestData.py)
|
|
|
|
|
|
|
|
|
|
这里用了一个投巧的办法,原理是先通过`QWebEngineUrlRequestInterceptor`中的`interceptRequest`方法对每个请求做拦截过滤,
|
|
|
|
|
发现目标url后重定向到`QWebEngineUrlSchemeHandler`实现的自定义协议头返回数据
|
|
|
|
|
|
|
|
|
|
![BlockRequestData](ScreenShot/BlockRequestData.png)
|