«Конфигурация config = новая конфигурация»: «Конфигурация» является пространством имен, но используется как тип

#c# #visual-studio #.net-core #jaeger #ocelot

#c# #visual-studio #.net-core #jaeger #ocelot

Вопрос:

очень новичок в .net, и это кажется простым вопросом.

Пытаюсь заставить этот код работать с веб-сайта Jaeger: https://ocelot.readthedocs.io/en/latest/features/tracing.html

 services.AddSingleton<ITracer>(sp =>
{
    var loggerFactory = sp.GetService<ILoggerFactory>();
    Configuration config = new Configuration(context.HostingEnvironment.ApplicationName, loggerFactory);

    var tracer = config.GetTracer();
    GlobalTracer.Register(tracer);
    return tracer;
});

services
    .AddOcelot()
    .AddOpenTracing();
  

в файле startup.cs в разделе ConfigureServices. Я добавил правильные ссылки, но получаю ошибку с:

 Configuration config = new Configuration(context.HostingEnvironment.ApplicationName, loggerFactory);
  

Visual studio продолжает жаловаться:

«Конфигурация» — это пространство имен, но используется как тип

Любые идеи о том, как исправить.

Вот что у меня есть при запуске до сих пор:

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Configuration;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Ocelot;
using Ocelot.DependencyInjection;
using Ocelot.Middleware;
using Ocelot.Provider.Consul;
using Microsoft.Identity.Web;
using Microsoft.Extensions.Configuration;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.Identity.Web.TokenCacheProviders.InMemory;
using System.Text;
using Microsoft.IdentityModel.Tokens;
using Microsoft.OpenApi.Models;
using Ocelot.Logging;
using OpenTracing.Noop;
using OpenTracing.Propagation;
using OpenTracing.Util;
using Ocelot.Tracing.OpenTracing;

namespace Ocelot.Demo1
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            _Configuration = configuration;
        }

        public ILoggerFactory _loggerFactory;

        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.AddCors(options =>
            {
                options.AddDefaultPolicy(
                    builder =>
                    {
                        // builder.WithOrigins("http://localhost:5200");
                        builder.WithOrigins("http://localhost:5200")
                    .AllowAnyMethod()
                    .AllowAnyHeader()
                    .AllowCredentials();
                    });
            });

            // Azure AD
            services.Configure<JwtBearerOptions>(JwtBearerDefaults.AuthenticationScheme, jwtOptions => {
                jwtOptions.Audience = "RANDOM TOKEN VALUE";
                jwtOptions.Authority = "https://login.microsoftonline.com/YOUR_MS_DOMIAN/";
                jwtOptions.RequireHttpsMetadata = false;
                jwtOptions.Events = new JwtBearerEvents { OnAuthenticationFailed = AuthenticationFailed, OnTokenValidated = AuthenticationTokenValidated };
                jwtOptions.TokenValidationParameters.ValidIssuer = "https://login.microsoftonline.com/RANDOM TOKEN VALUE/v2.0";
            });


            services.Configure<JwtBearerOptions>(JwtBearerDefaults.AuthenticationScheme, jwtOptions => {
                jwtOptions.Events = new JwtBearerEvents { OnAuthenticationFailed = AuthenticationFailed, OnTokenValidated = AuthenticationTokenValidated };
            });

            services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer();
            //.AddMicrosoftIdentityWebApi(Configuration,"AzureAD");
            // services.AddProtectedWebApi(Configuration).AddProtectedApiCallsWebApis(Configuration).AddInMemoryTokenCaches();


            services.AddSingleton<ITracer>(sp =>
            {
                var loggerFactory = sp.GetService<ILoggerFactory>();
                Configuration config = new Configuration("Ocelot API Gateway", loggerFactory);

                var tracer = config.GetTracer();
                GlobalTracer.Register(tracer);
                return tracer;
            });


            // Call Ocelot
            services.AddOcelot(_Configuration)
            .AddOpenTracing();
            services.AddControllers();
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseHttpsRedirection();
            app.UseRouting();

            app.UseCors();

            app.UseAuthorization();
            app.UseAuthentication();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
            app.UseOcelot().Wait();

        }

        private Task AuthenticationFailed(AuthenticationFailedContext arg)
        {
            // For debugging purposes only!
            var s = $"AuthenticationFailed: {arg.Exception.Message}";
            arg.Response.ContentLength = s.Length;
            //arg.Response.Body.Write(System.Text.Encoding.UTF8.GetBytes(s), 0, s.Length);
            return Task.FromResult(0);
        }

        private Task AuthenticationTokenValidated(TokenValidatedContext arg)
        {
            // For debugging purposes only!
            var s = $"AuthenticationTokenValidated: {arg.Result}";
            return Task.FromResult(0);
        }
    }
}
  

Ответ №1:

вы используете System.Пространство имен конфигурации, которое вызывает двусмысленность.

я бы предложил удалить используемую систему.Конфигурация. И попробуйте указать полное имя для конфигурации. visual studio предложит возможные кандидаты (нажмите Ctrl . для имени класса, которое вы хотите указать) при условии, что вы уже добавили все необходимые ссылки в проект.

Комментарии:

1. Я удалил его, и у него все еще была та же проблема

Ответ №2:

Если у вас есть

 using System;
  

тогда компилятор C # путается Configuration и думает, что это относится к пространству System.Configuration имен . Вы можете решить эту проблему, используя явное пространство имен Jaeger :

 var config = new Jaeger.Configuration(
    context.HostingEnvironment.ApplicationName, loggerFactory);
  

Комментарии:

1. Когда я меняю его на следующий код, я получаю следующее: невозможно неявно преобразовать тип ‘OpenTracing. ITracer’ to ‘Ocelot. Ведение журнала. ITracer’. Существует явное преобразование (вам не хватает приведения?)

2. Я не знаю этих библиотек, но, похоже, это два разных типа, которые случайно имеют одно и то же имя (находясь в другом пространстве имен). Вы могли бы решить проблему, написав оболочку для одной ITracer реализации другой ITracer , если вы хотите смешать две несовместимые библиотеки.

3. есть идеи, как это будет выглядеть?

4.См .: Шаблоны оболочек в C #, часть IV: шаблон адаптера.