国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開(kāi)發(fā)教程 > 詳細(xì)頁(yè)面

dotnet中的出錯(cuò)處理

dotnet中的出錯(cuò)處理

更新時(shí)間:2022-05-01 文章作者:未知 信息來(lái)源:網(wǎng)絡(luò) 閱讀次數(shù):

近日給老美做外包項(xiàng)目,被老美逼出來(lái)了一套關(guān)于錯(cuò)誤處理的方法,在此不敢藏拙,奉獻(xiàn)出來(lái)給大家批判。

首先,屏蔽程序中所有的自動(dòng)錯(cuò)誤處理,千萬(wàn)不要出來(lái):“
System.Web.Services.Protocols.SoapException: System.Web.Services.Protocols.SoapException: 服務(wù)器無(wú)法處理請(qǐng)求。”等錯(cuò)誤頁(yè)面,而應(yīng)該是一些簡(jiǎn)單易懂的東西,俺在此使用的是Duwamish 7.0里的錯(cuò)誤處理頁(yè)面:
<body >
<H2>An error has occurred</H2>
<P>We were unable to complete your request. This failure has been logged with our
system administrators, who are currently working to resolve the problem. We
apologize for any inconvenience caused by this temporary service outage, and we
appreciate your patience as we work to improve our web site.</P>
</body>
當(dāng)然,要做到這一點(diǎn)也很簡(jiǎn)單,可以在web.config里這樣配置(假如你的錯(cuò)誤頁(yè)面叫Error.aspx):
<customErrors
defaultRedirect = "Error.aspx"
mode="On"
/>
這個(gè)配置你可以給據(jù)你的需要修改(比如mode的值)。


其次,要把錯(cuò)誤信息寫(xiě)到日志中去。
我們定義錯(cuò)誤日志信息的結(jié)構(gòu)如下
public struct ErrorLogItem
{
public string User ;//當(dāng)前登錄人
public string AppName ;//應(yīng)用程序名稱(chēng)
public string ClassName ;//錯(cuò)誤發(fā)生的類(lèi)名稱(chēng)
public string FunctionName ;//錯(cuò)誤發(fā)生的方法(事件)名稱(chēng)
public string Position ;//錯(cuò)誤的位置(或其它信息)
public string ErrorInfo ;//錯(cuò)誤信息
public DateTime OccurTime ;//錯(cuò)誤發(fā)生的時(shí)間
}

錯(cuò)誤日志類(lèi)如下所示:
public class ErrorLog
{
private static ErrorLog _Instance = null ;
private static string strRootName ;
private static XmlElement xmlRoot ;
private static XmlDocument xmlDoc ;
private ErrorLog()
{
Load() ;
}
private bool Load()
{
if (!File.Exists(AppGlobal.ErrorLogFile))
CreateErrorLogFile(AppGlobal.ErrorLogFile);

if (xmlDoc == null)
xmlDoc = new XmlDocument() ;
try
{
xmlDoc.Load(AppGlobal.ErrorLogFile) ;
}
catch
{
return false ;
}
xmlRoot = xmlDoc.DocumentElement ;
if (xmlRoot != null)
strRootName = "/" + xmlRoot.Name + "/" ;
return true ;
}
private void CreateErrorLogFile(string strFileName)
{
StringBuilder sb = new StringBuilder() ;
sb.Append("<?xml version='1.0\' ?> ") ;
sb.Append("<errorlog>") ;
sb.Append("</errorlog>") ;

XmlDocument xmlDoc = new XmlDocument() ;
xmlDoc.LoadXml(sb.ToString()) ;
xmlDoc.Save(strFileName) ;
}
private void AddXmlAttribute(XmlElement xNode,string strAttr,string strAttrvalue)
{
XmlAttribute xAttr = (XmlAttribute)xmlDoc.CreateNode(XmlNodeType.Attribute,strAttr,null) ;
xAttr.InnerText = strAttrvalue;
xNode.Attributes.Append(xAttr) ;
}
public void SetErrorLog(ErrorLogItem errItem)
{
XmlElement xErrorElement = xmlDoc.CreateElement("error") ;

AddXmlAttribute(xErrorElement,"username",errItem.User);
AddXmlAttribute(xErrorElement,"application",errItem.AppName);
AddXmlAttribute(xErrorElement,"classname",errItem.ClassName);
AddXmlAttribute(xErrorElement,"functionname",errItem.FunctionName);
AddXmlAttribute(xErrorElement,"position",errItem.Position);
AddXmlAttribute(xErrorElement,"occurtime",errItem.OccurTime.ToString("g"));
xErrorElement.InnerText = errItem.ErrorInfo ;

xmlRoot.AppendChild(xErrorElement) ;

if (xmlRoot.ChildNodes.Count > AppGlobal.MaxErrorLogCount)
xmlRoot.RemoveChild(xmlRoot.FirstChild) ;
xmlDoc.Save(AppGlobal.ErrorLogFile) ;
}

public static ErrorLog Instance()
{
if(_Instance == null)
{
_Instance = new ErrorLog() ;
}
return _Instance ;
}
}//end class

我們可以通過(guò)調(diào)用SetErrorLog方法來(lái)把信息寫(xiě)到日志中去。
當(dāng)然,日志的位置以及日志記錄錯(cuò)誤信息的數(shù)量也是可以配置的
<appSettings>
<add key="errlogfile" value="c:\ddmsLog.xml" />
<add key="maxerrlogcount" value="1000" />
</appSettings>
我們可以通過(guò)下面的方法得到他們的值:
public static string ErrorLogFile
{
get
{
return ConfigurationSettings.AppSettings["errlogfile"].Trim() ;
}
}
public static int MaxErrorLogCount
{
get
{
return int.Parse(ConfigurationSettings.AppSettings["maxerrlogcount"].Trim()) ;
}
}

再次,我們還要把錯(cuò)誤信息自動(dòng)發(fā)到我們的信箱中(這一點(diǎn)很重要--至少對(duì)我這個(gè)項(xiàng)目來(lái)說(shuō),我不能跑到美國(guó)去調(diào)試,也不能老是讓老外告訴我發(fā)生了什么錯(cuò)誤)
發(fā)送郵件的方法如下:
public static bool SendErrorLogMail(string StrTo,ErrorLogItem errItem)
{
MailLink.Load(AppGlobal.MAIL_CFG_FILE_PATH) ;

string StrName = MailLink.GetNodeText(MAILLINKITEM.USERNAME) ;
string StrCode = MailLink.GetNodeText(MAILLINKITEM.PASSWORD) ;

string strFrom = MailLink.GetNodeText(MAILLINKITEM.MAILFROM) ;
string strSubject = "Error Log" ;
string strSmtpServer = MailLink.GetNodeText(MAILLINKITEM.MAILSMTPSERVER) ;

string strMailBody = "<div>An error occur </div>" ;
strMailBody += "<div>Login User:" + errItem.User + "</div>" ;
strMailBody += "<div>Applicatin Name:" + errItem.AppName + "</div>" ;
strMailBody += "<div>ClassName:" + errItem.ClassName + "</div>" ;
strMailBody += "<div>Function Name:" + errItem.FunctionName + "</div>" ;
strMailBody += "<div>Error Position:" + errItem.Position + "</div>" ;
strMailBody += "<div>Error Information:" + errItem.ErrorInfo + "</div>" ;
strMailBody += "<DIV> </DIV>" ;
strMailBody += "<DIV> </DIV>" ;
strMailBody += "<DIV>" + errItem.OccurTime + "</DIV>" ;

bool blResult = MailLink.SendMail(StrTo,strMailBody,strSubject,strFrom,StrName,StrCode,strSmtpServer) ;

return blResult ;
}
意思大家應(yīng)該明白,里面具體的一些方法調(diào)用大家可以寫(xiě)自己的代碼來(lái)代替。
當(dāng)然,郵箱地址也是可以配置的:
<appSettings>
<add key="errorlogemail" value="zl3624@china.com" />
</appSettings>
取出方法:
public static string ErrorLogEmail
{
get
{
return ConfigurationSettings.AppSettings["errorlogemail"].Trim() ;
}
}
最后,是用一個(gè)方法來(lái)調(diào)用寫(xiě)日志和發(fā)郵件的方法:
public static void LogAppError(Exception thisErr,string strClass,string strFunc,string strPos,string strUser)
{
ErrorLogItem errItem = new ErrorLogItem() ;

errItem.AppName = "Your AppName" ;
errItem.ClassName = strClass ;
errItem.ErrorInfo = thisErr.ToString() ;
errItem.FunctionName = strFunc ;
errItem.OccurTime = DateTime.Now ;
errItem.Position = strPos ;
errItem.User =strUser ;

try
{
ErrorLog.Instance().SetErrorLog(errItem) ;
SendErrorLogMail(ErrorLogEmail,sb.ToString()) ;
}
catch
{
}
finally
{

}
throw new Exception("An error occur :"+thisErr.ToString()) ;
}
那么,怎樣在程序中捕獲異常哪?
下面是俺的一段代碼:
public DataSet GetPrsnInfo(int aiTrx_no,int aiIncid_no,int aiPrsn_id)
{
try
{
ddmsWsPInfo.CandiService ddmsCS = new ddmsWsPInfo.CandiService() ;
ddmsCS.Url = AppGlobal.WebServicesUrl ;
DataSet dsPrsn = ddmsCS.GetPrsnInfo(aiTrx_no,aiIncid_no,aiPrsn_id) ;
ddmsCS.Dispose();
return dsPrsn ;

}
catch(Exception e)
{
string strErr = "aiTrx_no=" + aiTrx_no + " aiIncid_no=" + aiIncid_no + " aiPrsn_id=" + aiPrsn_id ;
AppGlobal.LogAppError(e,"PrsnManager","GetExtraPrsn",strErr,LoginUser.UserID) ;
return null ;
}
}

呵呵,這樣錯(cuò)誤處理應(yīng)該差不多了吧?

溫馨提示:喜歡本站的話(huà),請(qǐng)收藏一下本站!

本類(lèi)教程下載

系統(tǒng)下載排行

国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

  • <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        久久日一线二线三线suv| 丰满岳乱妇一区二区三区| 日本美女一区二区三区视频| 91成人在线观看喷潮| 樱桃视频在线观看一区| 99精品视频一区| 一区二区三区四区亚洲| 色综合久久天天| 性感美女极品91精品| 日韩一区二区三区免费看| 国产一区二区三区黄视频| 国产精品久久毛片| 欧美男同性恋视频网站| 国产一区二区三区久久久| 亚洲视频免费观看| 欧美一级片在线观看| 成人一区二区视频| 亚洲成人综合在线| 久久免费国产精品| 欧美日韩一区高清| 国产99精品国产| 天天综合网天天综合色| 国产视频一区在线观看| 91成人在线观看喷潮| 国产一区二区调教| 亚洲在线中文字幕| 国产三级一区二区三区| 7777精品伊人久久久大香线蕉经典版下载| 国产美女精品一区二区三区| 亚洲成av人在线观看| 国产日韩欧美精品在线| 欧美片网站yy| 91在线观看美女| 国产成人日日夜夜| 美女被吸乳得到大胸91| 亚洲一区精品在线| 亚洲同性同志一二三专区| 精品国产91洋老外米糕| 欧美老肥妇做.爰bbww| 99久久夜色精品国产网站| 韩国女主播一区| 日韩黄色一级片| 亚洲一区免费观看| 亚洲视频电影在线| 中文字幕一区二区在线播放| 久久免费精品国产久精品久久久久 | 日韩精品一区二区三区视频在线观看| 99国产精品99久久久久久| 国产一区在线精品| 另类综合日韩欧美亚洲| 婷婷开心激情综合| 亚洲国产精品视频| 一个色在线综合| 亚洲影院久久精品| 亚洲综合免费观看高清在线观看 | 欧美顶级少妇做爰| 色综合天天性综合| 91天堂素人约啪| 色哟哟精品一区| 在线观看日韩一区| 在线观看国产一区二区| 欧美主播一区二区三区| 欧美三级电影在线看| 欧美日韩成人综合| 日韩一区二区三区在线视频| 日韩欧美成人午夜| 日韩精品一区二区三区视频播放| 欧美成人高清电影在线| 久久久久久久久久久电影| 国产欧美视频一区二区| 国产精品午夜在线观看| 最近日韩中文字幕| 天天综合日日夜夜精品| 黄网站免费久久| 99在线热播精品免费| 欧美综合一区二区三区| 日韩欧美国产一区二区在线播放| 欧美极品另类videosde| 亚洲三级在线免费观看| 亚洲国产你懂的| 精品一区二区精品| 成人伦理片在线| 欧美丝袜第三区| 久久欧美中文字幕| 椎名由奈av一区二区三区| 五月天网站亚洲| 东方aⅴ免费观看久久av| 色狠狠色狠狠综合| 日韩视频免费观看高清完整版 | 国产女人18毛片水真多成人如厕 | 91视频在线观看| 欧美高清一级片在线| 精品av久久707| 一区二区三区高清在线| 捆绑紧缚一区二区三区视频| 不卡的av电影| 精品福利av导航| 亚洲国产欧美日韩另类综合 | 国产成人在线看| 色一区在线观看| 欧美精品一区二区三区久久久| 亚洲欧美在线视频观看| 免费成人小视频| 91视频免费看| 久久免费视频色| 日韩精品国产欧美| www.日韩在线| 久久久国产精品午夜一区ai换脸 | 亚洲综合视频网| 国产成人精品网址| 日韩免费视频线观看| 亚洲成人自拍偷拍| 91免费观看在线| 国产精品视频九色porn| 久久成人18免费观看| 欧美日韩国产另类一区| 亚洲日本电影在线| 成人av在线一区二区| 国产亚洲一二三区| 黑人巨大精品欧美一区| 91精品国产麻豆国产自产在线| 一区在线播放视频| 成人亚洲精品久久久久软件| 精品国产免费一区二区三区四区| 日韩精品电影在线| 欧美精品自拍偷拍| 日日摸夜夜添夜夜添亚洲女人| 欧美性色欧美a在线播放| 亚洲人成精品久久久久久| av一区二区久久| 亚洲欧洲日韩一区二区三区| 成人免费va视频| 亚洲视频 欧洲视频| 91在线视频网址| 最新国产成人在线观看| 91麻豆免费观看| 亚洲一区成人在线| 3d成人动漫网站| 蜜臀av在线播放一区二区三区| 制服丝袜激情欧洲亚洲| 久久精品国产亚洲5555| www国产精品av| 国产成人日日夜夜| 亚洲色图色小说| 欧美久久一区二区| 麻豆精品国产91久久久久久| 欧美精品一区二区三区在线播放| 国产一区不卡视频| 国产精品久久99| 欧美日韩在线播放一区| 三级在线观看一区二区| 26uuu精品一区二区三区四区在线| 国产成人亚洲精品青草天美| 最新日韩av在线| 欧美一区二区在线不卡| 国产精品影视在线观看| 亚洲欧洲日韩av| 日韩小视频在线观看专区| 国产91精品一区二区麻豆网站| 亚洲婷婷综合久久一本伊一区| 欧美性做爰猛烈叫床潮| 久久成人综合网| 一区二区三区四区中文字幕| 日韩精品一区二区在线观看| 成人午夜看片网址| 亚洲午夜精品在线| 久久看人人爽人人| 一本一道综合狠狠老| 久久精品免费观看| 亚洲欧美日韩在线不卡| 欧美精品日韩综合在线| 成人午夜免费av| 麻豆极品一区二区三区| 亚洲激情综合网| 久久久午夜精品理论片中文字幕| 色综合天天综合网天天狠天天| 老司机精品视频线观看86 | 亚洲国产欧美在线| 久久网站最新地址| 在线免费观看视频一区| 国产精品2024| 日韩电影免费在线观看网站| 国产精品久久久久一区二区三区| 在线电影国产精品| 91免费小视频| 国产乱理伦片在线观看夜一区| 午夜电影网亚洲视频| 国产精品久久免费看| 久久久久久亚洲综合影院红桃| 欧美久久久久久久久久| 色噜噜狠狠一区二区三区果冻| 韩日av一区二区| 蜜臀久久久99精品久久久久久| 亚洲免费观看高清完整| 国产日韩精品一区二区三区| 欧美va在线播放| 日韩欧美一区二区三区在线| 91精品办公室少妇高潮对白| www.日本不卡| av电影在线观看完整版一区二区|