ZCo*_*der 6 asp.net-core-mvc asp.net-core
这是我的第一个.net核心应用程序.并且有问题.问题是我正在为现有应用程序和Google控制台添加新模板,显示无法找到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"
}
}
Run Code Online (Sandbox Code Playgroud)
所有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 -->
Run Code Online (Sandbox Code Playgroud)
**
**
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?}");
});
}
}
}
Run Code Online (Sandbox Code Playgroud)
Shy*_*yju 16
在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")
});
}
Run Code Online (Sandbox Code Playgroud)
该PhysicalFileProvider班在定义Microsoft.Extensions.FileProviders命名空间.所以你应该在你的Startup.cs类中添加一个using语句.
using Microsoft.Extensions.FileProviders;
Run Code Online (Sandbox Code Playgroud)
现在可以从中访问文件yourSiteName/libs/somejsfile.js.另外,在这些脚本的路径前加上~/.tilda(~)符号告诉它是应用程序根目录.
<script src="~/libs/jquery/dist/jquery.js"></script>
Run Code Online (Sandbox Code Playgroud)
正如我前面提到的,这wwwroot是一个特殊的文件夹,用于保存静态资产.所以你也可以考虑移动你的libs目录wwwwroot,然后一切都应该工作正常,没有上面提到的自定义配置.
| 归档时间: |
|
| 查看次数: |
12692 次 |
| 最近记录: |