1.初识Core
我们新建一个项目-
新建之后我们就会看到:
/// <summary> /// asp.net--网站托管在IIS--IIS负责监听-转发请求--响应客户端 /// .net core--控制台--CreateWebHostBuilder(内置了服务器)--启动了服务器--负责监听-转发请求--响应客户端 /// KestrelServer 跨平台的服务器 /// (IIS只能做反向代理,不再做啥监听)/// </summary> public class Program { //Main是整个程序的入口 public static void Main(string[] args) { //跨平台没有IIS,.NETCore CreateWebHostBuilder(内置了服务器)--启动了服务器--负责监听-转发请求--响应客户端全部自己做,不用IIS处理 //只要当前这个服务器是跨平台的,那么我整个程序都是跨平台的 // 创建一个服务器实例,服务器是跨平台的, CreateHostBuilder(args) .Build() .Run(); } /// <summary> /// 调入当前方法,CreateHostBuilder->然后进入 Startup 这个类 /// </summary> public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }) ; }
/// appsettings.json相当于Webconfig,存储格式也变了,由XML格式变为了Json格式 /// Asp读取配置文件:依赖于ConfiguartionManager /// Core依赖于Configuration /// 通过Xpath来读取配置文件的数据
namespace MyNetCore.MVC6 { /// <summary> /// 固定类 /// </summary> public class Startup { /// <summary> /// 构造函数的注入,内置IOC /// </summary> public IConfiguration Configuration { get; } public Startup(IConfiguration configuration) { Configuration = configuration; } /// <summary> /// 把服务注入容器里面去【core内置IOC】:当前方法被运行时环境调入,把服务添加到container容器里面去 /// Startup:IServiceCollection就是一个容器,那我们是怎么使用 /// </summary> /// <param name="services"></param> // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddControllersWithViews(); services.AddSession(); } //上面服务注册了,那我们就可以做一些使用 // 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(); } else { //进入特定页面 app.UseExceptionHandler("/Home/Error"); } //上面是把服务注册到容器里面,这边就可以使用注册进来的服务 //使用文件,涉及:一些中间件的使用 //静态文件能够被保存在网站根目录下的任意文件夹内,并通过相对根的路径来访问。为了能使用静态文件服务,必须配置中间件,把静态文件中间件加入到管道内。
//静态文件中间件可以通过下述方法来配置:在项目中增加Microsoft.AspNetCore.StaticFiles包依赖,然后从Startup.Configure中调用.UseStaticFiles扩展方法: //使得web root(默认为wwwroot)下的文件可以被访问。 app.UseStaticFiles(); app.UseSession(); app.UseRouting();//将注册运行逻辑路由的中间件。 app.UseAuthorization(); //注册MVC中间件,并配置路由规则 app.UseEndpoints(endpoints => { //MapControllerRoute:添加控制器的常规路由 endpoints.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{id?}"); }); } } }
原文:https://www.cnblogs.com/wangwangwangMax/p/14081032.html