QuickStart下的CommandFilter项目 github上自己修改过的版本

http://docs.supersocket.net/v1-6/zh-CN/Command-Filter

 

命令筛选的例子

从CommandFilterAttribute派生出新的命令筛选类,然后将这些派生出来的类,放到命令类的上方[]

最后在执行命令的时候会触发

OnCommandExecuting 和OnCommandExecuted方法,这2个方法需要在派生类中重写

 

 

具体分析:

首先一个Server类

[CountCommandFilter]//Global command filter
public class MyAppServer : AppServer<MyAppSession>

 

然后有2个命令类

[LogTimeCommandFilter]

public class LOGIN : StringCommandBase<MyAppSession>

 

[LoggedInValidationFilter(Order = 0)]
[LogTimeCommandFilter(Order = 1)]

public class QUERY : StringCommandBase<MyAppSession>

 

然后有3个命令筛选类

 public class CountCommandFilter : CommandFilterAttribute

public class LoggedInValidationFilter : CommandFilterAttribute

 public class LogTimeCommandFilter : CommandFilterAttribute

 

其中CountCommandFilter 作为全局的命令筛选
LOGIN 有一个显式的命令筛选[LogTimeCommandFilter]

Query有2个显式的命令筛选[LoggedInValidationFilter(Order = 0)]和[LogTimeCommandFilter(Order = 1)]

它们都具有隐式的全局命令筛选CountCommandFilter 

 

所以最后在执行命令的时候:

Login命令只会触发2个命令筛选

而Query命令会触发3个命令筛选

 

 

 

posted @ 2015-03-18 21:52  ChuckLu  阅读(255)  评论(0编辑  收藏  举报