How to use PKMCDO to programmatically upload a document to a folder in Visual C#
This article was previously published under Q312541
ADO and ADO MD have not been fully tested in a Microsoft .NET Framework environment. They may cause intermittent issues, especially in service-based applications or in multithreaded applications. The techniques that are discussed in this article should only be used as a temporary measure during migration to ADO.NET. You should only use these techniques after you have conducted complete testing to make sure that there are no compatibility issues. Any issues that are caused by using ADO or ADO MD in this manner are unsupported. For more information, see the following article in the Microsoft Knowledge Base:
You receive unexpected errors when using ADO and ADO MD in a .NET Framework application
This article describes how to use Microsoft Publishing and Knowledge Management Collaboration Data Objects (PKMCDO) for Microsoft Web Storage System to upload a document to a folder in the document library on a Microsoft SharePoint Portal Server workspace by using Microsoft Visual C#.
To use PKMCDO to upload a document to a folder in the document library on a SharePoint Portal Server workspace, follow these steps:
- Start Microsoft Visual Studio .NET or Microsoft Visual Studio 2005.
- On the File menu, point to New, and then click Project.
- Under Project Types, select Visual C# Projects.
Note In Visual Studio 2005, click Visual C# under Project Types.
- Under Templates, select Console Application, and then click OK.
By default, Class1.cs is created in Visual Studio .NET. Program.cs is created in Visual Studio 2005.
- Add a reference to the Microsoft PKMCDO for Microsoft Web Storage System library. To do so,
follow these steps:
- On the Project menu, click Add Reference.
- Click the COM tab, locate Microsoft PKMCDO for Microsoft Web Storage System Library, and then click
Note In Visual Studio 2005, you do not have to click Select.
- In the Add References dialog box, click OK.
- If you are prompted to generate wrappers for the libraries that you selected, click Yes.
- Repeat step 5 to add a reference to the Microsoft ActiveX Data Objects 2.6 Library.
- Insert the following code in the existing class where you see the comment that says "TODO: Add code to start application here:"
// TODO: Add code to start application here.
PKMCDO.KnowledgeDocument oDoc = new PKMCDO.KnowledgeDocument();
PKMCDO.KnowledgeFolder oFolder = new PKMCDO.KnowledgeFolder();
//TODO: Change the following variables to reflect your SharePoint Portal Server environment.
String sFilePath = "c:\\testdoc.txt" ;
String sAuthor = "AuthorName";
String sTitle = "TestDoc.txt";
String sDesc = "Test Description";
Object vEmpty = Missing.Value;
oWrkStream = (ADODB._Stream )oDoc.OpenStream(
oWrkStream.Type = ADODB.StreamTypeEnum.adTypeBinary;
oDoc.Author = sAuthor;
oDoc.Title = sTitle;
oDoc.Description = sDesc ;
oDoc = null;
- Insert the following statement after line 1 in Class1.cs:
- Search for TODO in the code, and then modify the code for your environment.
- Press F5 to build and to run the program.
- Load your SharePoint Portal Server folder in Microsoft Internet Explorer, and then make sure that you can see the document.
For more information, see the SharePoint Portal Server Software Development Kit (SDK).
Article ID: 312541 - Last Review: November 29, 2007 - Revision: 3.4
- Microsoft Visual C# 2005 Express Edition
- Microsoft Visual C# .NET 2003 Standard Edition
- Microsoft Visual C# .NET 2002 Standard Edition
- Microsoft SharePoint Portal Server 2001