nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台

这篇具有很好参考价值的文章主要介绍了nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

搭建nodejs服务

考虑跨域等性能,简易的工程化,采用express框架

接下来我们就来安装 body-parser express的中间件 body-parser
解析客户端请求的body中的内容,JSON编码处理和url编码处理
文件上传看我之前的博客内容

const express = require('express');
const bodyParser = require('body-parser');
const Aixpor = require("./options")
const app = express()
const port = 8088

app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json());


//设置跨域访问
app.all("*", function(req, res, next) {
	//设置允许跨域的域名,*代表允许任意域名跨域
	res.header("Access-Control-Allow-Origin", req.headers.origin || '*');
	 // //只允许http://xxx.xx.xx/可跨
    //res.header('Access-Control-Allow-Origin', 'http://xxx.xx.xx/');
	//允许的header类型
	res.header("Access-Control-Allow-Headers", "Content-Type, Authorization, X-Requested-With");
	//跨域允许的请求方式 
	res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
	// 可以带cookies
	res.header("Access-Control-Allow-Credentials", true);
	if (req.method == 'OPTIONS') {
		res.sendStatus(200);
	} else {
		next();
	}
})

app.listen(port, () => {
	console.log(`Example app listening at http://localhost:${port}`)
})

创建对外开放端口,获取基础数据

GET—query

http://localhost:8080/?age=1

app.get('/', function (req, res) {
  var params = req.query
  res.send(params)
})
//{"age": "1"}

nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台

GET—params

http://localhost:8080/12/url

app.get('/testcommit/:id?/url', function (req, res) {
  var params = req.params
  res.send(params)
})
// {"id": "13"}
//此处的问号代表的为可选参数,非必写参数

当然也可以进行组合发送
nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台

POST

app.post('/post', function (req, res) {
 var params = req.body
  console.log(params)
  //{ name:"勇敢牛牛" }
})

nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台

联动MYSQL数据库

获取websites表的所有书

链接数据库

let mysql = require('mysql');

let connection = mysql.createConnection({
  host:"localhost",
  port:"3306",
  database:'test_1',
  user:'root',
  password:'12345678',
  
})

connection.connect();
// 导出
exports.connection = connection;

这里是test_1数据库下的websites表格式数据内容。
nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台

app.get('/testcommit/:id?',(req,res)=>{
    res.status(200);
    let sql = "SELECT * FROM `websites` u "
    connection.query(sql,(err,result)=>{
      if(err){
        console.log('查询出错',err);
        res.json([])
        return;
      }
      res.json(result)
    })
  })

插入

app.post('/testcommit',(req,res)=>{
    let body = req.body;
    console.log(Object.values(body));
    
    let addSql = 'INSERT INTO websites(Id,name,url,alexa,country) VALUES(0,?,?,?,?)';
    connection.query(addSql,Object.values(body),(err,result)=>{
      if(err){
        console.log('插入出错',err);
        res.status(500);
        res.json({message:"添加数据出错啦"})
        return;
      }
      res.status(200);
      res.json({message:result})
    })
  })
}

nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台
根据这些http的menth方法,url,path,body等等标识来判断,唯一的资源判断。进行业务逻辑处理。

这是MySQL插入数据成功后返回的结果字段的含义:

- `fieldCount`: 返回结果中的字段数目。
- `affectedRows`: 受影响的行数,表示成功插入的行数。
- `insertId`: 插入的记录的自增ID值。如果表定义了自增ID字段,则返回新插入行的自增ID值;否则返回0- `serverStatus`: 服务器状态标识,表示执行插入操作后的服务器状态。
- `warningCount`: 警告数目,表示在执行插入操作期间发出的警告数量。
- `message`: 服务器返回的消息或错误信息。
- `protocol41`: 表示服务器是否使用的是MySQL 4.1+协议。
- `changedRows`: 发生更改的行数,对于插入操作,由于是新增数据,所以没有更改的行,该值通常为0

这些字段提供了关于插入操作的相关信息,包括受影响的行数、自增ID值以及服务器状态等。可以根据需要使用这些字段来进行后续的处理或判断。文章来源地址https://www.toymoban.com/news/detail-513808.html

到了这里,关于nodejs接口联动获取req的各种类型数据,搭建可视化流程引擎平台的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包