解讀26個ASP.Net開發(fā)新手的常見問題(2)_.Net教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:淺析ASp.Net自定義驗證碼控件
      最近自己寫了一個自定義驗證碼控件把它拿出來和大家分享分享 具體步驟 1---》新建asp.net 網(wǎng)站 2---》添加新建項目 ,選擇類庫 3---》新建兩個類 3.1--》自定義控件類(WebC

      以下為引用的內容:

      if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
      {
      e.Item.Attributes.Add("onclick","this.style.backgroundColor='#99cc00';
      this.style.color='buttontext';this.style.cursor='default';");
      }

      寫在DataGrid的_ItemDataBound里

      if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
      {
      e.Item.Attributes.Add("onmouseover","this.style.backgroundColor='#99cc00';
      this.style.color='buttontext';this.style.cursor='default';");
      e.Item.Attributes.Add("onmouseout","this.style.backgroundColor='';this.style.color='';");
      }

      8.關于日期格式

      以下為引用的內容:

        日期格式設定

      DataFormatString="{0:yyyy-MM-dd}"

        我覺得應該在itembound事件中

      e.items.cell["你的列"].text=DateTime.Parse(e.items.cell["你的列"].text.ToString("yyyy-MM-dd"))

      9.獲取錯誤信息并到指定頁面

      以下為引用的內容:

        不要使用Response.Redirect,而應該使用Server.Transfer

        e.g

      // in global.asax
      protected void Application_Error(Object sender, EventArgs e) {
      if (Server.GetLastError() is HttpUnhandledException)
      Server.Transfer("MyErrorPage.aspx");

      //其余的非HttpUnhandledException異常交給ASP.NET自己處理就okay了 :)
      }

        Redirect會導致post-back的產(chǎn)生從而丟失了錯誤信息,所以頁面導向應該直接在服務器端執(zhí)行,這樣就可以在錯誤處理頁面得到出錯信息并進行相應的處理

      10.清空Cookie

      以下為引用的內容:

      Cookie.Expires=[DateTime];
      Response.Cookies("UserName").Expires = 0

      11.自定義異常處理

      以下為引用的內容:

      //自定義異常處理類
      using System;
      using System.Diagnostics;

      namespace MyAppException
      {
      /// 〈summary>
      /// 從系統(tǒng)異常類ApplicationException繼承的應用程序異常處理類。
      /// 自動將異常內容記錄到Windows NT/2000的應用程序日志
      /// 〈/summary>
      public class AppException:System.ApplicationException
      {
      public AppException()
      {
      if (ApplicationConfiguration.EventLogEnabled)
      LogEvent("出現(xiàn)一個未知錯誤。");
      }

      public AppException(string message)
      {
      LogEvent(message);
      }

      public AppException(string message,Exception innerException)
      {
      LogEvent(message);
      if (innerException != null)
      {
      LogEvent(innerException.Message);
      }
      }

      //日志記錄類
      using System;
      using System.Configuration;
      using System.Diagnostics;
      using System.IO;
      using System.Text;
      using System.Threading;

      namespace MyEventLog
      {
      /// 〈summary>
      /// 事件日志記錄類,提供事件日志記錄支持
      /// 〈remarks>
      /// 定義了4個日志記錄方法 (error, warning, info, trace)
      /// 〈/remarks>
      /// 〈/summary>
      public class ApplicationLog
      {
      /// 〈summary>
      /// 將錯誤信息記錄到Win2000/NT事件日志中
      /// 〈param name="message">需要記錄的文本信息〈/param>
      /// 〈/summary>
      public static void WriteError(String message)
      {

      WriteLog(TraceLevel.Error, message);
      }

      /// 〈summary>
      /// 將警告信息記錄到Win2000/NT事件日志中
      /// 〈param name="message">需要記錄的文本信息〈/param>
      /// 〈/summary>
      public static void WriteWarning(String message)
      {

      WriteLog(TraceLevel.Warning, message);
      }

      /// 〈summary>
      /// 將提示信息記錄到Win2000/NT事件日志中
      /// 〈param name="message">需要記錄的文本信息〈/param>
      /// 〈/summary>
      public static void WriteInfo(String message)
      {
      WriteLog(TraceLevel.Info, message);
      }
      /// 〈summary>
      /// 將跟蹤信息記錄到Win2000/NT事件日志中
      /// 〈param name="message">需要記錄的文本信息〈/param>
      /// 〈/summary>
      public static void WriteTrace(String message)
      {

      WriteLog(TraceLevel.Verbose, message);
      }

      /// 〈summary>
      /// 格式化記錄到事件日志的文本信息格式
      /// 〈param name="ex">需要格式化的異常對象〈/param>
      /// 〈param name="catchInfo">異常信息標題字符串.〈/param>
      /// 〈retvalue>
      /// 〈para>格式后的異常信息字符串,包括異常內容和跟蹤堆棧.〈/para>
      /// 〈/retvalue>
      /// 〈/summary>
      public static String FormatException(Exception ex, String catchInfo)
      {
      StringBuilder strBuilder = new StringBuilder();
      if (catchInfo != String.Empty)
      {
      strBuilder.Append(catchInfo).Append("\r\n");
      }
      strBuilder.Append(ex.Message).Append("\r\n").Append(ex.StackTrace);
      return strBuilder.ToString();
      }

      /// 〈summary>
      /// 實際事件日志寫入方法
      /// 〈param name="level">要記錄信息的級別(error,warning,info,trace).〈/param>
      /// 〈param name="messageText">要記錄的文本.〈/param>
      /// 〈/summary>
      private static void WriteLog(TraceLevel level, String messageText)
      {

      try
      {
      EventLogEntryType LogEntryType;
      switch (level)
      {
      case TraceLevel.Error:
      LogEntryType = EventLogEntryType.Error;
      break;
      case TraceLevel.Warning:
      LogEntryType = EventLogEntryType.Warning;
      break;
      case TraceLevel.Info:
      LogEntryType = EventLogEntryType.Information;
      break;
      case TraceLevel.Verbose:
      LogEntryType = EventLogEntryType.SuccessAudit;
      break;
      default:
      LogEntryType = EventLogEntryType.SuccessAudit;
      break;
      }

      EventLog eventLog = new EventLog("Application", ApplicationConfiguration.EventLogMachineName, ApplicationConfiguration.EventLogSourceName );
      //寫入事件日志
      eventLog.WriteEntry(messageText, LogEntryType);

      }
      catch {} //忽略任何異常
      }
      } //class ApplicationLog
      }

      12.Panel 橫向滾動,縱向自動擴展

      〈asp:panel style="overflow-x:scroll;overflow-y:auto;">〈/asp:panel>

      13.回車轉換成Tab

      分享:解讀ASP.NET網(wǎng)站程序防SQL注入式攻擊方法
      一、什么是SQL注入式攻擊? 所謂SQL注入式攻擊,就是攻擊者把SQL命令插入到Web表單的輸入域或頁面請求的查詢字符串,欺騙服務器執(zhí)行惡意的SQL命令。在某些表單中,用戶輸入的內容直接用來

      來源:模板無憂//所屬分類:.Net教程/更新時間:2009-09-01
      相關.Net教程