ASP.Net中定时执行任务的方法
2014-12-09  高端网站定制
  这里的定时执行任务,指的是每天或者每个月的某个时间执行一项任务。思路有很多,如果只是对数据库数据作定时校验或者重置标识,加之又有足够的服务器配置权限,那么可以直接在SQL Server里建立维护任务,交给SQL Agent服务定期执行就好了。如果没有足够的服务器配置权限,也可以通过下面的方法来完成操作。

  通过Application_Start事件来判断时间间隔并调用相关的业务逻辑

  如果要处理的业务比较复杂,建议数据操作尽量写在存储过程中,然后写相应的调用方法来实现。这里以每天凌晨email发送一次报表为例

  这里首先想到的就是利用 Global.asax 文件来实现, 以下Global文件的内容。

  Copy to Clipboard引用的内容:

  <%@ Application Language="C#" %> 
  <%@ Import Namespace="System.Threading" %> 
  
  <mce:script runat="server"><!--

  //这里使用静态保持对这处Timer实例的引用,以免GC 
  private static System.Threading.Timer timer = null; 

  protected void Application_Start(object sender, EventArgs e) { 
  //计算现在到目标时间要过的时间段。 
  DateTime LuckTime = DateTime.Now.Date.Add(new TimeSpan(7, 0, 0)); 
  TimeSpan span = LuckTime - DateTime.Now; 
  if (span < TimeSpan.Zero) { 
  span = LuckTime.AddDays(1d) - DateTime.Now; 
  } 

  //按需传递的状态或者对象。 
  object state = new object(); 
  //定义计时器 
  timer = new System.Threading.Timer( 
  new TimerCallback(CertainTask), state, 
  span, TimeSpan.FromTicks(TimeSpan.TicksPerDay)); 
  } 
 
  protected void Application_End(object sender, EventArgs e) { 
  //结束时记得释放 
  if (timer != null) { timer.Dispose(); } 
  } 
 
  //这里是指定时间执行的代码,必须是静态的。 
  private static void CertainTask(object state) { 
  //这里写你的任务逻辑 
  } 
  // --></mce:script>
  复制代码
 
  当然,你也可以通过WebService来实现业务逻辑
 
  void Application_Start(object sender, EventArgs e)
  {

      // 在应用程序启动时运行的代码
      System.Timers.Timer myTimer = new System.Timers.Timer(60000);
      myTimer.Elapsed += new System.Timers.ElapsedEventHandler
  (OnTimedEvent);
      myTimer.Interval = 60000;
      myTimer.Enabled = true;
      }
  private static void OnTimedEvent(object source,
  System.Timers.ElapsedEventArgs e)
    {

      localhost.WebService mysrv = new localhost.WebService();
      mysrv.CertainTask();     //调用相应的方法
    }
  复制代码