|
一、前期准备首先声明:不懂也没关系,直接仿照代码,需要修改的地方我会用红色标注出来
需要的下载的东西::vs code 、nodeJS
本来也没想做API,定制贴了一个JS算法比较复杂发现node正常运行,V8等JS调试器运行无效又需要易语言来调用,于是用了这个办法,可以看附件图里的效果图,把要加密的参数做http请求的参数丢到抠出来的JS函数里执行得到加密结果 用来易语言调用
二、主要操作
怎么扣JS就没必要讲了,是哪个网站也不说了,我们直接上干货吧!
装好需要下载的东西以后,用VSCODE先创建一个项目文件夹我这里起命叫myJs,然后在目录下按cmd,打命令
- npm i express -S // <span style="background-color: rgb(255, 255, 255); font-family: tahoma, arial, sans-serif; font-size: 12px;">安装express依赖库</span>
复制代码 1。在项目文件夹根目录创建文件:server.js,代码如下:- <blockquote>let express = require('express') // 引入express
复制代码
let app = express() // 相当于 http.createServer(app)
app.use(bodyParser.json({ limit: '1mb' })); //body-parser 解析json格式数据
app.use(bodyParser.urlencoded({ //此项必须在 bodyParser.json 下面,为参数编码
extended: true
}));
// 访问根路由 测试服务是否正常启动 根路径:URL访问得到的结果用 res.send()展示!
app.get('/', (req, res, next) => {
const data = req.query;
console.log(data);
res.send('sever init success');
});
//访问JS加密算法接口API,路径为URL+/api 这里要求JSON格式为:{"data":{"xxx":"","xxx":""}} 取data里的参数即可 强烈要求 http请求带上header:Content-Type: application/json 不然就无效了
app.post('/api', (req, res, next) => {
var data = req.body.data;
//打印接受到的参数
console.log(data);
//encryption 函数获取抠出来的JS算法得到返回值resText
var resText = test.encryption(data.RS, data.RSAKEY, data.SM2KEY, data.clientId, data.UUID, data.phone, data.pwd);
// 发送加密结果到 客户端
res.send(resText);
});
// 监听3000端口 可以自己改 但是 127.0.0.1不能改 服务器上配置Nginx做个反向代理即可!!
let server = app.listen(3000, '127.0.0.1', () => {
let host = server.address().address // host域
let port = server.address().port // 端口号
console.log(`Server running at http://${host}:${port}`)
});
2.JS加密文件TEST如下:- //....你自己的加密算法置于此代码上方,下面的encryption的定义就是调用加密函数main,这个main是我自己命名的,传递参数也是不是必须的,可以自己定义自己的加密函数
复制代码
到这里就结束了,直接在项目跟目录打上cmd 执行命令:node server.js 运行输出 Server running at http//:127.0.0.1:3000 就是成功了,然后得到本文里的效果图
然后易语言就正常的http post去获取加密了~~~~
|
-
评分
-
查看全部评分
|