开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 7397|回复: 4
收起左侧

[技术专题] 使用Node.js搭载http API

[复制链接]
结帖率:80% (16/20)
发表于 2020-9-16 09:01:49 | 显示全部楼层 |阅读模式   广东省东莞市
一、前期准备首先声明:不懂也没关系,直接仿照代码,需要修改的地方我会用红色标注出来
需要的下载的东西::vs code 、nodeJS


本来也没想做API,定制贴了一个JS算法比较复杂发现node正常运行,V8等JS调试器运行无效又需要易语言来调用,于是用了这个办法,可以看附件图里的效果图,把要加密的参数做http请求的参数丢到抠出来的JS函数里执行得到加密结果 用来易语言调用


二、主要操作
怎么扣JS就没必要讲了,是哪个网站也不说了,我们直接上干货吧!
装好需要下载的东西以后,用VSCODE先创建一个项目文件夹我这里起命叫myJs,然后在目录下按cmd,打命令
  1. 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,代码如下:
  1. <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如下:
  1. //....你自己的加密算法置于此代码上方,下面的encryption的定义就是调用加密函数main,这个main是我自己命名的,传递参数也是不是必须的,可以自己定义自己的加密函数
复制代码

到这里就结束了,直接在项目跟目录打上cmd 执行命令:node server.js 运行输出 Server running at http//:127.0.0.1:3000 就是成功了,然后得到本文里的效果图
然后易语言就正常的http post去获取加密了~~~~
效果.png

评分

参与人数 3好评 +3 精币 +4 收起 理由
llxx123 + 1 + 2 支持开源~!感谢分享
EasonC + 1 新技能已get√
粉风 + 1 + 2 感谢分享,很给力!~

查看全部评分


发表于 2020-10-1 23:40:14 高大上手机用户 | 显示全部楼层   江西省宜春市
大佬牛逼
回复 支持 反对

使用道具 举报

发表于 2020-9-16 09:13:22 | 显示全部楼层   广西壮族自治区南宁市
可以可以666撒旦
回复 支持 反对

使用道具 举报

结帖率:80% (16/20)

签到天数: 5 天

 楼主| 发表于 2020-9-16 09:08:03 | 显示全部楼层   广东省东莞市
补发test.js代码:
  1. module.exports = {
  2.   encryption: function (fserverKeyInfo, RSAKEY, SM2KEY, clientId, UUID, phone, pwd) {
  3.     return main(fserverKeyInfo, RSAKEY, SM2KEY, clientId, UUID, phone, pwd);
  4.   }
  5. }
复制代码


回复 支持 反对

使用道具 举报

结帖率:80% (16/20)

签到天数: 5 天

 楼主| 发表于 2020-9-16 09:06:59 | 显示全部楼层   广东省东莞市
补发server.js代码:

  1. let express = require('express') // 引入express
  2. var bodyParser = require('body-parser'); //JSON参数解析

  3. var test = require('./test');//引入加密算法的JS文件

  4. let app = express() // 相当于 http.createServer(app)


  5. app.use(bodyParser.json({ limit: '1mb' }));  //body-parser 解析json格式数据
  6. app.use(bodyParser.urlencoded({            //此项必须在 bodyParser.json 下面,为参数编码
  7.   extended: true
  8. }));

  9. // 访问根路由 测试服务是否正常启动
  10. app.get('/', (req, res, next) => {
  11.   const data = req.query;
  12.   console.log(data);
  13.   res.send('sever init success');
  14. });

  15. //访问JS加密算法
  16. app.post('/api', (req, res, next) => {
  17.   var data = req.body.data;
  18.   console.log(data);
  19.   var resText = test.encryption(data.RS, data.RSAKEY, data.SM2KEY, data.clientId, data.UUID, data.phone, data.pwd);
  20.   res.send(resText);
  21. });

  22. // 监听3000端口
  23. let server = app.listen(3000, '127.0.0.1', () => {
  24.   let host = server.address().address // host域
  25.   let port = server.address().port // 端口号

  26.   console.log(`Server running at http://${host}:${port}`)
  27. });
复制代码
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表