腾讯云
开发者社区
文档
建议反馈
控制台
首页
学习
活动
专区
工具
TVP
最新优惠活动
文章/答案/技术大牛
搜索
搜索
关闭
发布
登录/注册
首页
学习
活动
专区
工具
TVP
最新优惠活动
返回腾讯云官网
大内老A
专栏作者
举报
840
文章
821451
阅读量
116
订阅数
订阅专栏
申请加入专栏
全部文章(840)
asp.net(267)
其他(119)
编程算法(116)
mvc(94)
.net(93)
javascript(54)
windows(51)
http(49)
网络安全(40)
xml(35)
数据库(32)
网站(32)
对象(31)
api(30)
node.js(28)
android(26)
aop(26)
tcp/ip(25)
分布式(22)
html(20)
缓存(20)
安全(20)
文件存储(19)
容器(19)
asp(17)
存储(16)
core(15)
c#(14)
json(13)
sql(13)
unity(13)
数据处理(13)
内存(13)
ide(12)
面向对象编程(12)
iis(12)
数据结构(12)
sql server(10)
bash(9)
https(9)
数组(9)
php(8)
python(8)
access(8)
打包(8)
linux(8)
日志服务(8)
webassembly(8)
jquery(7)
ajax(7)
public(7)
函数(7)
框架(7)
apache(6)
布局(6)
java(5)
instance(5)
int(5)
max(5)
system(5)
解决方案(5)
unix(4)
express(4)
gui(4)
rpc(4)
memory(4)
service(4)
tcp(4)
笔记(4)
编程(4)
流量(4)
模型(4)
入门(4)
设计(4)
数据(4)
字符串(4)
云数据库 Redis(3)
ruby on rails(3)
spring(3)
批量计算(3)
开源(3)
性能测试(3)
action(3)
程序(3)
二进制(3)
服务端(3)
数据类型(3)
线程(3)
序列化(3)
重定向(3)
c++(2)
actionscript(2)
bootstrap(2)
ubuntu(2)
容器镜像服务(2)
自动化(2)
图像识别(2)
silverlight(2)
kerberos(2)
系统架构(2)
微服务(2)
nat(2)
callback(2)
datetime(2)
dispose(2)
null(2)
ref(2)
session(2)
static(2)
throttling(2)
transactionscope(2)
var(2)
变量(2)
并发(2)
代理(2)
泛型(2)
服务(2)
高性能(2)
接口(2)
路由(2)
模块化(2)
索引(2)
性能(2)
指针(2)
私有网络(1)
负载均衡(1)
ios(1)
mac os(1)
scala(1)
react(1)
css(1)
嵌入式(1)
硬件开发(1)
oracle(1)
git(1)
深度学习(1)
访问管理(1)
shell(1)
ssh(1)
dns(1)
单元测试(1)
socket编程(1)
uml(1)
ntp(1)
微信(1)
小程序(1)
安全漏洞(1)
架构设计(1)
processing(1)
account(1)
add(1)
behavior(1)
block(1)
bug(1)
byte(1)
class(1)
client(1)
config(1)
controller(1)
cors(1)
database(1)
db(1)
display(1)
double(1)
error(1)
event(1)
exception(1)
exe(1)
execute(1)
global(1)
hosting(1)
httpclient(1)
idisposable(1)
image(1)
invoke(1)
key(1)
list(1)
mex(1)
module(1)
nullable(1)
object(1)
ode(1)
picturebox(1)
pipeline(1)
point(1)
post(1)
private(1)
profiler(1)
properties(1)
select(1)
send(1)
show(1)
string(1)
table(1)
task(1)
thread(1)
threadpool(1)
timeout(1)
transactions(1)
ui(1)
unmanaged(1)
using(1)
view(1)
web(1)
window(1)
登录(1)
队列(1)
反射(1)
集合(1)
架构(1)
客户端(1)
跨域(1)
内存泄漏(1)
事务(1)
系统(1)
线程池(1)
协议(1)
异步(1)
异常(1)
异常处理(1)
搜索文章
搜索
搜索
关闭
ASP.NET Core 6框架揭秘实例演示[35]:利用Session保留语境
网络安全
云数据库 Redis
存储
缓存
数据库
客户端和服务器基于HTTP的消息交换就好比两个完全没有记忆能力的人在交流,每次单一的HTTP事务体现为一次“一问一答”的对话。单一的对话毫无意义,在在同一语境下针对某个主题进行的多次对话才会有结果。会话的目的就是在同一个客户端和服务器之间建立两者交谈的语境或者上下文,ASP.NET Core利用一个名为SessionMiddleware的中间件实现了会话。本篇提供了几个简单的实例来演示如何在一个ASP.NET Core应用中利用会话来存储用户的状态。(本文提供的示例演示已经同步到《ASP.NET Core 6框架揭秘-实例演示版》)。
蒋金楠
2022-09-28
627
0
全新升级的AOP框架Dora.Interception[6]: 框架设计和实现原理
网络安全
编程算法
javascript
node.js
本系列前面的五篇文章主要介绍Dora.Interception(github地址,觉得不错不妨给一颗星)的编程模式以及对它的扩展定制,现在我们来聊聊它的设计和实现原理。
蒋金楠
2022-06-30
493
0
全新升级的AOP框架Dora.Interception[5]: 实现任意的拦截器注册方式
aop
网络安全
编程算法
Dora.Interception(github地址,觉得不错不妨给一颗星)提供了两种拦截器注册方式,一种是利用标注在目标类型、属性和方法上的InterceptorAttribute特性,另一种采用基于目标方法或者属性的调用表达式。通过提供的扩展点,我们可以任何我们希望的拦截器注册方式。
蒋金楠
2022-06-28
314
0
全新升级的AOP框架Dora.Interception[4]: 基于Lambda表达式的拦截器注册方式
aop
网络安全
http
如果拦截器应用的目标类型是由自己定义的,Dora.Interception(github地址,觉得不错不妨给一颗星)可以在其类型或成员上标注InterceptorAttribute特性来应用对应的拦截器。如果对那个的程序集是由第三方提供的呢?此时我们可以采用提供的第二种基于表达式的拦截器应用方式。这里的拦截器是一个调用目标类型某个方法或者提取某个属性的Lambda表达式,我们采用这种强类型的编程方式得到目标方法,并提升编程体验。
蒋金楠
2022-06-27
238
0
全新升级的AOP框架Dora.Interception[3]: 基于特性标注的拦截器注册方式
网络安全
aop
http
在Dora.Interception(github地址,觉得不错不妨给一颗星)中按照约定方式定义的拦截器可以采用多种方式注册到目标方法上。本篇文章介绍最常用的基于“特性标注”的拦截器注册方式,下一篇会介绍另一种基于(Lambda)表达式的注册方式。如果原生定义的这两种注册方式不能满足要求,利用框架提供的扩展,我们可以完成任何你想要的拦截器注册手段。
蒋金楠
2022-06-27
181
0
全新升级的AOP框架Dora.Interception[2]: 基于约定的拦截器定义方式
网络安全
javascript
node.js
aop
asp.net
Dora.Interception(github地址,觉得不错不妨给一颗星)有别于其他AOP框架的最大的一个特点就是采用针对“约定”的拦截器定义方式。如果我们为拦截器定义了一个接口或者基类,那么拦截方法将失去任意注册依赖服务的灵活性。除此之外,由于我们采用了动态代码生成的机制,我们可以针对每一个目标方法生成对应的方法调用上下文,所以定义在拦截上下文上针对参数和返回值的提取和设置都是泛型方法,这样可以避免无谓的装箱和拆箱操作,进而将引入拦截带来的性能影响降到最低。
蒋金楠
2022-06-27
825
0
全新升级的AOP框架Dora.Interception[1]: 编程体验
aop
网络安全
缓存
asp.net
编程算法
多年之前利用IL Emit写了一个名为Dora.Interception(github地址,觉得不错不妨给一颗星)的AOP框架。前几天利用Roslyn的Source Generator对自己为公司写的一个GraphQL框架进行改造,性能得到显著的提高,觉得类似的机制同样可以用在AOP框架上,实验证明这样的实现方式不仅仅极大地改善性能(包括执行耗时和GC内存分配),而且让很多的功能特性变得简单了很多。这并不是说IL Emit性能不好(其实恰好相反),而是因为这样的实现太复杂,面向IL编程比写汇编差不多。由于AOP拦截机制涉及的场景很多(比如异步等待、泛型类型和泛型方法、按地址传递参数等等),希望完全利用IL Emit高效地实现所有的功能特性确实很难,但是从C#代码的层面去考虑就简单多了。(拙著《ASP.NET Core 6框架揭秘》于日前上市,加入读者群享6折优惠)
蒋金楠
2022-06-21
501
0
ASP.NET Core高性能服务器HTTP.SYS
http
https
网络安全
windows
如果我们只需要将ASP.NET CORE应用部署到Windows环境下,并且希望获得更好的性能,那么我们选择的服务器类型应该是HTTP.SYS。Windows环境下任何针对HTTP的网络监听器/服务器在性能上都无法与HTTP.SYS比肩。
蒋金楠
2022-05-09
605
0
KestrelServer详解[1]:注册监听终结点(Endpoint)
http
https
网络安全
具有跨平台能力的KestrelServer是最重要的服务器类型。针对KestrelServer的设置均体现在KestrelServerOptions配置选项上,注册的终结点是它承载的最重要的配置选项。这里所谓的终结点(Endpoint)与“路由”介绍的终结点不是一回事,这里表示的就是服务器在监听请求时绑定的网络地址,对应着一个System.Net.Endpoint对象。我们知道ASP.NET Core应用承载API也提供了注册监听地址的方法,其本质其实也是为了注册终结点,那么两种注册方式如何取舍呢?本文提供的示例演示已经同步到《ASP.NET Core 6框架揭秘-实例演示版》)
蒋金楠
2022-05-09
1K
0
WCF技术剖析之七:如何实现WCF与EnterLib PIAB、Unity之间的集成
unity
网络安全
在这之前,我写过深入介绍MS EnterLib PIAB的文章(参阅《MS Enterprise Library Policy Injection Application Block 深入解析[总结篇]》),也写过WCF与PIAB的集成(参阅:《WCF后续之旅(8):通过WCF Extension 实现与MS Enterprise Library Policy Injection Application Block 的集成》)、WCF与Unity的集成(参阅《WCF后续之旅(7):通过WCF Extension实现和Enterprise Library Unity Container的集成》)以及Unity与PIAB的集成(参阅《Enterprise Library深入解析与灵活应用(1):通过Unity Extension实现和Policy Injection Application Block的集成》、《Enterprise Library深入解析与灵活应用(7):再谈PIAB与Unity之间的集成》)。由于部分实现时基于EnterLib、Unity前一个版本,在新的版本中(EnterLib V4.1与Unity 1.2)中,MS通过Unity对PIAB进行了重新设计与实现,所以我们很有必要重拾着这个话题,谈谈对于新的EnterLib和Unity,如何将PIAB和Unity集成到WCF之中。(Source Code从这里下载)
蒋金楠
2022-05-09
583
0
如何追踪每一笔记录的来龙去脉:一个完整的Audit Logging解决方案[下篇]
日志服务
网络安全
xml
access
通过第一部分的介绍,我们对这个Audit Logging解决方案的原理有了较为全面的了解,接下来我们将通过一个简单的Sample来进一步介绍如何在一个具体的应用中如何实现这样一个Audit Logging。
蒋金楠
2022-05-09
420
0
ASP.NET Core 6框架揭秘实例演示[24]:中间件的多种定义方式
asp.net
javascript
node.js
编程算法
网络安全
ASP.NET Core的请求处理管道由一个服务器和一组中间件组成,位于 “龙头” 的服务器负责请求的监听、接收、分发和最终的响应,针对请求的处理由后续的中间件来完成。中间件最终体现为一个Func<RequestDelegate, RequestDelegate>委托,但是我们具有不同的定义和注册方式。(本篇提供的实例已经汇总到《ASP.NET Core 6框架揭秘-实例演示版》)
蒋金楠
2022-05-09
632
0
我的WCF之旅(8):WCF中的Session和Instancing Management
面向对象编程
网络安全
tcp/ip
我们知道,WCF是MS基于SOA建立的一套在分布式环境中各个相对独立的Application进行Communication的构架。他实现了最新的基于WS-*规范。按照SOA的原则,相对独自的业务逻辑以service的形式封装,调用者通过Messaging的方式调用Service。对于承载着某个业务功能的实现的Service应该具有Context无关性、甚至是Solution无关性,也就是说个构成Service的operation不应该绑定到具体的调用上下文,对于任何调用,具有什么样的输入,就会有与之对应的输出。因为SOA的一个最大的目标就是尽可能地实现重用,只有具有Context无关性/Solution无关性,Service才能实现最大限度的重用。此外Service的Context无关性/Solution无关性还促进了另一个重要的面向服务的特征的实现:可组合性,把若干相关细粒度的Service封装成一个整体业务流程的Service。
蒋金楠
2022-05-09
224
0
WCF后续之旅(14):TCP端口共享
http
tcp/ip
网络安全
在基于TCP/IP协议簇的对等网络通信下,相互通信的应用程序运行各自的进程中,出于应用层的进程将数据局封装成数据报,并通过传输层的TCP或者UDP进行网络通信。而TCP和UPD则通过一个16bit的端口来识别不同的应用程序。
蒋金楠
2022-05-09
724
0
动态方法拦截(AOP)的N种解决方案
网络安全
.net
编程算法
AOP的本质是方法拦截(将针对目标方法调用劫持下来,进而执行执行的操作),置于方法拦截的实现方案,不外乎两种代码注入类型,即编译时的静态注入和运行时的动态注入,本篇文章列出了几种常用的动态注入方案。这篇文章的目标并不是提供完整的AOP框架的解决方案,而是说明各种解决方案后面的原理,所以我们提供的实例代码会尽可能简单。为了确定拦截操作是否执行,我们定义了如下这个Indicator类型,我们的拦截操作会将其静态属性Injected属性设置为True,我们演示的代码最终通过这个属性来确定拦截是否成功。[源代码从这里下载]
蒋金楠
2021-01-13
680
0
ASP.NET Core应用基本编程模式[2]:依赖注入
asp.net
网络安全
编程算法
网站
javascript
基于IHostBuilder/IHost的服务承载系统建立在依赖注入框架之上,它在服务承载过程中依赖的服务(包括作为宿主的IHost对象)都由代表依赖注入容器的IServiceProvider对象提供。在定义承载服务时,也可以采用依赖注入方式来消费它所依赖的服务。作为依赖注入容器的IServiceProvider对象能否提供我们需要的服务实例,取决于相应的服务注册是否预先添加到依赖注入框架中。服务注册可以通过调用IHostBuilder接口或者IWebHostBuilder接口相应的方法来完成,前者在《服务承载系统》已经有详细介绍,下面介绍基于IWebHostBuilder接口的服务注册。[本文节选自《ASP.NET Core 3框架揭秘》第11章, 更多关于ASP.NET Core的文章请点这里]
蒋金楠
2020-11-13
1K
0
用最简单的方式在ASP.NET Core应用中实现认证、登录和注销
javascript
node.js
asp.net
网络安全
网站
本篇文章节选自《ASP.NET Core 3框架揭秘》(下册),针对本书的限时5折优惠截至到今天24时,有兴趣的朋友可以通过加入读者群进行购买。入群方式:扫描右方二维码添加“博文小丸子(broadview002)”,并将本书书号“38462”作为验证信息。源代码从这里下载。
蒋金楠
2020-03-26
3.3K
0
ASP.NET Core应用的7种依赖注入方式
网络安全
javascript
node.js
网站
asp.net
构成HostBuilderContext上下文的两个核心对象(表示配置的IConfiguration对象和表示承载环境的IHostEnvironment对象)可以直接注入Startup构造函数中进行消费。由于ASP.NET Core应用中的承载环境通过IWebHostEnvironment接口表示,IWebHostEnvironment接口派生于IHostEnvironment接口,所以也可以通过注入IWebHostEnvironment对象的方式得到当前承载环境相关的信息。
蒋金楠
2020-03-26
1.6K
0
[ASP.NET Core 3框架揭秘] Options[1]: 配置选项的正确使用方式[上篇]
网络安全
编程算法
json
依赖注入不仅是支撑整个ASP.NET Core框架的基石,也是开发ASP.NET Core应用采用的基本编程模式,所以依赖注入十分重要。依赖注入使我们可以将依赖的功能定义成服务,最终以一种松耦合的形式注入消费该功能的组件或者服务中。除了采用依赖注入的形式消费承载某种功能的服务,还可以采用相同的方式消费承载配置数据的Options对象。
蒋金楠
2020-02-12
1K
0
[ASP.NET Core 3框架揭秘] 异步线程无法使用IServiceProvider?
asp.net
网络安全
我们通过一个简单的实例来模拟该同事遇到的问题。我们采用极简的方式创建了如下这个ASP.NET Core MVC应用。如下面的代码片段所示,除了注册与ASP.NET Core MVC框架相关的服务与中间件之外,我们还调用了IHostBuilder的UseDefaultServiceProvider方法将配置选项ServiceProviderOptions的ValidateScopes属性设置为True,以开启针对服务范围的验证。我们还采用Scoped生命周期模式注册了服务IFoobar,具体的实现类型Foobar还实现了IDisposable接口。
蒋金楠
2019-12-02
1K
0
点击加载更多
社区活动
腾讯技术创作狂欢月
“码”上创作 21 天,分 10000 元奖品池!
立即发文
Python精品学习库
代码在线跑,知识轻松学
立即查看
博客搬家 | 分享价值百万资源包
自行/邀约他人一键搬运博客,速成社区影响力并领取好礼
立即体验
技术创作特训营·精选知识专栏
往期视频·千货材料·成员作品 最新动态
立即查看
领券
问题归档
专栏文章
快讯文章归档
关键词归档
开发者手册归档
开发者手册 Section 归档