天天看点

将数据存储到SmartObject中

根据对K2 Blackpearl的一定了解,SmartObject可以帮助我们完成一些数据持久化的工作,以下是将表单中的数据存储到SmartObject中的相关代码,SmartObject的结构我就不一一赘述了,相信你能看懂的。

这些代码SDK中也有,在此贴出来,希望有大虾可以予小弟以指点。

//将表单中的数据存储到SmartObject中
private void SaveData(int argProcInstanceID)
{
    SourceCode.SmartObjects.Client.SmartObjectClientServer socs = new SourceCode.SmartObjects.Client.SmartObjectClientServer();
            
    // build a connection string
    SourceCode.Hosting.Client.BaseAPI.SCConnectionStringBuilder connectionString = new SourceCode.Hosting.Client.BaseAPI.SCConnectionStringBuilder();
    connectionString.Authenticate = true;
    connectionString.Host = System.Configuration.ConfigurationManager.AppSettings["K2Server"];
    connectionString.Integrated = true;
    connectionString.IsPrimaryLogin = true;
    connectionString.Port = Convert.ToUInt32(System.Configuration.ConfigurationManager.AppSettings["HostServicePort"]);
    //connectionString.UserID = "your user name";
    //connectionString.Password = "your password";
    connectionString.WindowsDomain = "dahanis";
    connectionString.SecurityLabelName = "K2";

    // open a K2 Server connection
    socs.CreateConnection();
    socs.Connection.Open(connectionString.ToString());
    try 
    {
        // get a handle to the 'SODHFKSQ' SmartObject
        SourceCode.SmartObjects.Client.SmartObject so = socs.GetSmartObject("so_DHFKSQ");

        // specify which method will be called
        so.MethodToExecute = "Create";

        // specify input parameters for the method
        so.Properties["ProInstanceID"].Value = argProcInstanceID.ToString();
        so.Properties["Folio"].Value = Folio.Text.Trim();
        so.Properties["ApplyEmployee"].Value = ApplyEmployee.Text.Trim();
        so.Properties["ApplyAmount"].Value = ApplyAmount.Text.Trim();
        so.Properties["ApplyDate"].Value = ApplyDate.Text.Trim();
        so.Properties["HigherLevelApprover"].Value = HigherLevelApprover.Text.Trim();
        so.Properties["FinanceApprover"].Value = FinanceApprover.Text.Trim();

        // call the method
        socs.ExecuteScalar(so);

        // note: if a method of type 'list' was specified, then the 'ExecuteList' method should be called
        // serverName.ExecuteList(smartObject);
    }
    catch(Exception ex)
    {
        throw new Exception(ex.Message);
    }
    finally 
    {
        socs.Connection.Close();
    }

}