我正试图在我的ASP.NET核心2.0应用程序中实现LinkedIn/OAuth身份验证,我需要将范围设置为{ "r_basicprofile", "r_emailaddress" }
,以便我可以使用用户的电子邮件、配置文件图像等。
当我试图在下面的代码中设置范围时,我会得到以下错误:
属性或索引器'OAuthOptions.Scope‘不能分配给--它是只读的。
下面是代码:
services.AddOAuth(CookieAuthenticationDefaults.AuthenticationScheme, options => {
options.SignInScheme = "LinkedIn";
options.ClientId = "1234567890";
options.ClientSecret = "1234567890";
options.CallbackPath = "/linkedin-callback";
// Configure the LinkedIn endpoints
options.AuthorizationEndpoint = "https://www.linkedin.com/oauth/v2/authorization",
options.TokenEndpoint = "https://www.linkedin.com/oauth/v2/accessToken",
options.UserInformationEndpoint = "https://api.linkedin.com/v1/people/~:(id,first-name,last-name,email-address,picture-url,picture-urls::(original))",
options.Scope = { "r_basicprofile", "r_emailaddress" };
options.Events = new OAuthEvents
{
OnCreatingTicket = OnCreatingTicketLinkedInCallBack,
OnTicketReceived = OnTicketReceivedCallback
};
})
知道我该怎么设置范围吗?
我试图修改我的ASP.NET核心1.1中的代码。这段代码在ASP.NET Core1.1应用程序中运行良好。
发布于 2017-08-19 22:57:33
只有在使用对象初始化时,Scope = { "r_basicprofile", "r_emailaddress" }
语法才可用。在这里,options
对象不是从代码中实例化的,而是由ASP.NET Core直接提供的,因此您不能使用这个语法。
好消息是,Scope
属性是一个集合(在内部是一个哈希集),因此您可以简单地这样做:
options.Scope.Add("r_basicprofile");
options.Scope.Add("r_emailaddress");
如果您想摆脱默认的作用域,可以使用options.Scope.Remove("scope")
或options.Scope.Clear()
删除它们。
https://stackoverflow.com/questions/45776947
复制相似问题