章节:
第一章:https://www.cnblogs.com/kimiliucn/p/17613434.html
第二章:https://www.cnblogs.com/kimiliucn/p/17620153.html
(1)管理Nuget程序,下载【log4net】和【Microsoft.Extensions.Logging.Log4Net.AspNetCore】
(2)新建一个文件夹,保存log4net配置文件,一定要在【属性】中的 复制到输出目录 选择【始终复制】。
(3)在【Program.cs】文件的【CreateHostBuilder】方法中配置log4net。
也可以使用以下方式配置(在Startup中):
这里注意,别选择错了!然后就可以了。
(1)右击项目,选择【发布】
(2)选择【文件夹】
(3)选择要保存的路径,然后点击【完成】;
(4)点击【发布】,可以看到已经发布完成了。
6.2.1-IIS发布
6.2.2-ASP.NET Core跨平台原因
6.2.3-使用脚本启动网站
6.2.4-发布之后运行为什么样式加载不出404?
(1)需要在【startup.cs】文件的【Configure】方法中引入一个中间件。
在【startup.cs】文件中读取配置文件
在【控制器】中读取配置文件。
(1)先构造函数注入Configure
(2)写代码获取
(1)定义一个类,结构(数据类型、属性名)和配置文件中完全一致。
(2)在【Startup.sc】配置一下
(3)在控制器中,构造函数注入一个IOptions
(4)获得并返回值
(5)前端获取值
其实是一个类文件。
Razor混编:可以在cshtml上写 后台C#代码 + 前台html代码,混合起来写;
(1)可以引入命名空间
(2)直接写后台代码
(3)实现接口
(4)可以依赖注入
(5)可以添加特性Class
(6)定义方法并调用
(7)写单行代码、多行代码
(8)Razor表达式
(9)输出尖括号
(10)for循环
(11)在后台代码内部写HTML代码
修改视图,增加了html代码,不能马上生效,怎么办?使用中间件
1.引入Nuget包
2.在【Startup.cs】文件的票【ConfigureServices】方法中配置。
8.4.1-我们看到的页面组成到底有哪些内容?
答:包含了Layout的模板嵌套的返回的需要渲染的视图内容;
8.4.2-如何嵌套呢?
答:通过Layout中RendBody()方法做了替换;把返回的视图替换到模板也中,形成了一整块的内容;目的在于每一次返回不同的页面的时候,能够吧不变的视图部分,种以重用;这样就可以少些代码。
8.4.3-在模板页面导入了JQ,在视图页面使用JQ为什么报错?
注意:
答:因为Script是写在下面的,先加载RenderBody,后加载JQ,所以会报错,解决方法如下:
本质:通过一个后台方法,返回一个【已经存在】的Html标签的字符串,浏览器在读取的时候,就读取成一个Html标签。
1.定义
/// <summary>
/// 图片
/// </summary>
/// <param name="helper"></param>
/// <param name="src"></param>
/// <returns></returns>
public static IHtmlContent Img(this IHtmlHelper helper,string src,string @class)
{
return new HtmlString($"<img src='{src}' class='{@class}'/>");
}
2.调用
<!--1.引入命名空间-->
<!--2.使用图片--自定义 扩展方法-->
@Html.Img("https://tpc.googlesyndication.com/simgad/3105023548593992165/downsize_200k_v1?w=200&h=200","border:1px solid red;")
通过一个后台方法,返回一个【不存在】的Html标签的字符串,在读取的时候,通过制后台方法,去生成我们制定的标签。
1.写一个扩展方法,定义一个普通类,类名建议以TagHelper结尾,加上特性;如果没有标记特性,视图中在调用的时候使用当前类名去掉TagHelper后缀得到的的字符串来调用。继承TagHelpre抽象类、或者实现接口ITagHelpr,二者选一起均可。然后实现接口Proccss方法。
2.在【_ViewImports.cshtml】进行注册
3.使用
1.创建一个局部视图
2.进行调用
9.3.1-局部视图的缺陷:
局部视图没有去访问控制器中的Action,所以不能完美的实现后台代码。可以使用视图组件解决。
9.4.1-视图组件的优点?
9.4.2-如何自定义视图组件?
(1)Rzaor组件对应的类需要以ViewComponent结尾,该类需要继承自ViewCompnent类。
(2)定义一个异步版本的InvokeAsync,可以自定义参数,IncokeAsync就是返回组件内容的方法。
(3)在Views/Shared文件下建立Components文件夹,在这个文件下创建一个和组件类名相同(如果加了特性,就按照特性上面的名称来)的文件夹,然后创建一个Default.cshtml视图。
注意:以上步骤可以不按照上面执行,我们可以随意新建一个视图,然后指定路径就可以了。
(4)调用
把对象的创建,统一交给第三方容器来创建;
(1)在【Startup.cs】的【ConfigureServices】中注册服务;注册抽象和具体的依赖关系;
(2)通过构造函数进行依赖注入,自动得到服务的实例;
(3)调用;
(1)在【Startup.cs】的【ConfigureServices】中注册服务;注册抽象和具体的依赖关系;
(2)通过构造函数进行依赖注入。
(3)调用;
DI依赖注入:IServiceCollection支持且支持构造函数注入。
如对象A依赖对象B,对象B依赖于对象C,就可以先构造对象C,然后传递给对象B,然后传递给对象A,然后得到具体的实例。可以支持无限层级的依赖注入,前提是先要先注入服务(注册抽象和具体的映射关系)。
那么在创建对象的时候, 不同的情况,需要让对象单例,每一次都创建新的对象实例,不同的作用于创建新的实例。
AddTransient:顺时声明周期,每次获取的都是不同的实例
AddSingleton:单例生命周期,在整个进程中获取的都是同一个实例
AddScoped:作用域生命周期(同一个作用域,获取的是同一个对象的实例,不同的作用域,获取的是不同的独对象实例)
建议:开发工作中,一般情况下,都是一个请求一个对象的实例,所以使用的是顺时声明周期(AddTransient)。
Autofac也是一款流行的IOC容器;
(1)管理Nuget程序包,下载并安装【Autofac】
(2)在【Startup.cs】的【ConfigureServices】中注册服务;
瞬时生命周期:每一次获取对象都是一个全新的实例,默认的生命周期。
单例声明周期:在整个进程中,对象永远都是同一个实例(SingleInstance)
每个生命周期范围一个实例:同一个生命周期范围内是同一个实例,不同的生命周期范围,实例不一样。(InstancePerLifetimeScope)
语法:InstancePerMatchingLifetimeScope(名称)
(1)管理Nuget包,引入3个程序集;
(2)新建一个配置文件【autofac.json】,记得将配置文件设置为:始终复制到目录。
(3)在【Startup.cs】的【ConfigureServices】中注册服务;
注意:Autofac是一个第三方容器;
(1)指定Autofac工厂替换默认工厂,在【Program.cs】中的【CreateHostBuilder】方法中指定。
(2)在【Startup.cs】类中增加一个【ConfigureContainer】方法,用来注册服务关系。
/// <summary>
/// 增加一个方法:
/// 整个方法被Autofac自动调用
/// 负责注册各种服务
/// </summary>
/// <param name="services"></param>
public void ConfigureContainer(ContainerBuilder containerBuilder) {
containerBuilder.RegisterType<TestServiceA>().As<ITestServiceA>();
containerBuilder.RegisterType<TestServiceB>().As<ITestServiceB>();
containerBuilder.RegisterType<TestServiceC>().As<ITestServiceC>();
containerBuilder.RegisterType<TestServiceD>().As<ITestServiceD>().PropertiesAutowired();
containerBuilder.RegisterType<TestServiceE>().As<ITestServiceE>();
}
(3)通过控制器构造函数注入,获取实例。
这种方法也还能用:
(1)首先在【Startup.cs】中【ConfigureServices】方法中,指定控制器实例容器来创建,进行替换。
(2)创建一个类(特性);
(3)创建一个类,用来判断维度;
(4)在【Startup.cs】中创建一个【ConfigureContainer】方法,负责注册各种服务。
注意:
一般使用以下方法:
(1)在【Startup.cs】中创建的【ConfigureContainer】方法中,注册资源和实现(单抽象、多实现)
(2)通过构造函数中,使用具体理性实理性做我参数,可以匹配到不同的具体类型实例。
(1)新建一个类,该类继承Module类,实现Load方法。
(2)与之前相同,不同的而方式:在【Startup.cs】中创建的【ConfigureContainer】方法中,注册资源和实现(单抽象、多实现)
AOP-面向切面编程:不用修改之前代码的基础上,可以动态的在某个动作之前加一些操作,动态的在某一个动作之后做点什么事。
(1)管理Gurget程序包,下载【Castle.Core】包,该包用来动态代理。
(2)创建一个类为【CustomAutofacAop】,该类继承自【IInterceptor】接口,并实现接口中的【Intercept】方法。
(3)在服务的抽象上面做一个标记,这个标记是用来:支持AOP扩展能够生效。
(4)因为这个【CustomAutofacAop】实例也是通过Autofac的IOC来做的,所以需要在【Startup.cs】中创建的【ConfigureContainer】方法中,注册服务,让Autofac支持AOP。
(1)管理Gurget程序包,下载【Castle.Core】包,该包用来动态代理。
(2)创建一个类为【CustomAutofacAopClass】,该类继承自【IInterceptor】接口,并实现接口中的【Intercept】方法。
(3)在类上面做一个标记,这个标记是用来:支持AOP扩展能够生效。
(4)因为这个【CustomAutofacAop】实例也是通过Autofac的IOC来做的,所以需要在【Startup.cs】中创建的【ConfigureContainer】方法中,注册服务,让Autofac支持AOP。
(1)在【Startup.cs】中创建的【ConfigureContainer】方法中,注册服务。
(2)在控制器中调用。
(1)道理和上面是一样的,可以吧Autofac上下文当做属性来注入。
(2)在使用的时候,通过Autofac上下文+不同注册的标识,获取到不同的具体实例。
手机扫一扫
移动阅读更方便
你可能感兴趣的文章