我是SSO的新手。最近,我专注于使用OIDC的项目。我尝试使用oidc-client解决问题。这是我的设置。(我删除了详细网址,但它们有效)。
var mgr = new Oidc.UserManager({
userStore: new Oidc.WebStorageStateStore({ store: window.localStorage }),
metadata: {
issuer: 'https://foo.com/',
authorization_endpoint: 'https://foo.com/',
userinfo_endpoint: 'https://foo.com/',
end_session_endpoint: 'https://foo.com/',
jwks_uri: 'https://foo.com/'
},
keys: [
{
'kty': 'RSA',
'kid': 'some info',
'use': 'some info',
'n': 'some info',
'e': 'some info'
}
],
client_id: 'aaaaa',
redirect_uri: 'https://foo.com/',
response_type: 'id_token token',
scope: 'openid'
})
Oidc.Log.logger = console
Oidc.Log.level = Oidc.Log.INFO
mgr.signinRedirect()
.then(function () { console.log('Hello') }).catch(function (err) {
console.log(err)
})
但是它没有重定向到authorization_endpoint。相反,它会引发类似以下的错误
oidc-client.min.js?dd17:1 SigninRequest.ctor:未通过任何授权 错误@ oidc-client.min.js?dd17:1 SigninRequest @ oidc-client.min.js?dd17:3(匿名)@ oidc-client.min.js?dd17:3 Promise.then(异步)createSigninRequest @ oidc-client.min.js?dd17:3 (匿名)@ oidc-client.min.js?dd17:3 Promise.then(异步) _signinStart @ oidc-client.min.js?dd17:3 signinRedirect @ oidc-client.min.js?dd17:3 onSubmit @ HelloWorld.vue?140d:71 click @ HelloWorld.vue?1f3f:21调用程序@ vue.runtime.esm.js?2b0e:2023 fn._withTask.fn._withTask @ vue.runtime.esm.js?2b0e:1822
我在vue-cli环境下运行代码。但是我认为这不会引起问题。如果您遇到了类似的问题,请告诉我如何解决。谢谢。
答案 0 :(得分:0)
在https://github.com/IdentityModel/oidc-client-js/wiki
中查看所需的设置必需的设置
- authority(字符串):OIDC / OAuth2提供程序的URL。
根据错误和代码,您似乎没有设置权限