explains step by step of accessing COM+ application using C#. The code is
compiled using beta2. Microsoft (R) Visual C# Compiler Version 7.00.9254 [CLR
version v1.0.2914]. It can be used with Beta1 with some minor modification.
If we want need to access the existing COM+ application with any .net
supported language, we don't need to modify the single line of existing COM+ application, despite of
the fact their execution model is completely different.
Here is the step-by-step easy example of doing the same. We can access it in two ways, Early Binding and
Late binding (remembered the old VB concepts). We will first look at Early binding example...
TlbImp.exe: (Type Library
(converts, generates wrapper DLL) the type definition found in COM component into equivalent .net
definitions (or metadata), understandable by
Common Language Runtime (CLR). The metadata generated, by TlbImp can be viewed
Ildasm.exe. If you are using the Visual Studio development environment, you only need to add
a reference to the COM type library and the conversion is done automatically.
To use existing COM+ application we need create Runtime Callable Wrapper (RCW) using
TlbImp.Exe, with VS.Net it is created automatically,
when we reference the existing COM Component. The difference is that, VS.Net create the RCW with the same name as the original DLL, which may
be confusing, and with
TlbImp.Exe, we can specify the different name using
Let us assume that we have a COM Component with a method Add,
which takes two parameter A and B and returns the Sum.
We have to register COM DLL first before using it...
Public Function Add(A As Long, B As Long) As Long
Add = A + B
Now we will run
TlbImp.Exe in our existing DLL i.e. CompAdd.Dll
This generated a wrapper dll CompAddRcw.dll. we can view this DLL using
The discussion in
IlDasm.Exe is beyond the scope of this article. Now
we will simply write code to use the Wrapper DLL, which
in turn will be calling the actual DLL. Now let us look into the C# code
for doing it.
As we can see that we are getting the same kind of
tooltip as we used to get with VB when we do early binding. Compile the program with /r:
csc TestClient.cs /r:CompAddRcw.dll. Execute it and
we just called COM component with .net.
Late binding we have to use
namespace, which allows us
to programmatically access the types contained in any assembly. We will see how
we can do late bindings in four easy steps..
- We have Get
IDispatch Interface using
- We have to create instance using the type ID
- We have to make array of arguments (if required)
- Invoke the Method using
Type.GetTypeFromProgID is used to load the type information of the COM
object. The call to
Activator.CreateInstance returns an instance of the COM object. And Finally
InvokeMember function is
used to call the Method of COM object.
This article gives very basic idea of using the old COM Application,
for the purpose of simplicity and to focus on the purpose of the
article no error handling has been done. In my next article we will
see how can we use .NET component with VB.