提问者:小点点

从Firebase实时数据库获取数据返回无效的json响应


在这里,我向一个api发出获取请求-

export async function getServerSideProps(ctx) {
    let id = ctx.params.id;

    let userObject;
    let userId;
    const cookie = parseCookies(ctx);
    if (cookie.auth) {
        userObject = JSON.parse(cookie.auth);
        userId = userObject.id;
    }
    if (!userId) {
        return {
            redirect: {
                permanent: false,
                destination: '/',
            },
        };
    }


    const res = await fetch(`http://localhost:3000/api/tests/${id}`);
    console.log(await res.json());
    const data = await res.json();
    console.log(data);
    // return {
    //  props: { product: data },
    // };
    return {
        props: {},
    };
}

这里我正在从firebase实时数据库读取数据-

export default async (req, res) => {
    const { id } = req.query;
    console.log(id);
    let obj;

    firebase
        .database()
        .ref('/test/' + id)
        .once('value')
        .then(snapshot => {
            console.log('here');
            const data = snapshot.val();
            obj = data;
        })
        .then(() => res.status(200).json(obj))
        .catch(err => console.log(err));
};

这给了我这个错误-

服务器错误FetchError:位于的json响应正文无效https://localhost:3000/api/tests/-MUT5-DbK6Ff6CstPSGc原因:JSON输入意外结束

除了发出fetch请求后得到的json响应之外,其他一切似乎都正常工作。我甚至不能安慰你。记录日志以查看实际得到的响应。我错过了什么?

编辑-这是我的Firebase数据库结构,其中测试节点是根节点


共1个答案

匿名用户

你的promise没有回报。这就是为什么obj是空的。而不是在第一次捕获时发送响应。

export default async (req, res) => {
    const { id } = req.query;
    console.log(id);
    let obj;

    firebase
        .database()
        .ref('/test/' + id)
        .once('value')
        .then(snapshot => {
            console.log('here');
            const data = snapshot.val();
            obj = data;
            res.status(200).json(obj)
        })
        .catch(err => console.log(err));
};