经过大量的搜索和大量的尝试,我完成了如何让人们在我的网站上注册和登录(并给予他们角色等等).我从类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)
现在它正在工作. (我通过覆盖会员提供程序中的所有方法,然后在每个位置设置一个断点,并且在任何地方,我根据我的自定义数据库填充了方法.