node多个res.end数据返回会返回最后一个

最近在做毕业设计

后台node学了没多久,在设计专门给登录做的url时发生了一些问题

这串代码,运行,并且前端请求后,前端控制台打印出了404,然后后台控制台打印出了数据,很明显登录请求的res.end(subdata.username)这行代码并没有执行,console运行后,最后运行的是res.end(‘404 not fond..’)

if(pathname === '/denglu'){
            fs.readFile(hidedata+'/user.json',function(err,data){
                var userdata = JSON.parse(data.toString())  //读用户总体数据
                res.end(subdata.username)
                console.log(userdata.user[1].username)
                // for(let i = 0; i < userdata.user.length-1;i++){
                //     if(userdata.user[i].username===subdata.username&&userdata.user[i].password===subdata.userpassword){
                //         res.end(userdata.user[i])
                //     }
                //     else res.end(error)
                // }
            })
        }
        //页面请求
        main = req.url;
        fs.readFile(find+main,function(err,data){
            if(err){res.end('404 not fond..')}
            else
            res.end(data)
        })

我多次修改后,最后在登录请求加了return完美解决

 if(pathname === '/denglu'){
            fs.readFile(hidedata+'/user.json',function(err,data){
                var userdata = JSON.parse(data.toString())  //读用户总体数据
                for(let i = 0; i < userdata.user.length-1;i++){
                    if(userdata.user[i].username===subdata.username&&userdata.user[i].password===subdata.userpassword){
                        res.end(userdata.user[i])
                    }
                    else res.end('error')
                }
            })
            return}

由此得出,res.end后服务器块的代码并不会终结运行,需要加入return。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值