Asp .Net Core Razor 500 Http Ошибка при переходе на страницу входа - PullRequest
2 голосов
/ 20 марта 2019

Я начинаю со страниц бритвы, и я создал страницу входа в систему и использовал 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 для тестирования, но это все же странное поведение и происходит только при первом запуске проекта каждый день

...