nodejs的 Cannot set headers after they are sent to the client
2023-12-14 03:32:49
这个问题是服务端重复响应照成的,例如:
exports.regUser = (req, res) => {
// 接受表单数据
const userinfo = req.body
// 判断依据是否合法
if(!userinfo.username || !userinfo.password){
return res.send({
status:1,
message:'用户名或者密码不能为空!'
})
}
const sql = `select * from ev_users where username=?`
db.query(sql,[userinfo.username],function(err, results){
//执行SQL语句失败
if(err){
return res.send({ status:1, message: err.message })
}
if(results.length > 0){
return res.send({ status:1, message:'用户名被占用,请更换其他用户名!' })
}
})
// 用户名可以使用
res.send("注册成功")
}
或者
exports.regUser = (req, res) => {
// 接受表单数据
const userinfo = req.body
// 判断依据是否合法
if(!userinfo.username || !userinfo.password){
return res.send({
status:1,
message:'用户名或者密码不能为空!'
})
}
const sql = `select * from ev_users where username=?`
db.query(sql,[userinfo.username],function(err, results){
//执行SQL语句失败
if(err){
res.send({ status:1, message: err.message })
}
if(results.length > 0){
res.send({ status:1, message:'用户名被占用,请更换其他用户名!' })
}
// 用户名可以使用
res.send("注册成功")
})
}
这里响应了两个以上send,就会出现上面的报错,解决办法:一次运行只保留一个send返回
exports.regUser = (req, res) => {
// 接受表单数据
const userinfo = req.body
// 判断依据是否合法
if(!userinfo.username || !userinfo.password){
return res.send({
status:1,
message:'用户名或者密码不能为空!'
})
}
const sql = `select * from ev_users where username=?`
db.query(sql,[userinfo.username],function(err, results){
//执行SQL语句失败
if(err){
return res.send({ status:1, message: err.message })
}
if(results.length > 0){
return res.send({ status:1, message:'用户名被占用,请更换其他用户名!' })
}
// 用户名可以使用
res.send("注册成功")
})
}
文章来源:https://blog.csdn.net/qq_35181466/article/details/134836176
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!