top | item 38705747

How to run a DOS-based web server

48 points| BryanLunduke | 2 years ago |lunduke.locals.com

30 comments

order

rollcat|2 years ago

I thought at first it's gonna be redbean (https://redbean.dev), but turns out Cosmo/APE (despite the .com file extension) "only" supports x86-64/Windows.

I like the idea of using the attached screen to scroll logs / show stats. My next server build has a 9" touchscreen on the front panel, and I'm looking for ideas on what (&how) to show there.

sebazzz|2 years ago

That's nice but you can't run the Web server in the background can you? So you need to terminate it to edit index.htm?

shrubble|2 years ago

Could you use DesQView or similar to multi-task it?

bluedino|2 years ago

Microsoft Windows will let you multitask DOS applications

enormousness|2 years ago

They use a VM so I assume you'd simply edit offline then redeploy the machine.

slim|2 years ago

you would need to make it a TSR

KRAKRISMOTT|2 years ago

Better sandbox the webserver in WebAssembly

nirui|2 years ago

It's cool and all, but does FreeDOS support something similar to Data Execution Prevention? I know MS-DOS probably don't have it, and searching "'FreeDOS' 'Data Execution Prevention'" on DuckDuckGo yielded no result.

rep_lodsb|2 years ago

Serious answer to silly question: DOS applications have full control over the hardware, so it's entirely up to them. In real / V86 mode, there is no distinction between code and data pages, however you can have separate segments for code, data and stack.

There are separate CPU instructions for "near" and "far" jump/call/return, and if all code fits into a single 64K segment ("small model"), there would be no need to ever have the "far" version of these instructions in your code. So if for example a return address or function pointer were overwritten, there would still be no way for an attacker to execute data, since it is in a different segment and all control transfer would be limited to the current code segment.

A lot of the more modern software included in FreeDOS is compiled with GCC and uses a flat 32-bit address space, so it doesn't have that protection. Most of it is command line utilities ported from UNIX-like systems, with even the most trivial of them being more than 100K in file size - IMO this goes very much against the "spirit" of DOS!

It should be possible to modify the compiler and runtime library to use separate segments for code and data. Since there is no size limit in 32-bit mode, there would be no need for far pointers, just two separate address spaces. Of course the UNIX and RISC zealots don't like this because it isn't portable to every other CPU, as if that matters somehow.

Enabling page-based DEP would also be theoretically possible, but require even more effort, I think. And for what purpose?

hulitu|2 years ago

Maybe not. COM files were, more or less, data.

chungy|2 years ago

You're not going to do this for security. It's purely for fun :)

mbbrutman|2 years ago

Cute article, but I'm not quite sure how you missed the mTCP HTTPServ program ...

tetrisgm|2 years ago

What happens if you DOS a DOS server?

ithkuil|2 years ago

Cuatro

redder23|2 years ago

I fail to see the point.

m00x|2 years ago

Fun experimentation