返回顶部
首页 > 资讯 > 数据库 >解决Cannot set headers after they are sent to the client
  • 318
分享到

解决Cannot set headers after they are sent to the client

数据库javascriptmysql 2023-08-18 20:08:01 318人浏览 泡泡鱼
摘要

问题原因 出现Cannot set headers after they are sent to the client的原因,客户端发出一次请求,服务器给出两次及以上响应。 解决办法 建议大家排查一下接口,清除掉多余的响应。 // 第三方插

问题原因

出现Cannot set headers after they are sent to the client的原因,客户端发出一次请求,服务器给出两次及以上响应。

解决办法

建议大家排查一下接口,清除掉多余的响应。

// 第三方插件const Mysql = require('mysql');// 数据库信息 let dbinfo = {    host: '127.0.0.1', //数据库的ip地址    user: 'root',      //登录数据库的账号    passWord: '123456',//数据库的密码    database: 'test', //数据库的名称    multipleStatements: true, // 支持执行多条 sql 语句}// 定义公共的数据库查询方法,传入三个参数 sql语句,res,参数:前两个为必传,参数不传默认为空数组let db = function (sql, res, params = []) {    return new Promise((resolve, reject) => {        // 一、新建一个连接池        let pool = mysql.createPool(dbinfo)        // 二、连接        pool.getConnection((error, connection) => {            // 三、使用sql语句操作            connection.query(sql, params, (err, results, fields) => {                if (err) {                // res是调用接口时,如果执行mysql执行出错,直接返回报错信息                    res.send({                        code: 500,                        status: false,                        msg: "服务器内部错误:" + err.message                    })                } else {                    resolve(results)                }                // 四、释放连接池                connection.release()            })        })    })}

调用db方法示例

// router是express框架的路由 , db为我们定义的mysql查询方法const { router , utilSuccess , utilErr , db  } = require('../../util/util');router.post('/deleteWxuser',   (req,res)=>{    let { id  } = req.body,    deleteSql =  'delete from wxuser where id in (?)';    db( deleteSql , res , [ id ] ).then( sqldata =>{        if( sqldata.affectedRows ){            res.send({                ...utilSuccess,                msg: "删除用户成功"            })        }else{            res.send({                ...utilErr,                msg: "删除用户失败",            })        }    })})

来源地址:https://blog.csdn.net/weixin_45481145/article/details/125455998

您可能感兴趣的文档:

--结束END--

本文标题: 解决Cannot set headers after they are sent to the client

本文链接: https://lsjlt.com/news/374738.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作