首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >next-auth + Chrome扩展

next-auth + Chrome扩展
EN

Stack Overflow用户
提问于 2022-08-03 18:56:38
回答 1查看 171关注 0票数 0

我想在一个有前端和后端的站点上使用next-auth。这在下一个版本中很容易,但是,我想不出一种通过Chrome扩展来验证用户身份的方法,这个扩展可以与后端通信。这样做的目的是在站点上创建数据,并将其与Chrome扩展一起用于创建该站点的用户。我不能把秘密存储在Chrome扩展程序上。有什么想法吗?我有一个想法来验证用户的身份,比如在电视和其他设备上。他们在站点上生成代码并将其插入到Chrome扩展程序中。当然,它在短期内是有效的。

但在我走上这条路之前,我想知道是否有人有更好的解决办法。

EN

回答 1

Stack Overflow用户

发布于 2022-08-10 21:23:38

对我起作用的是从扩展到next-auth会话端点:/api/auth/session的请求。

如果会话不存在,我将打开一个带有登录页面的新选项卡,然后从那里开始。

下面是我的manifest.json的样子:

代码语言:javascript
复制
{
    "manifest_version": 3,
    "name": "Timer Extension",
    "version": "1.0.0",
    "description": "Hello Chrome World!",
    "icons": {
        "16": "grin.png",
        "48": "grin.png",
        "128": "grin.png"
    },
    "action": {
        "default_icon": {
            "16": "grin.png",
            "24": "grin.png",
            "32": "grin.png"
        },
        "default_title": "Timer Extension Action Title",
        "default_popup": "popup.html"
    },
    "background": {
        "service_worker": "authCheck.js"
    },
    "host_permissions": [
        "https://*/"
    ]
}

以下是authCheck.js服务工作者:

代码语言:javascript
复制
chrome.runtime.onMessage.addListener(
    function (request, sender, onSuccess) {
        console.log("running check")
        fetch("<your-domain>/api/auth/session", {
            mode: 'cors',
        })
            .then(response => response.json())
            .then((session) => {
                if (Object.keys(session).length > 0) {
                    onSuccess(session)
                } else {
                    onSuccess(null)
                }
            })
            .catch(err => {
                console.error(err);
                onSuccess(null)
            })

        return true;  // Will respond asynchronously.
    }
);

然后,在default_popup html的js文件中,我有以下内容:

代码语言:javascript
复制
chrome.runtime.sendMessage(
    {action: 'AUTH_CHECK'},
    (session) => {    
        if (session) {
            //user is logged in
        } else {
            //no session means user not logged in
            chrome.tabs.create({
                url: '<link to your login page>'
              }); 
        }
    }
);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73226471

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档