我通过使用href将Facebook身份验证API路由链接到一个按钮来实现Passport Facebook身份验证,如下所示:
<a href="auth/facebook">Facebook Login</a>当我单击按钮时,它会重定向到Facebook身份验证页面。但是在页面上,会显示一条错误消息,上面写着“不安全的登录阻止:您无法从不安全的页面获得访问令牌或登录到此应用程序。
我怎样才能解决这个问题?
发布于 2018-03-22 02:27:50
令人惊讶的是,一小时前,我就开始尝试做同样的事情,并且一直有着同样的问题。如果您进入FB开发人员门户,并在Facebook下转到Settings,则可以选择强制HTTPS。

进一步调查显示
“强制使用HTTPS。此设置要求OAuth重定向,页面使用JavaScript SDK获取访问令牌。截止2018年3月,所有新创建的应用程序都默认启用此设置,您应该计划在2019年3月之前迁移所有现有应用程序,只使用HTTPS URL。大多数主流云应用程序主机为您的应用程序提供免费和自动配置的TLS证书。如果您自己托管应用程序或托管服务默认不提供HTTPS,您可以从”让加密“获得免费的域证书。”
参考资料:登录安全性
发布于 2018-04-13 23:21:27
由于您使用的是passport,所以也要检查您的auth.js设置,或者在任何地方保存这些设置。即使您的网站有证书,下列代码仍将失败:
'facebookAuth' : {
'clientID' : '.............', // App ID
'clientSecret' : '............................', // App Secret
'callbackURL' : 'localhost:9999/auth/facebook/callback',
'profileURL' : 'https://graph.facebook.com/v2.5/me?fields=first_name,last_name,email',
'profileFields' : ['id', 'email', 'name']
},问题在于callbackUrl。
'callbackURL' : '/auth/facebook/callback'
'callbackURL' : 'http://localhost:9999/auth/facebook/callback'上述两项声明都将失败。callbackUrl需要从https开始。第一个尝试加载http://localhost并附加callbackUrl。第二种方法明显地用http加载完整的url,两者都无法与FB连接。因此,尝试以下其中之一。如果您的站点有证书,请提供完整的url。如果要在本地主机上测试这一点,请创建自己的证书并通过https访问它,如下所示:
'callbackURL' : 'https://example.com/auth/facebook/callback'
'callbackURL' : 'https://localhost:9999/auth/facebook/callback'https://stackoverflow.com/questions/49403748
复制相似问题