Проверка подлинности Windows в приложении .net Core 2.1 - PullRequest
0 голосов
/ 06 июня 2018

У меня есть приложение .net Core 2.1 MVC, в котором размещается приложение Angular 6.Я использую Visual Studio 2017 15.7.3.Я пытаюсь настроить проверку подлинности Windows, но у меня возникают проблемы.Я следовал документации, и мои Program.cs и Startup.cs приведены ниже:

Program.cs:

using Microsoft.AspNetCore.Server.HttpSys;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Logging;
using NLog.Web;
using System;

namespace CoreIV_Admin_Core
{
public class Program
{
    public static void Main(string[] args)
    {
        var logger = NLog.Web.NLogBuilder.ConfigureNLog("nlog.config").GetCurrentClassLogger();

        try
        {
            logger.Debug("init main");
            CreateWebHostBuilder(args).Build().Run();
        }
        catch (Exception ex)
        {
            //NLog: catch setup errors
            logger.Error(ex, "Stopped program because of exception");
            throw;
        }
        finally
        {
            // Ensure to flush and stop internal timers/threads before application-exit (Avoid segmentation fault on Linux)
            NLog.LogManager.Shutdown();
        }
    }

    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .UseStartup<Startup>()
            //.UseHttpSys(options =>
            //{
            //    options.Authentication.Schemes = AuthenticationSchemes.NTLM | AuthenticationSchemes.Negotiate;
            //    options.Authentication.AllowAnonymous = false;
            //})
            .ConfigureLogging(logging =>
            {
                logging.ClearProviders();
                logging.SetMinimumLevel(Microsoft.Extensions.Logging.LogLevel.Information);
            })
            .UseNLog(); // NLog: setup NLog for Dependency injection
}
}

Startup.cs:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Server.HttpSys;
using Microsoft.AspNetCore.SpaServices.Webpack;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.DependencyInjection.Extensions;

namespace CoreIV_Admin_Core
{
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.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.TryAddSingleton<IHttpContextAccessor, HttpContextAccessor>();

        services.AddAuthentication(HttpSysDefaults.AuthenticationScheme);

        services.AddMvc()
               .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
    }

    // 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();
            app.UseWebpackDevMiddleware(new WebpackDevMiddlewareOptions
            {
                HotModuleReplacement = true
            });
        }
        else
        {
            app.UseExceptionHandler("/Home/Error");
            app.UseHsts();
        }

        app.UseHttpsRedirection();

        app.UseStaticFiles();

        app.UseCookiePolicy();

        app.UseHttpContext();

        app.UseAuthentication();

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Home}/{action=Index}/{id?}");

            routes.MapSpaFallbackRoute(
                name: "spa-fallback",
                defaults: new
                {
                    controller = "Home",
                    action = "Index"
                });
        });
    }
 }
}

Если я раскомментирую раздел .UseHttpSys в program.cs и нажму кнопку воспроизведения в Visual Studio для отладки, он почти сразу остановит сеанс отладки, и в журнале событий появится следующая ошибка:

«Приложение»MACHINE / WEBROOT / APPHOST / myapp 'с физическим корнем' C: \ Users \ me \ myapp 'создал процесс с командной строкой' C: \ Program Files (x86) \ Microsoft Visual Studio \ 2017 \ Professional \ Common7 \ IDE \ Extensions \ Microsoft\ Web Tools \ ProjectSystem \ VSIISExeLauncher.exe -argFile "C: \ Users \ me \ AppData \ Local \ Temp \ tmpFCA6.tmp" ", но не удалось прослушать указанный порт '28353'".

Если я попытаюсь с .UseHttpSys закомментированным, отладка работает, но я не могу быть должным образом аутентифицирован.

1 Ответ

0 голосов
/ 07 июня 2018

Камило, спасибо за ваш комментарий, он помог направить меня в правильном направлении.Я удалил раздел UseHttpSys из program.cs и добавил .UseIISIntegration().Я также изменил services.AddAuthentication(HttpSysDefaults.AuthenticationScheme) на services.AddAuthentication(IISDefaults.AuthenticationScheme) в моем startup.cs.Затем я поставил галочку Enable Windows Authentication в разделе «Отладка» свойств проекта и выбрал «IIS Express» для запуска, и все заработало.Я новичок в .net core с Windows-аутентификацией, поэтому я не знаю, правильно ли я все настроил, но это работает, и, надеюсь, этот пост поможет указать другим в правильном направлении.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...