C# · 12月 26, 2021

c# – ASP.NET MVC 4如何使用自定义的memberprovider和roleprovider实现Oauth

经过大量的搜索和大量的尝试,我完成了如何让人们在我的网站上注册和登录(并给予他们角色等等).我从类ExtendedMembershipProvider和RoleProvider继承,为他们做了一个customclass,但现在我仍然有问题使Oauth工作(主要是OpenID).我在AuthConfig中注册了GoogleClient,但是一旦我尝试登录,并且它出现在(在AccountController.cs中): if (OAuthWebSecurity.Login(result.Provider,result.ProviderUserId,createPersistentCookie: false))

然后它说尚未实现,现在我检查了扩展成员资格,我可以覆盖登录(因为它不在那里,但它在哪里).我也搜索google很多,但没有运气,任何使oauth工作的指示将是汗水(我想我需要做一个第3个CustomOathprovider,但我不能找到继承自)!

PS:我做了一个custommembershiprpovder和customroleprovider,因为我想使用一个不同的数据库方案.

格言

解决方法 我不得不在我的自定义成员提供者中覆盖3个更多的方法 public override void CreateOrUpdateOAuthAccount(string provider,string providerUserId,string userName)public override int GetUserIdFromOAuth(string provider,string providerUserId)//return -1 if User got no OauthAccountpublic override string GetUserNameFromId(int userId)

现在它正在工作. (我通过覆盖会员提供程序中的所有方法,然后在每个位置设置一个断点,并且在任何地方,我根据我的自定义数据库填充了方法.