You’re hacking around with a friend, and you need to send him a file. How would you do that?
Just use a USB stick (do people still carry those things around?).
With the “power of the Internet” you have a bunch of possible ways to do it with a simple journey around the planet:
- send an email
- put it on dropbox/gdrive/box/etc
After all, who doesn’t have an internet connection these days?
I’m an old guy and back when I was in college, having an internet connection wasn’t that obvious, but you could almost always count on a cat 5 twisted pair with an rj45 plug. Why? Simple – stumbling on a sudden LAN party, or just craving a quick frag with a pal in your fav map on Quake3 or Unreal was way more common than finding a USB stick or a wifi connection in an age they didn’t yet exist.
So now you have a nice TPC/IP connection you can leverage on (but no internet). Great, what to do?
NFS/SMB share? Perhaps not: there were always concerns about security. Iptables were tighter than my belt, after living almost an year in Dubai and gaining 10KGs; plus configuring one of those shares from scratch used to take more time than just spelling out the file bit by bit and have your friend manually type it.
FTP, WEBDAV, and a plethora of other options could have probably done it, sure. With configuration or giving account on your machine… See what I mean?
Today probably some young entrepreneur would come up with a whole startup to solve this problem, however, our simple solution used to be: netcat, the TCP/IP swiss army knife.
NC (short for netcat) can open tcp sockets for both reading (listen) and writing:
So, how do you do it? Simple:
Just set up a listener on the destination machine and divert it’s output into a file:
and simply cat it to netcat on your sending machine:
Add sugar and gpg for any extra privacy, because if you do it on you campus’ internal network, you don’t want sniffers to grab your stuff ;)
The same trick works with a directory. It’s unix, just add pipes and some other commands:
And that’s all :)