微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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 OauthAccount

public override string GetUserNameFromId(int userId)

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

原文地址:https://www.jb51.cc/csharp/92703.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐