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个命令筛选