__ _______..______ .______ ______
| | / || _ \ | _ \ / |
| | | (----`| |_) | | |_) | | ,----'
.--. | | \ \ | / | ___/ | |
| `--' | .----) | | |\ \----.| | | `----.
\______/ |_______/ | _| `._____|| _| \______|
为了建立一个更好的 jsrpc 交流平台,我们与猿人学的平哥共同创建了一个微信交流群。
希望借此机会,帮助广大开发者更深入地了解和使用 jsrpc。
请使用微信扫描以下二维码并备注“jsrpc”以申请加入我们的交流群。
在这个交流群里,我们将:
- 及时分享 jsrpc 的使用方法和实践案例。
- 发布工具的后续功能更新和版本维护信息。
- 邀请多位长期关注 jsrpc 的技术创作者共同参与内容交流和经验分享。
群内将提供更多的jsrpc 实操案例 、使用方法 及常见问题 汇总等资料,
欢迎感兴趣的朋友踊跃加入,共同构建一个开放、实用的jsrpc工具交流社区。
-- js逆向之远程调用(rpc)免去抠代码补环境
作者-黑脸怪
main.go (服务器的主代码)
resouces/JsEnv_De.js (客户端注入js环境)
config.yaml (可选配置文件)
运行服务器程序和js脚本 即可让它们通信,实现调用接口执行js获取想要的值(加解密)
原理:在网站的控制台新建一个WebScoket客户端链接到服务器通信,调用服务器的接口 服务器会发送信息给客户端 客户端接收到要执行的方法执行完js代码后把获得想要的内容发回给服务器 服务器接收到后再显示出来
说明:本方法可以https证书且支持wss
如图所示
api 简介
/list:查看当前连接的ws服务 (get)/ws:浏览器注入ws连接的接口 (ws | wss)/wst:ws测试使用-发啥回啥 (ws | wss)/go:获取数据的接口 (get | post)/execjs:传递jscode给浏览器执行 (get | post)/page/cookie:直接获取当前页面的cookie (get)/page/html:获取当前页面的html (get)
说明:接口用?group分组 如 "ws://127.0.0.1:12080/ws?group={}" 以及可选参数 clientId clientId说明:以group分组后,如果有注册相同group的 可以传入这个id来区分客户端,如果不传 服务程序会自动生成一个。当访问调用接口时,服务程序随机发送请求到相同group的客户端里。
//注入例子 group可以随便起名(必填) http://127.0.0.1:12080/go?group={}&action={}¶m={} //这是调用的接口 group填写上面注入时候的,action是注册的方法名,param是可选的参数 param可以传string类型或者object类型(会尝试用JSON.parse)
注入JS,构建通信环境(/resouces/JsEnv_De.js)
打开JsEnv 复制粘贴到网站控制台(注意:可以在浏览器开启的时候就先注入环境,不要在调试断点时候注入)
// 注入环境后连接通信
var demo = new Hlclient("ws://127.0.0.1:12080/ws?group=zzz");
// 可选
//var demo = new Hlclient("ws://127.0.0.1:12080/ws?group=zzz&clientId=hliang/"+new Date().getTime())浏览器已经连接上通信后 调用execjs接口就行
import requests
js_code = """
(function(){
console.log("test")
return "执行成功"
})()
"""
url = "http://localhost:12080/execjs"
data = {
"group": "zzz",
"code": js_code
}
res = requests.post(url, data=data)
print(res.text)// 注册一个方法 第一个参数hello为方法名,
// 第二个参数为函数,resolve里面的值是想要的值(发送到服务器的)
demo.regAction("hello", function (resolve) {
//这样每次调用就会返回“好困啊+随机整数”
var Js_sjz = "好困啊"+parseInt(Math.random()*1000);
resolve(Js_sjz);
})
访问接口,获得js端的返回值
http://127.0.0.1:12080/go?group=zzz&action=hello
//写一个传入字符串,返回base64值的接口(调用内置函数btoa)
demo.regAction("hello2", function (resolve,param) {
//这样添加了一个param参数,http接口带上它,这里就能获得
var base666 = btoa(param)
resolve(base666);
})访问接口,获得js端的返回值 http://127.0.0.1:12080/go?group=zzz&action=hello2¶m=123456
//假设有一个函数 需要传递两个参数
function hlg(User,Status){
return User+"说:"+Status;
}
demo.regAction("hello3", function (resolve,param) {
//这里还是param参数 param里面的key 是先这里写,但到时候传接口就必须对应的上
res=hlg(param["user"],param["status"])
resolve(res);
})访问接口,获得js端的返回值
url = "http://127.0.0.1:12080/go"
data = {
"group": "zzz",
"action": "hello3",
"param": json.dumps({"user":"黑脸怪","status":"好困啊"})
}
print(data["param"]) #dumps后就是长这样的字符串{"user": "\u9ed1\u8138\u602a", "status": "\u597d\u56f0\u554a"}
res=requests.post(url, data=data) #这里换get也是可以的
print(res.text)resp = requests.get("http://127.0.0.1:12080/page/html?group=zzz") # 直接获取当前页面的html
resp = requests.get("http://127.0.0.1:12080/page/cookie?group=zzz") # 直接获取当前页面的cookie





