如何在后台运行ASP.NET页面?

时间:2013-07-04 05:54:33

标签: c# asp.net background-process

大家好我有要求见面,我创建了一个ASP.NET页面,当页面加载时从sap中获取数据。我已经编写了用于在PAGE LOAD中获取SAP表的代码。

我需要在一天中自动运行页面上一次(没有用户插入),因此它可以自动同步ASP.NET和SAP之间的信息。

这是我的代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; 
using System.Web.UI;
using System.Data;
using System.Web.UI.WebControls;  
using System.Text;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Web.Security;
using System.Security.Authentication;
using First.EHSIMS;
using First.EHSIMS.Dbml;
using First.EHSIMS.Breadcrumb_New;
using SAP.Middleware.Connector;


 public class SAPSystemConnect : IDestinationConfiguration
{
public RfcConfigParameters GetParameters(string destinationName)
{

    RfcConfigParameters parms = new RfcConfigParameters();
    if ("DEV".Equals(destinationName))
    {

        parms.Add(RfcConfigParameters.AppServerHost, "ECC6");
        parms.Add(RfcConfigParameters.SystemNumber, "04");
        parms.Add(RfcConfigParameters.User, "sapuser");
        parms.Add(RfcConfigParameters.Password, "newmaars1");
        parms.Add(RfcConfigParameters.Client, "800");
        parms.Add(RfcConfigParameters.Language, "EN");
        parms.Add(RfcConfigParameters.PoolSize, "5");
        parms.Add(RfcConfigParameters.MaxPoolSize, "10");
        parms.Add(RfcConfigParameters.IdleTimeout, "000");

    }
    return parms;
   }

   public bool ChangeEventsSupported()
  {
    //throw new NotImplementedException();
    return false;
  }

  public event RfcDestinationManager.ConfigurationChangeHandler ConfigurationChanged;
  }


   public partial class Sap_Connection_sapcon : System.Web.UI.Page
   {

  public static DataTable CreateDataTable(IRfcTable rfcTable)
  {
    var dataTable = new DataTable();

    for (int element = 0; element < rfcTable.ElementCount; element++)
    {
        RfcElementMetadata metadata = rfcTable.GetElementMetadata(element);
        dataTable.Columns.Add(metadata.Name);
    }

    foreach (IRfcStructure row in rfcTable)
    {
        DataRow newRow = dataTable.NewRow();
        for (int element = 0; element < rfcTable.ElementCount; element++)
        {
            RfcElementMetadata metadata = rfcTable.GetElementMetadata(element);
            newRow[metadata.Name] = row.GetString(metadata.Name);
        }
        dataTable.Rows.Add(newRow);
    }

    return dataTable;
   }


    protected void Page_Load(object sender, EventArgs e)
    {

    SAPSystemConnect c = new SAPSystemConnect();
    RfcDestinationManager.RegisterDestinationConfiguration(c);
    RfcDestination rfcDest = null;
    rfcDest = RfcDestinationManager.GetDestination("DEV");
    try
    {
        RfcDestination mydestination = RfcDestinationManager.GetDestination("DEV");
        RfcRepository myrepository = mydestination.Repository;
        IRfcFunction position = myrepository.CreateFunction("ZPOSI");       
        IRfcTable positable = position.GetTable("POSITIONTAB1");
        IRfcTable jobtable = position.GetTable("JOBTAB");          
        position.Invoke(mydestination);
        RfcDestinationManager.UnregisterDestinationConfiguration(c); 


        if (jobtable.RowCount > 0)
            {
                DataTable JOBTABLE = CreateDataTable(jobtable);
                using (EHSIMSDataContext db = new EHSIMSDataContext())
                foreach (DataRow newRow1 in JOBTABLE.Rows)
                {
                    string JOB_ID = newRow1["JOB_ID"].ToString();

                    JOB34 _job1 = (from job1 in db.JOB34s
                                  where job1.JOB_NO.Equals(JOB_ID)
                                  select job1).SingleOrDefault<JOB34>();
                    if(_job1 == null)
                    {
                        JOB34 _JOB;
                        _JOB = new JOB34();
                        Guid g = Guid.NewGuid();
                        Guid g1 = Guid.NewGuid();
                        _JOB.JOB_ID = g1;
                        _JOB.JOB_NO = newRow1["JOB_ID"].ToString();
                        _JOB.NAME = newRow1["JOB_TXT"].ToString();
                        db.JOB34s.InsertOnSubmit(_JOB);
                        db.SubmitChanges();
                    }
                    else
                    {

                    }
                }
        }
        else
        {
            posid.Text = "notworking";
        }
        if (positable.RowCount > 0)
        {

            DataTable dataTable = CreateDataTable(positable);
            using (EHSIMSDataContext db1 = new EHSIMSDataContext())

                foreach (DataRow newRow in dataTable.Rows)
                {
                    string POS_ID = newRow["POSITION_ID"].ToString();

                    POSITION34 _pos1 = (from job in db1.POSITION34s
                                  where job.POSITION_NO.Equals(POS_ID)
                                        select job).SingleOrDefault<POSITION34>();

                    if (_pos1 == null)
                    {

                        string JOB_ID = newRow["JOB_ID"].ToString();

                        JOB34 _job = (from job in db1.JOB34s
                                      where job.JOB_NO.Equals(JOB_ID)
                                      select job).SingleOrDefault<JOB34>();



                        POSITION34 _pos;
                        _pos = new POSITION34();
                        Guid g = Guid.NewGuid();
                        Guid g1 = Guid.NewGuid();
                        _pos.POSITION_ID = g;
                        _pos.POSITION_NO = newRow["POSITION_ID"].ToString();
                        _pos.NAME = newRow["POSITION_TXT"].ToString();
                        _pos.REPORTED_TO = newRow["REPORTED_TO"].ToString();
                        _pos.JOB_ID = _job.JOB_ID;


                        db1.POSITION34s.InsertOnSubmit(_pos);
                        db1.SubmitChanges();
                    }
                    else
                    { 

                    }
                }

        }
        else
        {

            posid.Text = "notworking";
        }
        }
        catch (Exception ej)
       {
        posid.Text = ej.Message;
        }
     }

    }  

1 个答案:

答案 0 :(得分:0)

有几种选择:

  • 您可以使用独立的Windows服务来完成此任务,或者
  • 在Application Start上启动一个线程,该线程将每天执行一次操作,或
  • 在每个页面上加载检查数据库,如果操作在一天前完成并执行此操作

另见:

How to do background processing in ASP without using windows service

Can I use threads to carry out long-running jobs on IIS?