Domanda

Ho scritto una piccola applicazione utilizzando C # per copiare un documento nella cartella un individui 'Documenti' sul nostro server DMS.

Ho beased il codice attorno alla lista fornita nel. 'WorkSite SDK 8: Utilizzare l'IMANEXT2Lib.IManRefileCmd a File Nuovo documento cartelle' blog

Utilizzando questo codice in un'applicazione WinForm non ho problemi a copiare il file dalla cartella di origine nella cartella degli utenti DMS 'Documenti'.

Tuttavia, se io uso il codice in una riga di comando dell'applicazione / dll o qualsiasi altro tipo di applicazione (diverso da WinForm) durante il processo di copia che ricevo i messaggi di errore;

1.

  

è verificato un errore quando si tenta di accedere all'evento!

     

IManExt: errore si è verificato quando tentano di accedere l'evento

!      

Accesso negato.

2.

  

Il documento è stato importato nel database, ma non poteva essere aggiunto   la cartella.

     

IManExt: Il documento è stato importato nel database, ma non poteva essere   aggiunto alla cartella.

     

IManExt.LogRuleEventsCmd.1: errore si è verificato quando tentano di accedere l'evento

!      

IManExt.LogRuleEventsCmd.1:. Accesso negato

è verificato un errore quando si tenta di accedere all'evento!

-% -

Qualcuno sa il motivo per cui mi piacerebbe ricevere il 'Accesso negato' messaggi di errore quando si utilizza un'applicazione non WinForms per copiare i documenti? Quello che avrei bisogno di fare per ovviare a questo problema?

Qualsiasi aiuto sarebbe fantastico!

Codice sul posto:

    public void moveToDMS(String servName, String dBName, String foldName)
    {
        const string SERVERNAME = servName; //Server name
        const string DATABASENAME = dBName; //Database name
        const string FOLDERNAME = foldName; //Matter alias of workspace

        IManDMS dms = new ManDMSClass();
        IManSession sess = dms.Sessions.Add(SERVERNAME);
        sess.TrustedLogin();

        //Get destination database.
        IManDatabase db = sess.Databases.ItemByName(DATABASENAME);

        //Get destination folder by folder and owner name.
        IManFolderSearchParameters fparms = dms.CreateFolderSearchParameters();
        fparms.Add(imFolderAttributeID.imFolderOwner, sess.UserID);
        fparms.Add(imFolderAttributeID.imFolderName, FOLDERNAME);           

        //Build a database list in which to search.
        ManStrings dblist = new ManStringsClass();
        dblist.Add(db.Name);

        IManFolders results = sess.WorkArea.SearchFolders(dblist, fparms);

        if (results.Empty == true)
        {
            //No results returned based on the search criteria.
            Console.WriteLine("NO RESULTS FOUND!");
        }

        IManDocumentFolder fldr = null;

        if (results.Empty == false)
        {
            //Assuming there is only one workspace returned from the results.
            fldr = (IManDocumentFolder)results.ItemByIndex(1);
        }

        if (fldr != null)
        {
            // Import file path
            string docPath = @"C:\Temp\";
            string docName = "MyWord.doc";

            // Create an instance of the ContextItems Collection Object.
            ContextItems context = new ContextItemsClass();

            // Invoke ImportCmd to import a new document to WorkSite database.
            ImportCmd impCmd = new ImportCmdClass();

            // The WorkSite object you pass in can be a database, session, or folder.
            // Depends on in where you want the imported doc to be stored.
            context.Add("IManDestinationObject", fldr); //The destination folder.

            // Filename set here is used for easy example, a string variable is normally used here
            context.Add("IManExt.Import.FileName", docPath + docName);

            // Document Author
            context.Add("IManExt.Import.DocAuthor", sess.UserID); //Example of a application type.

            // Document Class
            context.Add("IManExt.Import.DocClass", "BLANK"); //Example of a document class.
            //context.Add("IManExt.Import.DocClass", "DOC"); //Example of a document class.

            // Document Description (optional)
            context.Add("IManExt.Import.DocDescription", docName); //Using file path as example of a description.

            // Skip UI
            context.Add("IManExt.NewProfile.ProfileNoUI", true);

            impCmd.Initialize(context);
            impCmd.Update();

            if (impCmd.Status == (int)CommandStatus.nrActiveCommand)
            {
                impCmd.Execute();

                bool brefresh = (bool)context.Item("IManExt.Refresh");
                if (brefresh == true)
                {
                    //Succeeded in importing a document to WorkSite
                    IManDocument doc = (IManDocument)context.Item("ImportedDocument");

                    //Succeeded in filing the new folder under the folder.
                    Console.WriteLine("New document number, " + doc.Number + ", is successfully filed to " + fldr.Name + " folder.");
                }

            }


        }

    }

È stato utile?

Soluzione

Nel caso in cui questo aiuta a qualcun altro.

Sembra che il mio problema era il risultato di un problema di threading.

Ho notato che le applicazioni # WinForm C che avevo creato sono stati fissati automaticamente per funzionare su un singolo thread 'ApartmentState' ([STAThread]).

considerando che le domande e console libreria di classi Stato e la gestione dei thread non erano stati definiti all'interno del progetto ed è stato manipolato con la configurazione di default .NET.

Per ottenere questo al lavoro:. Nell'applicazione console, ho solo aggiunto il tag [STAThread] sulla linea sopra la mia chiamata al metodo principale

Nella libreria di classi, ho definito un filo per la funzione riferimento al IMANxxx.dll e impostare ApartmentState es.

Thread t = new Thread(new ThreadStart(PerformSearchAndMove));
t.SetApartmentState(ApartmentState.STA);
t.Start();

In entrambi i casi assicurando filo singolo 'ApartmentState' stata implementata insieme risolverebbe il problema.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top