官方文档: https://www.tampermonkey.net/documentation.php#google_vignette
1.注释语法:
说明:
@name: 脚本名称
@match: 匹配网站,*表示通配
@icon 用于设置脚本的图标
@grant 这个属性可用来申请GM_*函数和unsafeWindow权限。相当于放在脚本header里面告诉油猴扩展,你需要用些什么东西,然后它就会给你相应的权限。
默认的情况下,你的脚本运行在油猴给你创建的一个沙盒环境下,这个沙盒环境无法访问到前端的页面,也就无法操作前端的一些元素等。
如果在页面最前方声明// @grant none,那么油猴就会将你的脚本直接放在网页的上下文中执行,这是的脚本上下文(window)就是前端的上下文。但是这样的话就无法使用GM_*等函数,无法与油猴交互,无法使用一些更强的功能。
所以一般写脚本的时候是使用unsafeWindow与前端交互,而不使用// @grant none,这样就可以使用grant去申请油猴的一些更强的函数功能。
@run-at: 主要是设置脚本运行的时候
@connect: 设置允许通过的域名,使用 @connect 配置确保此跨域请求是计划内的行为
创建方式:
1)新建一个脚本
2)在指定网址,选择并新建自动匹配当前地址,例如:@match https://passport.yhd.com/
2.使用
1)对于系统函数进行劫持
注意:若是一开始就需要注入的系统函数, 需要设置run-at,在一开始就进行注入
2)http访问
GM_xmlhttpRequestAPI
3) 插入新元素
4)添加监听器
5) 引入外部JS文件
-- @require 需要使用这个来引入需要的JS文件
6) 引入外部css资源
// @resource css https://blog.icodef.com/wp-content/themes/Kratos-3.0.7/assets/css/kratos.min.css?ver=3.2.4
// @resource SRIsecured1 http://example.com/favicon1.ico#md5=ad34bb...
// @resource SRIsecured2 http://example.com/favicon2.ico#md5=ac3434...,sha256=23fd34...
// @require https://code.jquery.com/jquery-2.1.1.min.js#md5=45eef...
// @require https://code.jquery.com/jquery-2.1.2.min.js#md5-ac56d...,sha256-6e789...
// @require https://code.jquery.com/jquery-3.6.0.min.js#sha256-/xUj+3OJU...ogEvDej/m4=
# 注: require 和 resource 支持 window.crypto 校验,例如 SHA-256, MD5, SHA-1, SHA-384 和 SHA-512。
脚本:
1) 打印hook cookie
https://github.com/JSREI/js-cookie-monitor-debugger-hook?tab=readme-ov-file
2) 监听页面跳转事件(页面被重定向情况)