This document covers the following topics:
Writing a client application with the EntireX .NET Wrapper typically requires the following steps:
Starting from an IDL file, generate a C# client interface object as described under Using the .NET Wrapper. From the context menu of the IDL file, choose > > . As an alternative, use the Microsoft Visual Studio Wizard for EntireX .NET Wrapper. Both approaches generate C# sources from an IDL file. If there is a related client-side mapping file (Natural | COBOL), this is also used (internally).
Create a Visual Studio Solution. See Creating a Microsoft Visual Studio Solution.
Build a .NET assembly from the generated C# client interface object. See Writing a Client Application.
Create an application that uses the generated client interface object assembly and the .NET Wrapper runtime SoftwareAG.EntireX.NETWrapper.Runtime.dll. See Creating the .NET Wrapper Client Application.
The following description outlines as an example the steps required to build a .NET Wrapper client application (solution) with the Microsoft Visual Studio.
Start Microsoft Visual Studio.
From the
menu, choose .... and choose an appropriate name for the solution.Select the solution and choose
, choose .In the New Project dialog, choose
and . Choose an appropriate name for the class library, e.g. "exampleClientStub".Delete the default class file Class1.cs.
Select the new project and choose
and add the example.cs file generated previously.Select References, choose Add Reference and add the .NET Wrapper runtime SoftwareAG.EntireX.NETWrapper.Runtime.dll.
Build the class library.
Add a new project to the solution: Choose the solution,
, ..., , . Choose an appropriate name for the project, for example, "exampleClient".Rename the default class file Class1.cs as appropriate.
Choose
and add the .NET Wrapper runtime SoftwareAG.EntireX.NETWrapper.Runtime.dll.Choose
and add the .NET Wrapper client interface object exampleClientStub.Now implement your client application. Add the following lines to the top of the class file:
using SoftwareAG.EntireX.NETWrapper.Runtime; using SoftwareAG.EntireX.NETWrapper.Generated.example;
In a method of the application class implement the connection to an EntireX Broker, for example,
Broker broker = new Broker("localhost:1971", "ERX-USER"); broker.Logon("ERX-PASS");
and an EntireX RPC service, for example,
Service service = new Service(broker, "RPC/SRV1/CALLNAT", "EXAMPLE"); service.UserIDAndPassword("RPC-USER", "RPC-PASSWORD");
The example class can now be instantiated, for example,
Example e = new Example( service );
and the example methods called, for example,
int result = ex.Calculator( "+", 10, 15);
Writing a .NET server assembly with the EntireX .NET Wrapper typically requires the following steps:
Generate a C# file as described under Using the .NET Wrapper. From the context menu of the IDL file, choose > > . As an alternative, use the Microsoft Visual Studio Wizard for EntireX .NET Wrapper.
Insert your server-specific code at the required positions (C# methods).
Build a .NET Server assembly (DLL) from the generated C# file, following the rules for building a client stub library with the Microsoft Visual Studio.
Note:
The file name of the .NET Server assembly and the name of the library/class in the generated C# file must be identical.
Make the .NET Server assembly available to the .NET RPC Server, see Locating and Calling the Target Server in the .NET RPC Server documentation.
To start, stop and configure the .NET RPC Server to suit your needs, see Administering the .NET RPC Server in the .NET RPC Server documentation.
The generated C# client interface object can be used in an ASP.NET Web service to publish EntireX RPC services as Web services. With Visual Studio you can easily create an ASP.NET Web service that publishes methods of the EntireX RPC service (or your own methods that just use the EntireX RPC service).
Note:
The .NET Wrapper Runtime uses unmanaged DLLs. For this reason, ASP.NET applications have to run in full-trust mode.
You have built the .NET Wrapper example EntireX\examples\RPC\dotNetClient as described in the README file.
Then create a new "ASP.NET Web service" project with references to the generated client interface object and the .NET Wrapper runtime.
You can use the following example code (in the .asmx file) to implement
a Web method add
that exposes the calc
method of the
example.
using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Diagnostics; using System.Web; using System.Web.Services; using System.Text; using SoftwareAG.EntireX.NETWrapper.Runtime; using SoftwareAG.EntireX.NETWrapper.Generated.example; namespace WebService1 { /// <summary> /// Summary description for Service1. /// </summary> public class Service1 : System.Web.Services.WebService { public Service1() { //CODEGEN: This call is required by the ASP.NET Web Services Designer InitializeComponent(); } #region Component Designer generated code //Required by the Web Services Designer private IContainer components = null; /// <summary> /// Required method for Designer support - do not modify /// the contents of this method with the code editor. /// </summary> private void InitializeComponent() { } /// <summary> /// Clean up any resources being used. /// </summary> protected override void Dispose( bool disposing ) { if(disposing && components != null) { components.Dispose(); } base.Dispose(disposing); } #endregion // WEB SERVICE EXAMPLE [WebMethod] public int add(int sum1, int sum2) { Example e = new Example(); int result = e.calc("+", sum1,sum2); return result; } } }
It is assumed that you have read the document Internationalization with EntireX and are familiar with the various internationalization approaches described there.
The .NET Wrapper uses by default the "current locale" encoding set up on the Windows system for converting UNICODE (UTF-16) representations of strings to single-byte or multibyte representations that are sent to the Broker, and vice versa.
If you want to adapt the locale settings of your Windows system, use the Regional and Language Options in the Windows Control Panel.
The Broker class of the .NET Wrapper Runtime makes use of the .NET Framework class System.Text.Encoding for character conversion.
Refer also to the .NET Framework class library documentation for System.Text.Encoding.
The CharacterEncoding
property of the Broker class
that guides the character conversion is initialized with
System.Text.Encoding.GetEncoding(0)
(current locale). The codepage
that corresponds to this encoding is automatically transferred to the Broker as
part of the locale string, specifying the encoding of the data, when
communicating with a Broker version 7.2 and above.
The application programmer can also assign a custom encoding object to
the Broker class's CharacterEncoding
property for custom character conversions.
If an encoding object is provided, the corresponding codepage is transferred as
part of the locale string to the Broker for all Broker versions.
If communicating with a Broker version 7.1 and below and if no encoding
is provided by the .NET Wrapper programmer, an EntireX
administrator can force a codepage string to be sent to the Broker by setting
the environment variable ERX_CODEPAGE
to the name
of the respective codepage. See ERX_CODEPAGE
.
When setting the codepage with the environment variable
ERX_CODEPAGE
:
The ERX_CODEPAGE
environment variable is
ignored if the application programmer has already provided a codepage.
The value of the ERX_CODEPAGE
environment
variable must be the name of the system's default codepage. Under Windows,
simply apply the value "LOCAL"
to specify the default Windows ANSI codepage.
The codepage specified must be one that is supported by the Broker, depending on the Broker's internationalization approach. See Locale String Mapping for information on how the broker derives the codepage from the locale string.
Before starting the application, set the locale string with the
environment variable ERX_CODEPAGE
.
Example:
ERX_CODEPAGE=LOCAL