这是我的第一个.net Core应用程序。并且有问题。问题是我正在为现有应用程序添加新模板而Google Console显示无法找到CSS和JS的错误
**
**
{
"ConnectionStrings": {
"DefaultConnection": "Server=.;Database=MusicSite;Trusted_Connection=True;MultipleActiveResultSets=true"
},
"Logging": {
"IncludeScopes": false,
"LogLevel": {
"Default": "Warning"
}
},
"dependencies": {
"bootstrap": "3.3.6",
"jquery": "2.2.0"
}
}
所有CSS和Js文件夹都包含在解决方案
中我在Console App中收到的错误
**
**
**
**
<!-- style -->
<link rel="stylesheet" href="css/animate.css/animate.min.css" type="text/css" />
<link rel="stylesheet" href="css/glyphicons/glyphicons.css" type="text/css" />
<link rel="stylesheet" href="css/font-awesome/css/font-awesome.min.css" type="text/css" />
<link rel="stylesheet" href="css/material-design-icons/material-design-icons.css" type="text/css" />
<link rel="stylesheet" href="css/bootstrap/dist/css/bootstrap.min.css" type="text/css" />
<!-- build:css css/styles/app.min.css -->
<link rel="stylesheet" href="css/styles/app.css" type="text/css" />
<link rel="stylesheet" href="css/styles/style.css" type="text/css" />
<link rel="stylesheet" href="css/styles/font.css" type="text/css" />
<link rel="stylesheet" href="libs/owl.carousel/dist/assets/owl.carousel.min.css" type="text/css" />
<link rel="stylesheet" href="libs/owl.carousel/dist/assets/owl.theme.css" type="text/css" />
<link rel="stylesheet" href="libs/mediaelement/build/mediaelementplayer.min.css" type="text/css" />
<link rel="stylesheet" href="libs/mediaelement/build/mep.css" type="text/css" />
<!-- endbuild -->
<script src="libs/jquery/dist/jquery.js"></script>
<!-- Bootstrap -->
<script src="libs/tether/dist/js/tether.min.js"></script>
<script src="libs/bootstrap/dist/js/bootstrap.js"></script>
<!-- core -->
<script src="libs/jQuery-Storage-API/jquery.storageapi.min.js"></script>
<script src="libs/jquery.stellar/jquery.stellar.min.js"></script>
<script src="libs/owl.carousel/dist/owl.carousel.min.js"></script>
<script src="libs/jscroll/jquery.jscroll.min.js"></script>
<script src="libs/PACE/pace.min.js"></script>
<script src="libs/jquery-pjax/jquery.pjax.js"></script>
<script src="libs/mediaelement/build/mediaelement-and-player.min.js"></script>
<script src="libs/mediaelement/build/mep.js"></script>
<script src="scripts/player.js"></script>
<script src="scripts/config.lazyload.js"></script>
<script src="scripts/ui-load.js"></script>
<script src="scripts/ui-jp.js"></script>
<script src="scripts/ui-include.js"></script>
<script src="scripts/ui-device.js"></script>
<script src="scripts/ui-form.js"></script>
<script src="scripts/ui-nav.js"></script>
<script src="scripts/ui-screenfull.js"></script>
<script src="scripts/ui-scroll-to.js"></script>
<script src="scripts/ui-toggle-class.js"></script>
<script src="scripts/ui-taburl.js"></script>
<script src="scripts/app.js"></script>
<script src="scripts/site.js"></script>
<script src="scripts/ajax.js"></script>
<!-- endbuild -->
**
**
namespace MusicSite
{
public class Startup
{
public Startup(IHostingEnvironment env)
{
var builder = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true);
if (env.IsDevelopment())
{
// For more details on using the user secret store see https://go.microsoft.com/fwlink/?LinkID=532709
builder.AddUserSecrets<Startup>();
}
builder.AddEnvironmentVariables();
Configuration = builder.Build();
}
public IConfigurationRoot Configuration { get; }
// 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.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddDefaultTokenProviders();
services.AddMvc();
// Add application services.
services.AddTransient<IEmailSender, AuthMessageSender>();
services.AddTransient<ISmsSender, AuthMessageSender>();
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
app.UseStaticFiles();
// Add MVC to the request pipeline.
app.UseMvc();
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
app.UseDatabaseErrorPage();
app.UseBrowserLink();
}
else
{
app.UseExceptionHandler("/Home/Error");
}
app.UseStaticFiles();
app.UseIdentity();
// Add external authentication middleware below. To configure them please see https://go.microsoft.com/fwlink/?LinkID=532715
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
}
}
}
答案 0 :(得分:13)
在ASP.NET核心中,默认情况下,静态文件仅从wwwroot
文件夹提供。这意味着如果您尝试从Libs
目录访问文件,它将无法正常工作。
好消息是,您可以根据需要配置静态文件位置。因此,请更新Configure
中的startup.cs
方法。
public void Configure(IApplicationBuilder app, IHostingEnvironment env,
ILoggerFactory loggerFactory)
{
// Your existing code goes here
app.UseStaticFiles();
// This will add "Libs" as another valid static content location
app.UseStaticFiles(new StaticFileOptions()
{
FileProvider = new PhysicalFileProvider(
Path.Combine(Directory.GetCurrentDirectory(), @"Libs")),
RequestPath = new PathString("/libs")
});
}
PhysicalFileProvider
类在Microsoft.Extensions.FileProviders
命名空间中定义。因此,您应该在Startup.cs
类中添加using语句。
using Microsoft.Extensions.FileProviders;
现在可以从yourSiteName/libs/somejsfile.js
访问这些文件。另外,使用~/
为这些脚本添加前缀。 tilda(~
)标志告诉它是app root。
<script src="~/libs/jquery/dist/jquery.js"></script>
正如我前面提到的,wwwroot
是一个特殊的文件夹,用于保存静态资产。因此,您也可以考虑将libs
目录移到wwwwroot
下,然后一切正常,没有上述自定义配置。