File Transfer
This example contains minimal HTTP client and server.
The client uploads a file to the server in a single POST, shaping traffic to send small data chunks.
The server manually processes requests in order to be able to write as soon as data arrives, to avoid buffering a whole (possibly huge) file not fitting in RAM.
Uploads are authenticated using Basic Auth. Both client and server have a default user/pass and can be configured using the command line. Only authenticated users can upload a file.
The server can also accept regular uploads from any HTTP client, for example curl:
curl -su user:pass http://localhost:8090/upload/foo.txt --data-binary @Makefile
-
Follow the Build Tools tutorial to setup your development environment.
-
Start a terminal in this project directory; and build the example:
cd mongoose/examples/file-transfer make clean all
-
Manually start the server, either in background (to reuse the same terminal window) or in foreground; in which case you'll need another terminal to run the client. The server will listen at all interfaces in port 8090
./server 6332b7 2 server.c:157:main Mongoose version : v7.12 6332b7 2 server.c:158:main Listening on : http://0.0.0.0:8090 6332b7 2 server.c:159:main Web root : [/home/mongoose/examples/file-transfer/web_root] 6332b7 2 server.c:160:main Uploading to : [/home/mongoose/examples/file-transfer/upload]
-
Manually run the client to send a file, default is to send it as "foo.txt" to the server in localhost at port 8090
./client -f Makefile ok
Default operation is to assume hardcoded username and password. Call both server and client with no arguments to see usage instructions
See detailed tutorials at https://mongoose.ws/tutorials/file-uploads/ https://mongoose.ws/tutorials/http-server/ https://mongoose.ws/tutorials/http-client/