83

随着Asp .Net Core的升级迭代,很多开发者都逐渐倾向于.net core开发。

.net core是一个跨平台的应用程序,可以在windows、Linux、macOS系统上进行开发和部署,是一个体系结构更精简模块化框架。

生成WebUi和WebApi的统一使用场景;
集成新的客户端框架和开发工作流;
前后端分离为两个dll(view.dll,web.dll),更容易迭代,可以使用应用版本控制;
内置依赖注入,更高效安全;
高性能模块化的HTTP请求管道;
能够在iis,nginx,apache,docker上进行托管;
web开发方式更简化;

释语

ASP.Net Core接收并处理的大部分是针对静态文件的请求,最常见的是JavaScript、CSS样式和图片。

比较有意思的是,他提供了中间件来处理针对于静态文件的请求,这种请求可以通过http请求的方式获取指定的物理文件,并且将其所在的物理目录结构展示出来。

通过http请求获取的web资源大部分来源于存储在服务器磁盘上的静态文件。

为什么使用静态文件服务器?因为这样不需要安装web服务器,打开程序即可使用,方便快捷。

详解

说了这么多,我们来实际操作一下:

使用的是 StaticFiles 中间件。

我们先创建一个Asp .Net Core Web应用程序,操作方式如下:

1、创建一个名为NetCoreFileServer的项目,选择web引用程序,相应的中间件会自动加载进来

选择Web引用程序

发布物理文件

创建项目后,在wwwroot 文件夹下创建一个图片文件夹,添加一行图片,然后将程序运行起来,

网址直接导航到图片:http://localhost:10610/img/Lighthouse.jpg

默认的话只能访问wwwroot文件夹下面的文件,如果需要访问非wwwroot文件下的文件,就需要在中间件中扩展一下;

打开Startup.cs,找到 Configure 方法,在app.UseStaticFiles();后面添加一个扩展方法,如下标红部分:

复制代码
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Home/Error");
}

        app.UseStaticFiles();
        app.UseCookiePolicy();

        //这是添加的扩张方法
        //设置访问文件
        app.UseStaticFiles(new StaticFileOptions
        {
            //配置除了默认的wwwroot文件中的静态文件以外的文件夹提供 Web 根目录外的文件 ,
            //经过此配置以后,就可以访问非wwwroot文件下的文件
            FileProvider = new PhysicalFileProvider(
              Path.Combine(Directory.GetCurrentDirectory(), "Image")),
            RequestPath = "/Image",
        });

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Home}/{action=Index}/{id?}");
        });
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

复制代码
然后访问一下非wwwroot文件夹下的文件,http://localhost:10610/Image/Hydrangeas.jpg

这样就能正常访问文件了,其html文件等访问方式一样的操作。

静态文件服务器

按照类似的方式,我们来做一下静态文件的访问;

同理,我们需要在Startup.cs中找到 Configure 方法,在app.UseStaticFiles();后面添加一个扩展方法,如下标红部分:

复制代码
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Home/Error");
}

        app.UseStaticFiles();
        app.UseCookiePolicy();

        //这是添加的扩张方法
        //设置访问文件
        app.UseStaticFiles(new StaticFileOptions
        {
            //配置除了默认的wwwroot文件中的静态文件以外的文件夹提供 Web 根目录外的文件 ,
            //经过此配置以后,就可以访问非wwwroot文件下的文件
            FileProvider = new PhysicalFileProvider(
              Path.Combine(Directory.GetCurrentDirectory(), "Image")),
            RequestPath = "/Image",
        });

        //配置访问指定文件磁盘
        var dir = new DirectoryBrowserOptions();
        dir.FileProvider = new PhysicalFileProvider(@"E:");
        app.UseDirectoryBrowser(dir);
        var staticfile = new StaticFileOptions();
        staticfile.FileProvider = new PhysicalFileProvider(@"E:");//指定目录 这里指定E盘,也可以是其它目录            
        app.UseStaticFiles(staticfile);

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Home}/{action=Index}/{id?}");
        });
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

复制代码

配置好后启动程序进行访问得到目录,点击指定文件即可访问

这样我们就能浏览指定磁盘的文件了。

你会发现有些文件打开会404,有些又可以打开。那是因为MIME 没有识别出来。

我们可以手动设置这些 MIME ,也可以给这些未识别的设置一个默认值,如下标红部分。

复制代码
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Home/Error");
}

        app.UseStaticFiles();
        app.UseCookiePolicy();

        //这是添加的扩张方法
        //设置访问文件
        app.UseStaticFiles(new StaticFileOptions
        {
            //配置除了默认的wwwroot文件中的静态文件以外的文件夹提供 Web 根目录外的文件 ,
            //经过此配置以后,就可以访问非wwwroot文件下的文件
            FileProvider = new PhysicalFileProvider(
              Path.Combine(Directory.GetCurrentDirectory(), "Image")),
            RequestPath = "/Image",
        });

        //配置访问指定文件磁盘
        var dir = new DirectoryBrowserOptions();
        dir.FileProvider = new PhysicalFileProvider(@"E:");
        app.UseDirectoryBrowser(dir);
        var staticfile = new StaticFileOptions();
        staticfile.FileProvider = new PhysicalFileProvider(@"E:");//指定目录 这里指定E盘,也可以是其它目录
        staticfile.ServeUnknownFileTypes = true;
        staticfile.DefaultContentType = "application/x-msdownload"; //设置默认  MIME
        var provider = new FileExtensionContentTypeProvider();
        provider.Mappings.Add(".log", "text/plain");//手动设置对应MIME
        staticfile.ContentTypeProvider = provider;
        app.UseStaticFiles(staticfile);

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Home}/{action=Index}/{id?}");
        });
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34

复制代码
设置好以后,对于未识别的,默认为下载。 .log 就被我手动设置成文本方式。

对于前面的这么多设置,StaticFiles 提供了一种简便的写法。UseFileServer

app.UseFileServer(new FileServerOptions()
{
FileProvider = new PhysicalFileProvider(@“C:”),
EnableDirectoryBrowsing = true
});

原文地址:https://www.cnblogs.com/gd11/p/14217832.html