64 bit C# with a 32 bit VB6 COM object

前端 未结 4 1051
情话喂你
情话喂你 2020-11-29 10:55

I have a 32 bit in-proc STA VB6 dll. I sadly cannot do anything about this. My C# component greatly benefits from being 64 bit. Is there anyway to call/interface with this 3

4条回答
  •  一整个雨季
    2020-11-29 11:29

    You can load a (for example) 32-bit only DLL in a surrogate, and access it from a 64-bit process, in the following manner.

    This will work provided there is a marshaller available, which there generally will be for a component with a typelib because they usually use the standard marshaller. It will not work if the object requries a custom prox/stub because 64 bit versions won't exist, or you wouldn't have this problem in the first place.

    How to register a third-party 32-bit component for use from a 64-bit client

    First you need an AppID. If the DLL already has an AppID, you should use that. You can find out by checking under the CLSID key for the CoClass you are interested in.

    The example used here is the Capicom.HashedData and Capicom.EncryptedData classes. Capicom is 32-bit only.

    • AppID: CAPICOM does not have an AppID, so for the AppID I have just used the CLSID of the EncryptedData class.

    • CLSID: You need a list of the CLSID of each class you want to be able to create from 64-bit clients. In this example, it is just EncryptedData and HashedData.

    • Registration: Create a registry file containing the details, as per the example, and load it into the registry.

    You should use the 32-bit version of Regedit to do this, as it is a 32-bit component. If you have a 64-bit component you want to access from 32-bits, use the other one. (This is because of the registry virtualisation for the 32-bit compatibility layer- using the the matching bitness version of regedit takes care of this issue for you, by making sure you edit the correct virtualised version of the registry).

    Windows Registry Editor Version 5.00
    
    
    ;;; Capicom AppID - just using the Capicom.EncryptedData CLSID
    ;;; Use default surrogate = empty string
    [HKEY_CLASSES_ROOT\AppID\{A440BD76-CFE1-4D46-AB1F-15F238437A3D}]
    "DllSurrogate"=""
    
    ;;; Capicom.EncryptedData
    [HKEY_CLASSES_ROOT\CLSID\{A440BD76-CFE1-4D46-AB1F-15F238437A3D}]
    AppID="{A440BD76-CFE1-4D46-AB1F-15F238437A3D}"
    
    ;;; Capicom.HashedData - use same AppID for all!!!!!
    [HKEY_CLASSES_ROOT\CLSID\{CE32ABF6-475D-41F6-BF82-D27F03E3D38B}]
    AppID="{A440BD76-CFE1-4D46-AB1F-15F238437A3D}"
    

    Save to a myComponent-dllhost.reg file, and away you go.

    c:\windows\sysWow64\regedit.exe "myComponent-dllhost.reg"
    

    You should now be able to access Capicom.HashedData and Capicom.EncryptedData from 64-bit script/COM hosts.

    Notes:

    • This only works for basic OLE Automation types. Any object compatible with Windows Scripting Host scripts in VBScript or JavaScript should be OK.
    • You only have to add the AppID to directly creatable objects. That's basically those with an InprocServer32 entry. Objects which are generated from factories or which are only available as child objects do not have to have an AppID added.
    • If there is already an AppID all you need to do is add the empty-string "DllSurrogate" entry. That's it!
    • this will NOT affect normal clients of the DLL. As long as the bit-ness matches, they will continue to be loaded in-process as before. The only difference it will make is that it will become possible to instantiate it out-of-process from a client of a different bitness.

提交回复
热议问题