c# – PasswordSignInAsync()成功后,User.Identity.IsAuthenticated为false
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – PasswordSignInAsync()成功后,User.Identity.IsAuthenticated为false,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3667字,纯文字阅读大概需要6分钟。
内容图文
![c# – PasswordSignInAsync()成功后,User.Identity.IsAuthenticated为false](/upload/InfoBanner/zyjiaocheng/768/2e969f9d6dad42e9bd226e4fc115c017.jpg)
该问题涉及ASP.NET Core 2.0中的身份验证.
在PasswordSignInAsync()之后,结果的状态为success.所以我在StaticController中重定向到动作聊天.
[HttpPost("login")]
public async Task<ActionResult> Login([Bind] LoginModel lm) {
if (!ModelState.IsValid)
return BadRequest(ModelState);
var result = await _signInManager.PasswordSignInAsync(lm.Username, lm.Password, false, false);
if (result.Succeeded)
return RedirectToAction("Login", "Static");
else
return BadRequest(new { message = "Invalid username or password" });
}
StaticController.Chat()
[HttpGet("/chat")]
public ActionResult Chat() {
if (User.Identity.IsAuthenticated)
return File("~/chat/index.html", "text/html");
else
return RedirectToAction("Login", "Static");
}
这里出现问题是因为User.Identity.IsAuthenticated始终为false.即使执行Login()操作后我从浏览器localhost:5000 / chat调用它仍然是假的.
这些是我发现的相关解决方案,但它们都不起作用:
这个解决方案已经过时了.我使用的是ASP.NET Core 2.0,而UseCookieAuthentication()已经过时了.
User.Identity.IsAuthenticated always false after PasswordSignInAsync gives success
正如它在Login()操作后在07解决方案中所述,我应该再次调用Chat()方法(就像我在localhost:5000 / chat中所做的那样),它应该可以工作.那么问题是它没有.
这是我的Startup.cs:
public class Startup
{
public IConfiguration Configuration { get; }
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
services.AddDbContext<ApplicationDbContext>(options => {
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"));
});
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddDefaultTokenProviders();
services.Configure<IdentityOptions>(options => {
// Password settings
options.Password.RequireDigit = true;
options.Password.RequiredLength = 6;
options.Password.RequireNonAlphanumeric = false;
options.Password.RequireUppercase = false;
options.Password.RequireLowercase = false;
// User settings
options.User.RequireUniqueEmail = true;
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseStaticFiles();
app.UseMvc();
app.UseAuthentication();
}
}
请帮忙.
解决方法:
这是我的startup.cs
public class Startup
{
public IConfiguration Configuration { get; private set; }
public Startup(IHostingEnvironment env)
{
var config = new ConfigurationBuilder()
.AddJsonFile("config.json", optional: true)
.SetBasePath(env.ContentRootPath)
.Build();
Configuration = config;
}
public void ConfigureServices(IServiceCollection services)
{
services.ConfigureDataContext(Configuration);
services.AddIdentity<ApplicationUser, IdentityRole>(p =>
{
p.Password.RequireDigit = false;
p.Password.RequireLowercase = false;
p.Password.RequireUppercase = false;
p.Password.RequireNonAlphanumeric = false;
})
.AddEntityFrameworkStores<MyShuttleContext>()
.AddDefaultTokenProviders();
services.ConfigureDependencies();
services.AddMvc();
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
app.UseStaticFiles();
app.UseAuthentication();
app.ConfigureRoutes();
}
}
这是我的config.json
{
"DefaultUsername": "carrier",
"DefaultPassword": "******",
"Data": {
"UseInMemoryStore": "false",
"DefaultConnection": {
"ConnectionString": "Server=(localdb)\\MSSQLLocalDB;Database=MyShuttle;Trusted_Connection=True;MultipleActiveResultSets=true"
}
},
"EntityFramework": {
"MyShuttleContext": {
"ConnectionStringKey": "Data:DefaultConnection:ConnectionString"
}
}
}
我的控制器代码与您的相同.我对这段代码没有任何问题.您可以尝试检查SQL Server对象资源管理器以检查表是否正确填充.
内容总结
以上是互联网集市为您收集整理的c# – PasswordSignInAsync()成功后,User.Identity.IsAuthenticated为false全部内容,希望文章能够帮你解决c# – PasswordSignInAsync()成功后,User.Identity.IsAuthenticated为false所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。