Я начинаю со страниц бритвы, и я создал страницу входа в систему и использовал ldap для аутентификации и входа в систему. У меня по-прежнему нет возможности выхода из системы.Я хочу, чтобы логин был страницей по умолчанию, поэтому я удалил каждую отдельную страницу по умолчанию из шаблона бритвы, но ошибка оставила логин только
Pages
Account Folder
Login page
Проблема - после входа в систему, теперь всякий раз, когда я пытаюсьдоступ к странице входа дает мне эту ошибку
Ошибка HTTP 500.0 - сбой загрузки обработчика ANCM Распространенные причины этой проблемы: указанная версия Microsoft.NetCore.App или Microsoft.AspNetCore.App былане найдено.Обработчик запроса в процессе, Microsoft.AspNetCore.Server.IIS, не был указан в приложении.ANCM не смог найти дотнет.Действия по устранению неполадок: проверьте наличие в системном журнале событий сообщений об ошибках. Включите ведение журнала сообщений процесса приложения. Присоедините отладчик к процессу приложения и проверьте. Для получения дополнительной информации посетите страницу: https://go.microsoft.com/fwlink/?LinkID=2028526
Я не смог найтичто-нибудь об этой ошибке происходит только на одной странице, только о IIS.
Это происходит только на странице входа в систему, я могу нормально обращаться к другим страницам ...
Вот код на моей странице входа в систему
@page
@model GestaoRequisicoes.Pages.LoginModel
@{
ViewData["Title"] = "Login";
}
<h1>Login</h1>
<p>Autentique-se para iniciar sessão:</p>
<form method="post">
<div class="container">
<div class="row">
<div class="col-md-12">
<div class="form-group">
<div asp-validation-summary="All" class="text-danger"></div>
<label for="exampleInputPassword1">Username</label>
<input asp-for="loginData.Username" value="username" class="form-control form-control-sm" />
</div>
<div class="form-group">
<label for="exampleInputPassword1">Password</label>
<input asp-for="loginData.Password" value="password" class="form-control form-control-sm" />
</div>
<div class="form-group form-check">
<input id="txtRememberMe" asp-for="loginData.RememberMe" type="checkbox" class="form-check-input" />
<label class="form-check-label" for="txtRememberMe">Remember me</label>
</div>
<input type="submit" value="Login" class="btn btn-primary" />
</div>
</div>
</div>
@Html.AntiForgeryToken()
</form>
и CS-файл
public class LoginModel : PageModel
{
[BindProperty]
public LoginData loginData { get; set; }
public void OnGet()
{
}
public async Task<IActionResult> OnPostAsync()
{
if (ModelState.IsValid)
{
string dominio = "10.35.14.240/OU=Users,OU=PLG,OU=PT,OU=EMEA,DC=sd6,DC=glb,DC=corp,DC=local";
string adPath = "LDAP://" + dominio;
LDAPAutenticador aut = new LDAPAutenticador(adPath);
var isValid = aut.autenticado(dominio, loginData.Username, loginData.Password);
if (!isValid)
{
ModelState.AddModelError("", "username or password is invalid");
return Page();
}
else
{
var identity = new ClaimsIdentity(CookieAuthenticationDefaults.AuthenticationScheme, ClaimTypes.Name, ClaimTypes.Role);
identity.AddClaim(new Claim(ClaimTypes.NameIdentifier, loginData.Username));
identity.AddClaim(new Claim(ClaimTypes.Name, loginData.Username));
var principal = new ClaimsPrincipal(identity);
await HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, principal, new AuthenticationProperties { IsPersistent = loginData.RememberMe });
return RedirectToPage("Account/Index");
}
}
else
{
ModelState.AddModelError("", "username or password is blank");
return Page();
}
}
public class LoginData
{
[Required]
[StringLength(8)]
public string Username { get; set; }
[Required, DataType(DataType.Password)]
public string Password { get; set; }
public bool RememberMe { get; set; }
}
}
и файл запуска
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.AddAuthentication(options =>
{
options.DefaultSignInScheme = CookieAuthenticationDefaults.AuthenticationScheme;
options.DefaultAuthenticateScheme = CookieAuthenticationDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = CookieAuthenticationDefaults.AuthenticationScheme;
}).AddCookie(options => { options.LoginPath = "/Login"; });
services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
services.AddMvc().AddRazorPagesOptions(options =>
{
options.Conventions.AuthorizeFolder("/Account");
options.Conventions.AllowAnonymousToPage("/Login");
}).SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseCookiePolicy();
app.UseAuthentication();
app.UseMvc();
}
}
ОБНОВЛЕНИЕ
Это былоНекоторое время, но если кто-то замечает какую-то ошибку, просто проверьте окно просмотра событий Windows, и оно сообщит вам об ошибке.Сообщение было связано с исключением тайм-аута пула соединений с Entity Framework.Я предполагаю, что Entity Framework просто не смог подключиться к SQL Server, пока я не обновил базы данных в проводнике SQL Server, возможно потому, что я использую экземпляр localdb \ mssqlserver для тестирования, но это все же странное поведение и происходит только при первом запуске проекта каждый день