【koa】解决koa-router获取请求参数的问题

本文介绍了如何在Koa中通过koa-router获取请求参数,包括GET请求和POST请求。对于GET请求,参数直接在URL中;而对于POST请求,可以通过安装koa-bodyparser获取参数,或者使用原生方法通过request.body来获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端代码:

$.ajax({
	url:'http://localhost:7777/charts/query',
	type: 'POST',
	contentType: 'application/json',
	data: JSON.stringify({"cccc":"32423423"}),
	dataType: 'json',
	success:function (resp) {
		console.log(resp.models);
	}
})

 

1.get请求获取参数的办法:

const Koa = require('koa')
const app = new Koa()

app.use( async (ctx) => {
    ctx.body = {
        url: ctx.url,
        ctx_query: ctx.query,
        ctx_querystring: ctx.querystring
    }
})

app.listen(3000, () => {
	console.log('start ok')
})

2.post请求获取参数(简单版):

  • 先安装koa-bodyparser包
npm install koa-bodyparser --save 
  • 调用

  

onst Koa = require('koa')
const bodyParser = require('koa-bodyparser')

const app = new Koa()

app.use(bodyParser())

app.use( async (ctx) => {
    ctx.body =  ctx.request.body
})

app.listen(3000, () => {
    console.log('start ok')
})

3.post请求获取参数(原生版):

//使用原生方式
const Koa = require('koa')
const app = new Koa()

app.use( async (ctx) => {
    let data = await parseData(ctx)
    ctx.body = data
})

app.listen(3000, () => {
    console.log('start ok')
})

function parseData(ctx) {
    return new Promise((resolve, reject) => {
        try {
            let str = ''
            ctx.req.on('data', (data) => {
                str += data
            })
            ctx.req.addListener('end', () => {
                resolve(parseUrl(str))
            })
        } catch (err) {
            reject(err)
        }
    });
}

function parseUrl(url) {
    let obj = {}
    let arr = url.split('&')
    arr.forEach((e, i) => {
        let temparr = e.split('=')
        obj[temparr[0]] = temparr[1]
    });
    return obj
}

原生方法相对来说比较繁琐,所以一般采用简单版的方式,需要获取参数,只需调用request.body就可以获取到post请求的参数了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值