Solved

Inter Delphi communication ways

Posted on 2013-05-15
14
313 Views
Last Modified: 2013-09-05
Hi delphi devs,

I'm looking for a way to let delphi programs communicate across the globe without the use of database.
I'm writing the programs in D2010 at the moment.

Basically i need to send a piece of text (integers, strings, etc) and the remote side has to send a similar response.

What resembles this idea most would be a user requesting a report by a certain time.
>> The app sends the name of the report, the destination folder of the report and the time it has to be delivered.
>> The backend app receives this info, prepares the report and places the report on that specifc folder

I'm looking for ideas, and some code of how the communication would work.
> I'm not looking for a full back-end communication framework ...

Something like this:
procedure Message(ReportName, DestFolder: string; DeliveryTime: TDateTime;
  var ReturnMessage: string);
begin
  ... your code ideas ...
end;

this requires 2 sides: the sending app code and the remote app code.

ideas with existing components (like Indy) are also welcome

I'll probably find a way myself, but asking a question here, may give more perspective and ideas.
0
Comment
Question by:Geert Gruwez
14 Comments
 
LVL 45

Expert Comment

by:aikimark
ID: 39170184
Even though it is a bit bloated, XML is a fairly standard data exchange format.

You might also consider JSON or some other mark-up standard, such as YAML.  Most of these formats have less overhead.
0
 
LVL 8

Assisted Solution

by:lomo74
lomo74 earned 250 total points
ID: 39170655
I'd go with SOAP. It has a quite heavy overhead, but it allows function calls to run across the internet easily. Delphi also eases the process of creating client and server code through its wizard.
You can also develop client and server using different languages (I personally developed many applications mixing Delphi, C#, Java and PHP).
If bandwidth is an issue, JSON is a good lightweight alternative. More info here, along with links to Delphi JSON implementations.
0
 
LVL 27

Expert Comment

by:Sinisa Vuk
ID: 39171478
I see here multiple data to transfer. Main is report definition (description,title,column titles, some other info) and real data (two xml nodes). So I would go with custom xml (maybe with use of Indy or ICS) where part of it is allocated for report (first node) and other one for data. Data node will introduce as normal data XML with a fields description.
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 37

Author Comment

by:Geert Gruwez
ID: 39174014
i'm looking for the actual mechanism used for sending/receving the data between the apps
what the data format is and the interpretation of it is irrelevant at this point

i have used soap too.
It's probably my code, but this soap gets stuck every so often ...
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39175345
If you want some assurances that the message will get through, use a mail protocol.  However, you should be able to do this with simple TCP.  Do not use UDP.

In order to make TCP work, you will need to get past firewalls.
0
 
LVL 15

Expert Comment

by:mikelittlewood
ID: 39189990
Hi Geert, Am i right in assuming you don't want a "middle man" in this, i.e. web services?
0
 
LVL 37

Author Comment

by:Geert Gruwez
ID: 39190691
no middle man, you'r right, just direct delphi to delphi communication

i know not to use UDP > delivery is not guaranteed
0
 
LVL 45

Accepted Solution

by:
aikimark earned 250 total points
ID: 39190714
In one system I designed, machines established TCP connections when they needed to talk to the server.  Indy components were used.  We used the machine name and a port number when specifying the TCP address.  We encrypted our data stream, since we couldn't be sure if someone was sniffing packets somewhere in the network.  We also included other message validation methods and a hash of the data to help ensure the integrity of communication.

Even though that was in a network, I don't see any reason you can't do something similar with TCP/IP.
0
 
LVL 37

Author Comment

by:Geert Gruwez
ID: 39190828
i don't need encryption
this is strictly a system internal to the company

security is taken care of by our network team
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39190845
If you are communicating out on the Internet and not behind a company's firewall, all your data can be seen.
0
 
LVL 37

Author Comment

by:Geert Gruwez
ID: 39207302
i'm always going to be behind a company firewall with this
and i'm not going to repeat it a third time !

so stop giving those remarks about security
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39207469
@Geert

When you stated "communicate across the globe", that does not imply that you are behind a firewall.

"i'm not going to repeat it a third time"
This is the first time you've stated your run-time configuration in this thread.  I won't mention security again.
0
 
LVL 37

Author Comment

by:Geert Gruwez
ID: 39215804
0
 
LVL 37

Author Closing Comment

by:Geert Gruwez
ID: 39466967
closing ... again
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Delphi XE10 Round Image 2 183
Unique identifier on a terminal server (rdp) 4 71
RESTRequest Parameter 4 51
TlistView is Really heavy on Android 3 11
A lot of questions regard threads in Delphi.   One of the more specific questions is how to show progress of the thread.   Updating a progressbar from inside a thread is a mistake. A solution to this would be to send a synchronized message to the…
Hello everybody This Article will show you how to validate number with TEdit control, What's the TEdit control? TEdit is a standard Windows edit control on a form, it allows to user to write, read and copy/paste single line of text. Usua…
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

679 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question