Ссылка браузера основных веб-приложений не работает в проекте asp mvc 6

Я пытаюсь заставить работать ссылку браузера, чтобы я мог использовать панель инструментов веб-основы в браузере. Я ожидаю увидеть некоторый код, введенный в нижней части исходного кода страницы для ссылки на браузер, как в проектах ASP.NET 4, но, похоже, это не относится к ASP.NET 5.

введите здесь описание изображения

Кому-нибудь еще удалось заставить это работать? Заранее спасибо за любую помощь.

Я использую визуальную студию 2015, обновление 1.

Я пробовал работать в режиме администратора и отключил брандмауэр, но по-прежнему нет подключений в ссылке браузера в Visual Studio при работе в режиме отладки.

Изменить

Этот метод определенно называется

app.UseBrowserLink();

Этот пакет nuget определенно упоминается Microsoft.VisualStudio.Web.BrowserLink.Loader

Я попытался переустановить asp.net 5 rc1 и Visual Studio 2015 Pro, а также использовать сообщество Visual Studio, которое тоже не работает.

Я пытался переустановить IIS Express 10 и 8, но это тоже не работает.

Это начинает быть настоящей болью. Использование F12 в браузере делает работу, но это очень медленно и утомительно.

если кто-нибудь может предложить что-то, чтобы попытаться заставить это работать, это было бы здорово. Я чувствую, что исчерпал все варианты.

Вот мой проект.json:

{
  "userSecretsId": "aspnet5-BusiHub.Web-ce0683d8-2598-4feb-99b6-82d6cf4e8028",
  "version": "1.0.0-*",
  "compilationOptions": {
    "emitEntryPoint": true
  },

  "dependencies": {
    "EntityFramework.Commands": "7.0.0-rc1-final",
    "EntityFramework.MicrosoftSqlServer": "7.0.0-rc1-final",
    "Microsoft.AspNet.Authentication.Cookies": "1.0.0-rc1-final",
    "Microsoft.AspNet.Diagnostics.Entity": "7.0.0-rc1-final",
    "Microsoft.AspNet.Identity.EntityFramework": "3.0.0-rc1-final",
    "Microsoft.AspNet.IISPlatformHandler": "1.0.0-rc1-final",
    "Microsoft.AspNet.Loader.IIS": "1.0.0-beta7",
    "Microsoft.AspNet.Loader.IIS.Interop": "1.0.0-beta7",
    "Microsoft.AspNet.Mvc": "6.0.0-rc1-final",
    "Microsoft.AspNet.Mvc.TagHelpers": "6.0.0-rc1-final",
    "Microsoft.AspNet.Server.Kestrel": "1.0.0-rc1-final",
    "Microsoft.AspNet.StaticFiles": "1.0.0-rc1-final",
    "Microsoft.AspNet.Tooling.Razor": "1.0.0-rc1-final",
    "Microsoft.AspNet.WebApi": "5.2.3",
    "Microsoft.Extensions.CodeGenerators.Mvc": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.FileProviderExtensions": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.Json": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.UserSecrets": "1.0.0-rc1-final",
    "Microsoft.Extensions.Logging": "1.0.0-rc1-final",
    "Microsoft.Extensions.Logging.Console": "1.0.0-rc1-final",
    "Microsoft.Extensions.Logging.Debug": "1.0.0-rc1-final",
    "Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0-rc1-final",
    "System.Web.Optimization.Less": "1.3.4"
  },

  "commands": {
    "web": "Microsoft.AspNet.Server.Kestrel",
    "ef": "EntityFramework.Commands"
  },

  "frameworks": {
    "dnx451": {
      "frameworkAssemblies": { }
    }
  },

  "exclude": [
    "wwwroot",
    "node_modules"
  ],

  "publishExclude": [
    "**.user",
    "**.vspscc"
  ],

  "scripts": {
    "prepublish": [ "npm install", "bower install", "gulp clean", "gulp min" ]
  }
}

Вот мой startup.cs

public class Startup
{
    public Startup(IHostingEnvironment env)
    {
        // Set up configuration sources.
        var builder = new ConfigurationBuilder()
            .AddJsonFile("appsettings.json")
            .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true);

        if (env.IsDevelopment())
        {
            // For more details on using the user secret store see http://go.microsoft.com/fwlink/?LinkID=532709
            builder.AddUserSecrets();
        }

        builder.AddEnvironmentVariables();
        Configuration = builder.Build();
    }

    public IConfigurationRoot Configuration { get; set; }

    // This method gets called by the runtime. Use this method to add services to the container.
    public void ConfigureServices(IServiceCollection services)
    {
        // Add framework services.
        services.AddEntityFramework()
            .AddSqlServer()
            .AddDbContext<ApplicationDbContext>(options =>
                options.UseSqlServer(Configuration["Data:DefaultConnection:ConnectionString"]));

        services.AddIdentity<ApplicationUser, IdentityRole>()
            .AddEntityFrameworkStores<ApplicationDbContext>()
            .AddDefaultTokenProviders();

        services.AddMvc();

        // Add application services.
        services.AddTransient<IEmailSender, AuthMessageSender>();
        services.AddTransient<ISmsSender, AuthMessageSender>();

        services.AddTransient<ApplicationDbContextInitializer>();
    }

    // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
    public async void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory, ApplicationDbContextInitializer dbContextInitializer)
    {
        loggerFactory.AddConsole(Configuration.GetSection("Logging"));
        loggerFactory.AddDebug();

        if (env.IsDevelopment())
        {
            // Allow updates to your files in Visual Studio to be shown in the browser. You can use the Refresh 
            // browser link button in the Visual Studio toolbar or Ctrl+Alt+Enter to refresh the browser.
            app.UseBrowserLink();

            app.UseDeveloperExceptionPage();
            app.UseDatabaseErrorPage();
        }
        else
        {
            app.UseExceptionHandler("/Home/Error");

            // For more details on creating database during deployment see http://go.microsoft.com/fwlink/?LinkID=615859
            try
            {
                using (var serviceScope = app.ApplicationServices.GetRequiredService<IServiceScopeFactory>()
                    .CreateScope())
                {
                    serviceScope.ServiceProvider.GetService<ApplicationDbContext>()
                         .Database.Migrate();
                }
            }
            catch { }
        }

        app.UseIISPlatformHandler(options => options.AuthenticationDescriptions.Clear());

        app.UseStaticFiles();

        app.UseIdentity();

        // To configure external authentication please see http://go.microsoft.com/fwlink/?LinkID=532715

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

        // Seed the database with sample data - admin roles, admin users etc
        await dbContextInitializer.InitializeDataAsync();
    }

    // Entry point for the application.
    public static void Main(string[] args) => WebApplication.Run<Startup>(args);
}

Обновить

Я установил плагин livereload для chrome и настроил livereload в gulp, как это было предложено в комментарии ниже от vendettamit. Браузер Chrome теперь обновляется, когда я изменяю файлы CSS/Less. Мне все еще не хватает веб-инструментов для проектирования и проверки из-за того, что ссылка на браузер не работает, но я надеюсь, что это изменится в будущих обновлениях платформы ASP.NET и/или визуальной студии.

мой скрипт для глотка, если кто-то наткнется на эту же проблему:

    /// <binding BeforeBuild='min, less' Clean='clean' />
"use strict";

var gulp = require("gulp"),
    rimraf = require("rimraf"),
    concat = require("gulp-concat"),
    cssmin = require("gulp-cssmin"),
    uglify = require("gulp-uglify"),
    less = require("gulp-less"),
    livereload = require("gulp-livereload");

var project = require('./project.json');

var paths = {
    webroot: "./wwwroot/"
};

paths.js = paths.webroot + "js/**/*.js";
paths.minJs = paths.webroot + "js/**/*.min.js";
paths.css = paths.webroot + "css/**/*.css";
paths.minCss = paths.webroot + "css/**/*.min.css";
paths.concatJsDest = paths.webroot + "js/site.min.js";
paths.concatCssDest = paths.webroot + "css/site.min.css";

gulp.task("clean:js", function (cb) {
    rimraf(paths.webroot + "/js/site.min.js", cb);
    rimraf(paths.webroot + "/js/site.js", cb);
});

gulp.task("clean:css", function (cb) {
    rimraf(paths.webroot + "/css/site.min.css", cb);
    rimraf(paths.webroot + "/css/site.css", cb);
});

gulp.task("clean", ["clean:js", "clean:css"]);

gulp.task("min:js", function () {
    return gulp.src([paths.js, "!" + paths.minJs], { base: "." })
        .pipe(concat(paths.concatJsDest))
        .pipe(uglify())
        .pipe(gulp.dest("."));
});

gulp.task("min:css", function () {
    return gulp.src([paths.css, "!" + paths.minCss])
        .pipe(concat(paths.concatCssDest))
        .pipe(cssmin())
        .pipe(gulp.dest("."));
});

gulp.task("min", ["min:js", "min:css"]);

gulp.task("less", ["clean:css"], function () {
    return gulp.src('Styles/*.less')
        .pipe(concat('site.less'))
        .pipe(less())
        .pipe(gulp.dest(paths.webroot + '/css'))
        .pipe(livereload());
});

gulp.task("scripts", ["clean:js"], function() {
    return gulp.src('Scripts/*.js')
        .pipe(concat('site.js'))
        .pipe(gulp.dest(paths.webroot + '/js'));
});

gulp.task("all", ["less", "scripts"]);

gulp.task('watch', function() {
    livereload.listen();
    gulp.watch('styles/*less', ['less']);
});

person Adam H    schedule 28.12.2015    source источник
comment
Я не уверен, что Live reload поставляется с RC-версией. Была проблема, посвященная аналогичной проблеме со ссылкой на браузер. А пока вы можете попробовать это   -  person vendettamit    schedule 29.12.2015
comment
Вы также можете попробовать данное решение здесь, но похоже, что это ручное обновление.   -  person vendettamit    schedule 29.12.2015
comment
Спасибо, обязательно попробую настроить. Это было бы намного быстрее, чем использование окна F12. Причина, по которой мне нравится использовать веб-предметы первой необходимости, заключается в том, что дизайн и проверка на панели инструментов требуют подключения по ссылке в браузере. По какой-то причине я не могу заставить это работать?   -  person Adam H    schedule 30.12.2015
comment
@vendettamit, если вы опубликуете это как ответ, я отмечу его как правильный. Я думаю, что ссылка на браузер связана с фреймворком asp.net 5.   -  person Adam H    schedule 30.12.2015


Ответы (1)


Я не уверен, что Live reload поставляется с RC-версией. Была проблема, связанная с аналогичной проблемой со ссылкой на браузер. А пока вы можете попробовать этот плагин Chrome для перезагрузки в реальном времени.

Вы также можете попробовать данное решение здесь, но похоже, что это ручное обновление.

person vendettamit    schedule 30.12.2015