XML-RPC vs. RTC Format

2018-06-17 18:57:05来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

 Author XML-RPC vs. RTC Format
Danijel Tkalcec [RTC]

25.10.2006 11:49:37
Registered user
There are two major differences between the XML-RPC format and the RTC format.

One difference is that XML-RPC doesn't support all types supported by RTC, so multiple RTC types need to be mapped to a single XML-RPC type. Because of this, some type information will be "lost" when sending the data over XML-RPC. Here is a list showing how your RTC types will be mapped to XML-RPC when sending the data out ...

1) rtc_Float, rtc_Currency -> <double>

2) rtc_Integer, rtc_LargeInt -> <int>

3) rtc_Text, rtc_String, rtc_WideString, rtc_Variable -> <value>

4) rtc_DateTime -> <datetime.iso8601> (no miliseconds)

5) rtc_Boolean -> <boolean>

6) rtc_DataSet -> <struct> with "Fields" and "Rows" as <array>s

7) rtc_Exception -> <fault><struct>

8) rtc_Record -> <struct>

9) rtc_Array -> <array>

10) rtc_ByteStream -> <base64>

11) rtc_Null -> <nil/>

When RTC Clients need to talk to a RTC Server (and vice-versa), you can send all RTC types like DataSets and Exceptions as parameters and all other XML-RPC apps will be able to decipher the data, but other XML-RPC apps will most likely see the data "differently".

For example, a rtc_DataSet will be seen as a <struct> with two <array>s and not as a single DataSet object (like in RTC SDK), while Exceptions included in other data will be seen as a <struct> with 2 <member>s (unless it's a single Exception sent from the Server to the Client, for which the standard <fault> structure will be used).

You can also activate both data formats on the ServerModule (fmt_RTC and fmt_XMLRPC), so your RTC clients can use the compact RTC format while other apps use XML-RPC.

Another difference is that XML-RPC function call parameters are sent in a list, where order is important, but no names are assigned, while RTC uses names for all parameters. To make the communication between RTC Clients and Servers compatible even when using XML-RPC, all parameters will be packed into a <struct>, unless you pack them in an array called "params". That way, name information will be preserved if you use the "standard RTC way", and ... if you need to talk to a server/client which wants the parameters in a list, you will pack them into an array named "params", with the first parameter at index 0.

So, if a non-RTC app will want to call a remote function written with RTC by using names, it will have to send all parameters as a single <struct> param. On the other hand, when you want to call remote functions written by other servers, unless they use the same <struct> method, you will need to pack the data in an array called "params" (elements start from index 0).

That way we are keeping 100% compatibility between RTC clients and servers, while still making communication with other XML-RPC apps possible, regardless of their format.

Best Regards,
Danijel Tkalcec
Danijel Tkalcec [RTC]

25.10.2006 12:33:46
Registered user
Here is how XML-RPC types will be mappet to RTC types when you receive a request or a response over XML-RPC ...

1) <FAULT> -> rtc_Exception

2) <METHODCALL>, <CALL> -> rtc_Function

3) <I4>, <INT> -> rtc_LargeInt

4) <BOOLEAN> -> rtc_Boolean

5) <VALUE>, <STRING> -> rtc_String

6) <DOUBLE> -> rtc_Float

7) <DATETIME.ISO8601>, <DATETIME>, <TIMESTAMP> -> rtc_DateTime

8) <BASE64>, <BASE64BINARY>, <BINARY> -> rtc_ByteStream

9) <STRUCT> -> rtc_Record; Except if it is the first and the only parameter in a function call list, in which case all values will be prepared as named parameters, "the standard RTC way".

10) <ARRAY> -> rtc_Array

11) </NIL> -> rtc_Null

Best Regards,
Danijel Tkalcec

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:[试玩] FMXLinux (Firemonkey for Linux) Linux 桌面开发(第三

下一篇:[修正] Firemonkey SpeedButton 鼠标移开按钮后 IsPressed 为 Fa