Click here to Skip to main content
Licence 
First Posted 30 Mar 2004
Views 152,085
Bookmarked 39 times

.NET Remoting: Passing through the obstacles path from version 1.0 to 1.1

By | 31 Mar 2004 | Article
Houston, we have a problem. One small step for mankind, one Giant irritation for developers.

Introduction

The following article's aim is to help those of you who want to use .NET Remoting on Framework 1.1*. This article will not teach you Remoting, mainly because I am not an expert on that field. Furthermore, my CodeProject colleagues published some useful and nice to read articles on that issue (see links below). The attached projects were kept simple as possible to allow you to overcome the changes presented by Framework 1.1*. It handles the maladies of security exception, serialization and delegates issues.

Background

Recently, I have faced the challenge of exposing objects via .NET Remoting. Like the most of you, I have started with the MSDN, and of course CodeProject, but all the examples were suited for Framework 1.0 only. Attempts to run 1.0 project on a 1.1 Framework ends with lots of exceptions.

  • Type System.DelegateSerializationHolder and the types derived from it (such as System.DelegateSerializationHolder) are not permitted to be deserialized at this security level.
  • Because of security restrictions, the type System.Runtime.Remoting.ObjRef cannot be accessed.
  • This remoting proxy has no channel sink which means either the server has no registered server channels that are listening, or this application has no suitable client channel to talk to the server.

The web is full of developers' complaints on the very same problems but I have not found a simple, corrective and comprehensive example. So there you have it!.

Code snippets

Activate through Config files

Server side configuration

 <system.runtime.remoting>
    <application name="ServerAssembly" >
     <service>
          <!-- type: is the full type name 
(type the class that inherit from MBR,assembly) of the 
object-->
          <!-- objectUri - alias -->
          <!-- Server tells remoting Here's a type 
Here's how and when to instantiate the type
Here's the name (end point) a client will use to contact the type
            -->            
  
        <wellknown mode="Singleton" 
            type="SharedAssembly.SharedObj, SharedAssembly" 

objectUri="ParachuteExample" />
           </service>
         <channels>
            <channel ref="tcp" port="6123">    
                <serverProviders>            
                    <formatter ref="binary" typeFilterLevel="Full" />
                </serverProviders>                
            </channel>    
         </channels>     
    </application>
  </system.runtime.remoting>

Server side code

RemotingConfiguration.Configure ("ServerAssembly.exe.config");

Client side configuration

   <system.runtime.remoting>
      <application>
         <client>
            <wellknown 
               type="SharedAssembly.SharedObj, SharedAssembly"
               url="tcp://localhost:6123/ParachuteExample"
            />
         </client>
       <channels>
    <channel ref="tcp" port="0">        
     <clientProviders>            
      <formatter ref="binary" />
     </clientProviders>
     <serverProviders>            
      <formatter ref="binary" typeFilterLevel="Full" />
     </serverProviders>            
    </channel>
   </channels>

      </application>

Client side code

RemotingConfiguration.Configure ("ClientAssembly.exe.config");
SharedObj remObject = new SharedObj();

Activate through code

Server side

    BinaryClientFormatterSinkProvider clientProvider = null;
    BinaryServerFormatterSinkProvider serverProvider = 
       new BinaryServerFormatterSinkProvider();
    serverProvider.TypeFilterLevel = 

    System.Runtime.Serialization.Formatters.TypeFilterLevel.Full;
                
    IDictionary props = new Hashtable();
    props["port"] = 6123;
    props["typeFilterLevel"] = TypeFilterLevel.Full;
    TcpChannel chan = new TcpChannel(
    props,clientProvider,serverProvider);

    ChannelServices.RegisterChannel(chan);

    RemotingConfiguration.RegisterWellKnownServiceType(typeof(SharedObj),
                    "ParachuteExample",
                    WellKnownObjectMode.Singleton);

Client Side

    BinaryClientFormatterSinkProvider clientProvider = 
       new BinaryClientFormatterSinkProvider();
    BinaryServerFormatterSinkProvider serverProvider = 
       new BinaryServerFormatterSinkProvider();
    serverProvider.TypeFilterLevel = 

    System.Runtime.Serialization.Formatters.TypeFilterLevel.Full;
                
    IDictionary props = new Hashtable();
    props["port"] = 0;
    string s = System.Guid.NewGuid().ToString();
    props["name"] = s;
    props["typeFilterLevel"] = TypeFilterLevel.Full;
    TcpChannel chan = new TcpChannel(
    props,clientProvider,serverProvider);

    ChannelServices.RegisterChannel(chan);


    Type typeofRI = typeof(IParachute);
    IParachute remObject = (IParachute)Activator.GetObject(    typeofRI,
                    "tcp://localhost:6123/ParachuteExample");

Using the code

Since some of you like configuration files while others like to connect and create the well known object via code, I have included two projects accordingly. Both projects, codeActivationExample.zip and configFileExample.zip, include the same assemblies as follows:

  • ClientAssembly
  • ServerAssembly
  • SharedAssembly

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Cohen Shwartz Oren

Other
Applicure
Israel Israel

Member

Oren, lives in Israel and work as R&D Manager in Applicure Technologies. A company that develop a software-based products for web application security.
 
Since the .Net kickoff he lives the .NET world and managed and develops in various aspects of its technologists: .Net Remoting, Web services, Reflection WMI Management, Ajax and Web Forms.
 
His Software engineering experience includes:
* Design of complex large scale client-server architectures with emphasis on performance issues.
* Design Windows and Web Applications with emphasis on User Experience and Usability.
* Migration of C++ and COM Software projects to .Net.
* Frameworks like: MFC, ATL and .Net
 
For Oren computer programming is not only a job but also a hobby he developed some useful
freeware
. Apart from programming, he is practicing skydiving and snowboarding.


Blog: Blog:The RnD Manager
.

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
GeneralMy vote of 2 Pinmemberngoj14:22 29 Dec '09  
QuestionBug Remoting by TCP channel in Vista PinmemberZapfchen3:57 7 Jul '09  
AnswerRe: Bug Remoting by TCP channel in Vista PinmemberZapfchen2:36 9 Jul '09  
GeneralServer Raise Event Pinmembertbman14:54 16 Jan '09  
GeneralHi Thanks! HttpChannel is working now! Pinmemberjayzonpanget19:02 21 Oct '08  
GeneralSame problem in HttpChannel Pinmemberjayzonpanget18:56 21 Oct '08  
GeneralExcellent article, got exactly what I wanted Pinmemberebranson19698:43 12 May '08  
GeneralThanks a lot! Pinmembersidkud12:53 24 Dec '07  
GeneralWMI versus .Net Remoting Pinmemberpuromtec16:36 9 Aug '07  
GeneralRe: WMI versus .Net Remoting PinmemberCohen Shwartz Oren0:25 13 Aug '07  
GeneralRe: WMI versus .Net Remoting [modified] Pinmemberpuromtec14:42 14 Aug '07  
GeneralNicely Done PinmemberChristopher G. Lasater8:30 23 May '07  
GeneralRe: Nicely Done PinmemberCohen Shwartz Oren9:30 23 May '07  
GeneralExample fails using HttpChannel Pinmemberrcarsten22:13 14 Nov '06  
GeneralRe: Example fails using HttpChannel Pinmemberjayzonpanget19:03 21 Oct '08  
QuestionRetrieving events in VBA PinmemberJEBond5:46 24 Oct '06  
Excellent article. Based on that I tried to forward events received by the client side to a VBA class. In other words, I made the client side COM visible so I could forward events to VBA (see "Understanding Classic COM Interoperability With .NET Applications" article). It worked fine for events raised in a VBA code, but when the event is raised by another client I get a serialization problem. Any tips on that?
Thanks a lot.

GeneralThanks a lot PinmemberNehal Kanani0:05 20 Jan '06  
GeneralRe: Thanks a lot PinmemberCohen Shwartz Oren6:14 12 May '07  
GeneralEvents PinsussHector Caban0:27 2 Apr '05  
GeneralRe: Events PinmemberCohen Shwartz Oren6:13 12 May '07  
GeneralRe: Events PinmemberChris Zubriski8:03 16 Sep '08  
Generalnew cool stuff PinmemberAlex Sivokho23:23 3 Feb '05  
GeneralRe: new cool stuff PinmemberCohen Shwartz Oren2:20 17 Mar '05  
GeneralRe: new cool stuff Pinmemberajn999918:40 17 Mar '05  
GeneralSome Remoting Exceptions and how to deal with them PinmemberCohen Shwartz Oren0:08 18 Oct '04  

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web01 | 2.5.120529.1 | Last Updated 1 Apr 2004
Article Copyright 2004 by Cohen Shwartz Oren
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid