Frage

Ich habe mit C # eine kleine Anwendung das Schreiben eines Dokuments in ein Individuen kopieren ‚Eigene Dateien‘ Ordner auf der DMS-Server.

Ich habe den Code um den beased im Listing provided 'Worksite SDK 8: IMANEXT2Lib.IManRefileCmd Nutzen Sie Neues Dokument Ordner-Datei'. Blog

Mit diesem Code in einer WinForm-Anwendung habe ich keine Probleme Kopieren Sie die Datei aus dem Quellordner in den Benutzer DMS Ordner ‚Eigene Dateien‘.

Allerdings, wenn ich den Code in einer Befehlszeile verwenden application / DLL oder jede andere Art von Anwendung (außer WinForm) während des Kopiervorganges ich die Fehlermeldungen angezeigt werden;

1.

  

Fehler beim Versuch das Ereignis zu protokollieren!

     

IManExt: Fehler beim versuchen, das Ereignis zu protokollieren

     

Zugriff verweigert wird.

2.

  

Das Dokument wurde in die Datenbank importiert, aber nicht hinzugefügt werden könnte, um   der Ordner.

     

IManExt: Das Dokument wurde in die Datenbank importiert, kann aber nicht sein   in den Ordner.

     

IManExt.LogRuleEventsCmd.1: Fehler beim versuchen, das Ereignis zu protokollieren

     

IManExt.LogRuleEventsCmd.1: Zugriff verweigert.

Fehler beim Versuch das Ereignis zu protokollieren!

-% -

Wer weiß, warum ich hatte die Aufnahme der ‚Zugriff verweigert‘ Fehlermeldung, wenn eine nicht-WinForms-Anwendung unter Verwendung von Dokumenten zu kopieren? Was würde ich dieses Problem tun müssen, um zu umgehen?

Jede Hilfe wäre erstaunlich!

Code-in-Ort:

    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.");
                }

            }


        }

    }

War es hilfreich?

Lösung

Für den Fall, das hilft jemand anderes.

Es scheint, mein Problem ist das Ergebnis eines Threading-Problems war.

Ich habe bemerkt, die C # Winform apps ich geschaffen hatte, wurden automatisch auf einem einzigen 'ApartmentState' Thread ausgeführt ([STAThread]).

Während die Konsolenanwendungen & Klassenbibliothek Threadzustand und das Management hatte sich nicht im Rahmen des Projektes definiert und wurde mit dem Standard-.NET-Konfigurations behandelt werden.

Um diese an der Arbeit. In der Konsolenanwendung, ich habe gerade den [STAThread]-Tag auf der Linie über meinem Hauptmethodenaufruf hinzugefügt

In der Klassenbibliothek, definierte ich einen Thread für die Funktion Referenzierung der IMANxxx.dll und setze Apartment z.

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

In beiden Fällen gewährleistet Single 'ApartmentState' Thread wurde implementiert Satz würde das Problem beheben.

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top