Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/38.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 错误:Route.post()需要回调函数,但得到了[object]_Javascript_Node.js_Express_Mongoose_Express Router - Fatal编程技术网

Javascript 错误:Route.post()需要回调函数,但得到了[object]

Javascript 错误:Route.post()需要回调函数,但得到了[object],javascript,node.js,express,mongoose,express-router,Javascript,Node.js,Express,Mongoose,Express Router,我试图在我的web应用程序中实现密码重置功能,但我一直在标题中看到错误。我的代码: main.js: const router = express.Router(); const AsyncNewPassword = require('./controller/asyncnewpassword'); const ResetPassWord = require ('./controller/resetpassword'); const ValidPasswordToken = require ('

我试图在我的web应用程序中实现密码重置功能,但我一直在标题中看到错误。我的代码:

main.js:

const router = express.Router();
const AsyncNewPassword = require('./controller/asyncnewpassword');
const ResetPassWord = require ('./controller/resetpassword');
const ValidPasswordToken = require ('./controller/validpasswordtoken');
...
router.post('/req-reset-password', function (req, res) { ResetPassWord });
router.post('/new-password', function (req, res) { AsyncNewPassword });
router.post('/valid-password-token', function (req, res) { ValidPasswordToken });
asyncnewpassword.js:

module.exports.NewPassword = async function NewPassword(req, res) {
    passwordResetToken.findOne({ resettoken: req.body.resettoken }, function (err, userToken, next) {
      if (!userToken) {
        return res
          .status(409)
          .json({ message: 'Token has expired' });
      }

      User.findOne({
        _id: userToken._userId
      }, function (err, userEmail, next) {
        if (!userEmail) {
          return res
            .status(409)
            .json({ message: 'User does not exist' });
        }
        return bcrypt.hash(req.body.newPassword, 10, (err, hash) => {
          if (err) {
            return res
              .status(400)
              .json({ message: 'Error hashing password' });
          }
          userEmail.password = hash;
          userEmail.save(function (err) {
            if (err) {
              return res
                .status(400)
                .json({ message: 'Password can not reset.' });
            } else {
              userToken.remove();
              return res
                .status(201)
                .json({ message: 'Password reset successfully' });
            }

          });
        });
      });

    })
}
module.exports.ResetPassword = async function ResetPassword(req, res) {
    if (!req.body.email) {
    return res
    .status(500)
    .json({ message: 'Email is required' });
    }
    const user = await User.findOne({
    email:req.body.email
    });
    if (!user) {
    return res
    .status(409)
    .json({ message: 'Email does not exist' });
    }
    var resettoken = new passwordResetToken({ _userId: user._id, resettoken: crypto.randomBytes(16).toString('hex') });
    resettoken.save(function (err) {
    if (err) { return res.status(500).send({ msg: err.message }); }
    passwordResetToken.find({ _userId: user._id, resettoken: { $ne: resettoken.resettoken } }).remove().exec();
    res.status(200).json({ message: 'Reset Password successfully.' });
    var transporter = nodemailer.createTransport({
      service: 'Gmail',
      port: 465,
      auth: {
        user: 'user',
        pass: 'password'
      }
    });
    var mailOptions = {
    to: user.email,
    from: 'bot@example.com',
    subject: 'Node.js Password Reset',
    text: 'You are receiving this because you (or someone else) have requested the reset of the password for your account.\n\n' +
    'Please click on the following link, or paste this into your browser to complete the process:\n\n' +
    'http://localhost:4200/response-reset-password/' + resettoken.resettoken + '\n\n' +
    'If you did not request this, please ignore this email and your password will remain unchanged.\n'
    }
    transporter.sendMail(mailOptions, (err, info) => {
    })
    })
    }

resetpassword.js:

module.exports.NewPassword = async function NewPassword(req, res) {
    passwordResetToken.findOne({ resettoken: req.body.resettoken }, function (err, userToken, next) {
      if (!userToken) {
        return res
          .status(409)
          .json({ message: 'Token has expired' });
      }

      User.findOne({
        _id: userToken._userId
      }, function (err, userEmail, next) {
        if (!userEmail) {
          return res
            .status(409)
            .json({ message: 'User does not exist' });
        }
        return bcrypt.hash(req.body.newPassword, 10, (err, hash) => {
          if (err) {
            return res
              .status(400)
              .json({ message: 'Error hashing password' });
          }
          userEmail.password = hash;
          userEmail.save(function (err) {
            if (err) {
              return res
                .status(400)
                .json({ message: 'Password can not reset.' });
            } else {
              userToken.remove();
              return res
                .status(201)
                .json({ message: 'Password reset successfully' });
            }

          });
        });
      });

    })
}
module.exports.ResetPassword = async function ResetPassword(req, res) {
    if (!req.body.email) {
    return res
    .status(500)
    .json({ message: 'Email is required' });
    }
    const user = await User.findOne({
    email:req.body.email
    });
    if (!user) {
    return res
    .status(409)
    .json({ message: 'Email does not exist' });
    }
    var resettoken = new passwordResetToken({ _userId: user._id, resettoken: crypto.randomBytes(16).toString('hex') });
    resettoken.save(function (err) {
    if (err) { return res.status(500).send({ msg: err.message }); }
    passwordResetToken.find({ _userId: user._id, resettoken: { $ne: resettoken.resettoken } }).remove().exec();
    res.status(200).json({ message: 'Reset Password successfully.' });
    var transporter = nodemailer.createTransport({
      service: 'Gmail',
      port: 465,
      auth: {
        user: 'user',
        pass: 'password'
      }
    });
    var mailOptions = {
    to: user.email,
    from: 'bot@example.com',
    subject: 'Node.js Password Reset',
    text: 'You are receiving this because you (or someone else) have requested the reset of the password for your account.\n\n' +
    'Please click on the following link, or paste this into your browser to complete the process:\n\n' +
    'http://localhost:4200/response-reset-password/' + resettoken.resettoken + '\n\n' +
    'If you did not request this, please ignore this email and your password will remain unchanged.\n'
    }
    transporter.sendMail(mailOptions, (err, info) => {
    })
    })
    }

validpasswordtoken.js:

module.exports.ValidPasswordToken = async function ValidPasswordToken(req, res) {
    if (!req.body.resettoken) {
    return res
    .status(500)
    .json({ message: 'Token is required' });
    }
    const user = await passwordResetToken.findOne({
    resettoken: req.body.resettoken
    });
    if (!user) {
    return res
    .status(409)
    .json({ message: 'Invalid URL' });
    }
    User.findOneAndUpdate({ _id: user._userId }).then(() => {
    res.status(200).json({ message: 'Token verified successfully.' });
    }).catch((err) => {
    return res.status(500).send({ msg: err.message });
    });
};
我的堆栈跟踪:

Error: Route.post() requires a callback function but got a [object Object]
    at Route.<computed> [as post] (C:\Apps\Projects\Project1\backend\node_modules\express\lib\router\route.js:202:15)
    at Function.proto.<computed> [as post] (C:\Apps\Projects\Project1\backend\node_modules\express\lib\router\index.js:510:19)
    at Object.<anonymous> (C:\Apps\Projects\Project1\backend\index.js:441:8)
    at Module._compile (internal/modules/cjs/loader.js:1138:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
    at Module.load (internal/modules/cjs/loader.js:986:32)
    at Function.Module._load (internal/modules/cjs/loader.js:879:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47
错误:Route.post()需要回调函数,但得到了[object]
在途中。[发布](C:\Apps\Projects\Project1\backend\node\u modules\express\lib\router\route.js:202:15)
在Function.proto。[发布](C:\Apps\Projects\Project1\backend\node\u modules\express\lib\router\index.js:510:19)
反对。(C:\Apps\Projects\Project1\backend\index.js:441:8)
at模块编译(内部/modules/cjs/loader.js:1138:30)
at Object.Module._extensions..js(internal/modules/cjs/loader.js:1158:10)
在Module.load(内部/modules/cjs/loader.js:986:32)
at Function.Module._load(内部/modules/cjs/loader.js:879:14)
在Function.executeUserEntryPoint[作为runMain](internal/modules/run_main.js:71:12)
在internal/main/run_main_module.js:17:47
最初,该代码在路由器第二个参数中没有函数包装器,但我添加了它,从那时起,访问它时找不到URL…

您可以尝试:

router.post('/req-reset-password', ResetPassWord);
这应该调用方法
ResetPassword

只需注意:使用
resetPassword
纠正驼峰式大小写

编辑:

您的导入可能有问题。
试一试

或者使用大括号导入:

const { ResetPassWord } = require ('./controller/resetpassword');
编辑2:

因为您使用的是nodejs,所以可以使用es6

在从属模块中:

exports.resetPassword = async (req, res) => {
... 
在路由器文件中:

import { restPassword } from './controller/resetpassword';
如果可以的话,我会一直使用它。

你能试试吗:

router.post('/req-reset-password', ResetPassWord);
这应该调用方法
ResetPassword

只需注意:使用
resetPassword
纠正驼峰式大小写

编辑:

您的导入可能有问题。
试一试

或者使用大括号导入:

const { ResetPassWord } = require ('./controller/resetpassword');
编辑2:

因为您使用的是nodejs,所以可以使用es6

在从属模块中:

exports.resetPassword = async (req, res) => {
... 
在路由器文件中:

import { restPassword } from './controller/resetpassword';

应该可以工作,我一直在使用它。

我在您的代码示例(?)中没有看到使用中间件的路由。@html\u程序员,即
router.post('/req reset password',function(req,res){ResetPassWord})使用ResetPassword包装器的用途是什么?还要注意的是,包装器中的函数实际上没有被调用。这是一次试图解决问题的尝试。。我找到了一个建议这样做的答案..我在您的代码示例(?)@html_程序员,即
router.post('/req reset password',function(req,res){ResetPassWord})中没有看到使用中间件的路由使用ResetPassword包装器的用途是什么?还要注意的是,包装器中的函数实际上没有被调用。这是一次试图解决问题的尝试。。我找到了一个答案,所以建议这样做。然后我得到了与标题中相同的错误。问题中包含的堆栈跟踪现在我得到了
错误:Route.post()需要一个回调函数,但得到了一个[object Undefined]
:/
语法错误:意外的标记“export”
:/根据这一点,ES6语法不受直接支持。当我得到
错误:Route.post()需要回调函数,但又得到了一个[object Undefined]
。然后我得到了与标题中相同的错误。问题中包含的堆栈跟踪现在我得到了
错误:Route.post()需要一个回调函数,但得到了一个[object Undefined]
:/
语法错误:意外的标记“export”
:/根据这一点,ES6语法不受直接支持。当我获取
错误:Route.post()需要回调函数,但再次获取[object Undefined]
。。