2024-01-25 15:05:48 -03:00

48 lines
1.9 KiB
Markdown

# 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:
```sh
curl -su user:pass http://localhost:8090/upload/foo.txt --data-binary @Makefile
```
- Follow the [Build Tools](../tools/) tutorial to setup your development environment.
- Start a terminal in this project directory; and build the example:
```sh
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
```sh
./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
```sh
./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/