oidc-client.js引发“未通过权限”错误

时间:2018-09-04 09:35:59

标签: javascript vue.js single-sign-on oidc oidc-client-js

我是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环境下运行代码。但是我认为这不会引起问题。如果您遇到了类似的问题,请告诉我如何解决。谢谢。

1 个答案:

答案 0 :(得分:0)

https://github.com/IdentityModel/oidc-client-js/wiki

中查看所需的设置
  

必需的设置

     
      
  • authority(字符串):OIDC / OAuth2提供程序的URL。
  •   

根据错误和代码,您似乎没有设置权限