ASP.NET MVC ×Ô¶¨Òå¹ýÂËÊôÐÔʵÏÖEnterpriseµÄlog¹¦ÄÜ
ÏÖÔÚµÄÆóÒµ¼¶¿ª·¢ÏîÄ¿£¬ÌرðÊÇÍøÕ¾Ò»°ã¶¼»áÓõ½log¹¦ÄÜ£¬ÏëÏë´ó²¿·Ö»áÓÃEnterprise Logging Application Block µÄ¹¦ÄÜ »òÕß×Ô¼ºÐ´Ò»¸ö×é¼þ£¬¼Ç¼ϵͳÈÕ־ʼþ£¬¸üºÃµÄ¸ú×ÙÁ˽âϵͳÔËÐÐÇé¿ö, ÏÖÓÃASP.NET MVC µÄ¹ýÂËÊôÐÔʵÏÖlog¹¦ÄÜ£¡
ASP.NET MVCµÄfilter ÊÇÒ»¸öÊôÐÔ£¬¿ÉÒÔÓ¦Óõ½controller ºóÕßaction.µ±Controller»òÕßaction method ±»µ÷ÓÃʱ£¬ASP.NET MVCµÄfilterÔÚµ÷ÓÃÖ´ÐÐÇ°ºó»á±»´¥·¢¡£ ÏÈ¿´Ïµ±Control ÀïÃæµÄaction ±»µ÷ÓÃʱµÄÀûÓü̳Ð,×Ô¶¨ÒåÀàlogµÄЧ¹ûͼ£º
ҪʵÏÖÉÏÃæµÄЧ¹û£¬ÏÖ×Ô¶¨ÒåÒ»¸öÀàLogMessageAttribute,LogMessageAttribute¼Ì³Ð½Ó¿ÚIActionFilter ,IResultFilter,Ò²¿ÉÒÔÑ¡ÔñÐԵļ̳ÐÖØдÀàFilterAttribute¡£
IActionFilter interface ¶¨ÒåΪ£º
public interface IActionFilter
{
// Methods
void OnActionExecuted(ActionExecutedContext filterContext);
void OnActionExecuting(ActionExecutingContext filterContext);
}
OnActionExecuting £ºÔÚController ÀïÃæµÄaction method µ÷ÓÃ֮ǰÔËÐÐ
OnActionExecuted£ºÔÚController ÀïÃæµÄaction method µ÷ÓÃÖ®ºóÔËÐУ¬µ«ÊÇÔÚIResultFilter½Ó¿ÚµÄOnResultExecuting·½·¨Ö´ÐÐ֮ǰ
IResultFilter interface¶¨ÒåΪ£º
public interface IResultFilter
{
// Methods
void OnResultExecuted(ResultExecutedContext filterContext);
void OnResultExecuting(ResultExecutingContext filterContext);
}
OnResultExecuting£ºÔÚController ÀïÃæµÄaction methodµ÷Óô¦ÀíÍæÇ°Ö´ÐÐ.
OnResultExecuted£ºÔÚController ÀïÃæµÄaction methodµ÷Óô¦ÀíÍæºóÖ´ÐÐ.
½ÓÏÂÀ´ÊÇÖØÍ·Ï·£ºLogMessageAttribute×Ô¶¨ÒåÀà
´úÂë
[AttributeUsage(AttributeTargets.Class |AttributeTargets.Method ,Inherited=true ,AllowMultiple=true )]
public class LogMessageAttribute:FilterAtt
Ïà¹ØÎĵµ£º
ÕâÀïÊÇ´ÓDatasetÀïµÄÊý¾ÝÉú³ÉÇúÏßͼ.
ÎÒµÄDatasetÊÇ´Ó±íSendrecÀï¶ÁÈ¡µÄÊý¾Ý,·Ö±ðÓÐId,Sendid(¶©µ¥ºÅ),Sendtime(¼Ç¼ʱ¼ä),Sendnum(µ¥Î»Ê±¼ä·¢ËÍÁ¿/ÎÒÕâÀïÊÇÎå·ÖÖÓ)¼¸¸ö×Ö¶Î
¹ý³ÌÈçÏÂ:
public void draw(Page page,DataSet ds,int Tnum){}
ÆäÖÐpageÊÇÓÃÀ´´«µÝÒýÓÃÕâ¸ö¹ý³ÌµÄÒ³Ãæ,ÕâÑùÈÃÒ³ÃæÊÇJPG·½Ê½Ö±½ÓÏò¿Í»§¶ËÊä³öÉú ......
ÉÏ´Î×öÁ˸öÏîÄ¿£¬Éæ¼°µ½Êý¾Ý¿âµÄ»¹ÔºÍ»Ö¸´£¬µ½ÍøÉÏÕÒÁËһϣ¬ÊÇÀûÓÃSQLDMOʵÏֵģ¬Ö»ÒªÌí¼ÓSQLDMOÒýÓþͺÃÁË£¬È»ºóÀûÓÃϱߵÄÀàµÄ·½·¨¾Í¿ÉÒÔʵÏÖÁË¡£
ÎÒ°ÑÔ×÷ÕßµÄÀàÀ©³äÁËһϣ¬¿ÉÒÔ×Ô¶¯Ê¶±ðweb.configÀï µÄÊý¾Ý¿âÁ¬½Ó×Ö·û´®£¬¿ÉÒÔͨ¹ý±äÁ¿ÉèÖû¹Ô»Ö¸´µÄÐÅÏ¢¡£
ÐèҪעÒâµÄʱ»¹Ô£¬»¹ÔµÄʱºòÎÊÌ ......
¸ø³öÈçÏÂÀý×Ó ÎÒÖ»ÖªµÀÕâÑù×ö¿ÉÒÔµ÷ÓÃÉÏÒ»¸öÒ³Ãæ µÄÖµ»òÕß·½·¨ µ«ÊÇÎÒ²»ÖªµÀÔÀíºÍËüµÄÓÅÂÔ
Çë¸ßÊÖ ¼ÓÒÔÖ¸µã ´ó¼Ò¹²Í¬Ñ§Ï° лл£¡
1.Default.aspx Ò³Ãæ
protected void but1_Click(object sender, EventArgs e)
{
Server.Transfer("Default2.aspx");
......
°ïÈË¿´Ò»¸öÍøÕ¾£¬ÊÇghost¿Ë¡ºó³öÏÖ¿Õ°×¹ÊÕÏ£¬ÎÞÂÛÖØ×°IIS»¹ÊÇNETFrameWork¶¼²»ÄÜÕý³£½âÎöaspxÎļþÒ»Ñù£¬Óöµ½aspxÏÔʾ¾ÍÊÇ¿Õ°×Ò³Ãæ¡£
×îºó·¢ÏÖglobal.aspxµÄapplication_error´¦ÀíÖаѴíÎóÐÅÏ¢²Á³ýÁË£¬Ð޸ĻØÀ´ÈÃËüÏÔʾ¾ßÌå´íÎó¡£
·¢ÏÖÎÞ·¨cscдÈëdllÎļþµ½ÁÙʱĿ¼¡£
½â¾ö·½·¨£¬¸³ÓèNetServiceÓû§ÍêÈ«¿ØÖÆȨÏÞ£¬ÔÚ%win ......
//ƽ³£µ÷ÓÃjavascript·½·¨
ClientScript.RegisterStartupScript(this.GetType(), "", "<script>alert'Weclome!!!');</script>");
±³¾°²»Îª°×É«µÄ·½·¨£º
Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('Ìí¼Óʧ°Ü£¬ÇëÁªÏµ¼¼ÊõÔ±£¡') ......