// Next.js API route support: https://nextjs.org/docs/api-routes/introduction import type { NextApiRequest, NextApiResponse } from 'next'; import { jsonRes } from '@/service/response'; import { User } from '@/service/models/user'; import { AuthCode } from '@/service/models/authCode'; import { connectToDatabase } from '@/service/mongo'; import { generateToken } from '@/service/utils/tools'; import { EmailTypeEnum } from '@/constants/common'; export default async function handler(req: NextApiRequest, res: NextApiResponse) { try { const { email, code, password } = req.body; if (!email || !code || !password) { throw new Error('缺少参数'); } await connectToDatabase(); // 验证码校验 const authCode = await AuthCode.findOne({ email, code, type: EmailTypeEnum.findPassword, expiredTime: { $gte: Date.now() } }); if (!authCode) { throw new Error('验证码错误'); } // 更新对应的记录 await User.updateOne( { email }, { password } ); // 根据 email 获取用户信息 const user = await User.findOne({ email }); jsonRes(res, { data: { token: generateToken(user._id), user } }); } catch (err) { jsonRes(res, { code: 500, error: err }); } }