smtp4dev - the fake SMTP email server for development and testing.
A dummy SMTP server for Windows, Linux, Mac OS-X (and maybe elsewhere where .NET Core is available). Lets you test your application without spamming your real customers and without needing to set up a complicated real email server with a special configuration. Messages received in smtp4dev can be viewed and inspected.
This repository hosts the development of v3 which has a web UI so that it can be shared amongst members of a team, and be available cross platform. This version is in development, but now approaching a stable state.
If you're looking for the older v2 Windows GUI version. Grab it here.
If you find smtp4dev useful, please consider supporting further development by making a donation:
(+270k when prev hosted on Codeplex)
The MacOS release is totally untested. Please contribute instructions on how to use and feedback on any issues
-
Download a release and unzip.
-
On Linux
chmod +x
theRnwood.Smtp4dev
file to make it executable -
Edit
appsettings.json
and set the port number you want the SMTP server to listen on. -
Run
Rnwood.Smtp4dev
(.exe
on Windows). (If you downloaded thenoruntime
version, you need the .NET Core 3.1 runtime on your machine and you should executedotnet Rnwood.Smtpdev.dll
to run it.) -
Open your browser at
http://localhost:5000
(to run the web server on a different port or make it listen on interfaces other than loopback, add the command line arg--server.urls "http://0.0.0.0:5001/"
when starting the executable. -
Now configure your apps which send mail, to use the SMTP server on the machine where SMTP4dev is running (
localhost
if they are on the same machine), and using the port you selected (25
by default).
If you're using the .NET Core SDK 3.1 or greater, you can install smtp4dev as a global tool using the following command:
dotnet tool install -g Rnwood.Smtp4dev --version "3.1.0-*"
Then you can start smtp4dev by running
smtp4dev
Docker images for both Windows and Linux are available. To run with the web interface on port 3000 and SMTP on port 2525:
docker run -p 3000:80 -p 2525:25 rnwood/smtp4dev:v3
This is a cross platform tag which will work on either Windows or Linux. To see the full list of available tags see the Docker hub page for smtp4dev.
The folder /smtp4dev
will be used for the database and auto-generated TLS certificate. You can mount a directory outside of the container here for peristent storage.
A service in Windows can be installed using New-Service in PowerShell, or sc in both command line or PowerShell. If you use sc in PowerShell, it must be run as sc.exe. sc is an alias for Set-Content.
New-Service -Name Smtp4dev -BinaryPathName "{PathToExe} --service"
sc.exe create Smtp4dev binPath= "{PathToExe} --service"
smtp4dev keeps the latest 100 messages and 100 sessions by default.
The --messagestokeep X
and --sessionstokeep X
command line options can override this.
By default smtp4dev will create a Sqlite DB named database.db
in <APPDATA>\smtp4dev
directory when it runs (<APPDATA>
is environment variable APPDATA
on Windows and XDG_CONFIG_HOME
on most other platforms).
For Docker images, the default path is /smtp4dev
- see above.
To change the path of this file use the --db "/path/to/file.db"
command line option or edit ServerOptions\Database
in appsettings.json
To use an in memory DB use an empty string (e.g. --db=""
)). All session and messages will be lost when the process exits. (Docker: The =
in the example is important as Docker will eat the empty quotes if ommitted.)
smtp4dev listens on 0.0.0.0 (all interfaces) port 25 by default. To change this either edit ServerOptions\Port
in the appsettings.json
before startup or add the --smtpport
command line options (e.g. --smtpport 2525
).