How to Use CheckTLS.com

The steps below walk you through what you can do on this site, in order of increasing difficulty:

Follow the first few steps to get an idea of what we do and how we do it. Peruse the first paragraph of the sections below to get an idea of what else we can do and why. Bookmark this page and come back to it as you think of other questions about your email. The more you know about CheckTLS.com, the more valuable it becomes!

Quick Look Into Your Email

Quick Look: Getting Email

Do a quick check of your own email address. Will it accept TLS encrypted message from the Internet? Google says 90% of email systems do.

Confidence Factor: (displays here)

we do not keep or use your address, see our privacy policy

See TestReceiver for more about this test.

Quick Look: Sending Email

It is more important to protect email you send because you are responsible for protecting email until it is accepted by the receiver.

Click to send us a message to test. We will email you back the test results.

We will email you back the test results, which will look something like this:

    From: CheckTLS Test Sender TLS <testsender@CheckTLS.com>
 Subject: SUCCESSFUL

SUCCESSFUL //email/test From:

Your email was sent securely using TLS.

See TestSender for more about this test.

Why How You Send Is More Important

Because you are responsible for protecting emails you send, you need to know if your recipients will let you use encryption. By default almost every email system will fall back to plain text if the recipient won't encrypt. See Mandatory TLS below for why yours will too.

Run the same test as above on addresses you send to. Will they accept TLS encrypted message from the Internet? Most will, but you will find a few that do not.

Confidence Factor: (displays here)

we do not keep or use any addresses, see our privacy policy

If you email someone that does not pass this test, you are sending to them in plain text. That is probably illegal and certainly violates common sense.

See TestReceiver for more about this test.

Deeper Look At Your Email

A basic email server has two pieces that must work together: the email server and the MX DNS entry that points to it. The simple test above checks the email server(s), the DNS MX record(s), and that the two are working together.

The safety measures the Internet has invented to protect wanted email and reduce unwanted email add more pieces. Each new piece has to fit correctly into the whole. CheckTLS can help you configure these measures and fit them properly into your whole.

CheckTLS does two things: test individual pieces of an email system, and test all the pieces working together. This combination of isolated feature testing and total systemic testing, in real-time on real-live systems, is unique to CheckTLS.

Once installed, it is just as important to keep your email system working correctly, efficiently, and safely. We allow subscribers to save the tests they use in installing and configuring their email systems and run them repeatedly on demand or on a schedule. CheckTLS lets you monitor not just that some email is getting through, but that all mail is getting through and that all your security measures are working properly.

Deeper Look: Receiving Email

Find out more about what goes into the "score" (Confidence Factor) that we compute for your email address and the addresses of people you email with.

Deeper Look Receiving: Show More Detail

The //email/testTo: above that reported on whether or not your or someone else's emailbox can receive email with TLS encryption can show many details about an email system. The Show Detail button above or here shows these details.

(opens a new window)

This new window shows our server testing your email system in real time. It shows the details of what went into your Confidence Factor.

It shows a matrix of each SMTP step for each of your MX hosts. The squares in the matrix indicate the success or failure of the step, and how long that step took.

Beneath that are the complete transcripts of the SMTP "conversations" our servers had with your servers. Included in each transcript are annotations that describe what happened at certain steps and/or that show more information about what was going on in that step, such as the contents of the SSL Certificate used.

We encourage you to run this test on different email systems to get a better understanding of what the details show and how well-tuned email systems look.

Bookmark //email/testTo: and come back to it as you find other addresses or think of other things you want to know about an email system. This test is very powerful and can uncover lots of things about an email system.

Deeper Look Receiving Detail: What To Look For
Receiving Detail Look For: MX DNS Entries

Make sure that the MX hosts listed are what you expect. We see "forgotten" MX hosts, left over from upgrades where people forget to remove the old ones when they finish testing the new ones. Those old MX host can have old certificates, insecure SSL Versions, and incorrect end-user delivery options, resulting in insecure or completely lost emails.

Receiving Detail Look For: MX Hosts

Be sure each MX host is properly configured. We see mis-matched certificates and other settings, which cause inconsistent email results, and inconsistent results are the hardest to diagnose.

Receiving Detail Look For: TLS Version

Obviously check that each MX host can "starttls". Check that each one offers the version(s) of TLS (SSL) that you want, and only those versions. Use the SSL Version option in //email/testTo: to test both that the versions you want do work, and that the versions you do not want are refused.

Receiving Detail Look For: Certificates

While certificate verification does not typically cause email to revert to plain text, an expired or improperly signed certificate will prevent some senders from being able to send to you. The more security conscious a trading partner is, the more likely they are to refuse to send email to a site with a certificate weakness. These security conscious trading partners are likely to be your most important trading partners.

Deeper Look Receiving: Email Protection (MTA-STS, SMTP TLS Reporting)

SMTP MTA Strict Transport Security (MTA-STS) tells the Internet that your email can receive email using TLS, and whether or not you require it. MTA-STS has several "moving parts" that have to be in sync: a DNS record, a policy file, and policy settings that match other DNS records. Any errors may mean your email is less secure than you expect and can even result in email loss.

Adding a SMTP TLS Reporting DNS record tells the Internet how to inform you if there are any errors with your TLS.

Google has added MTA-STS and SMTP TLS Reporting to gmail: gmail supports MTA-STS and TLS Reporting

The tests above test your MTA-STS and TLSRPT by default.

Deeper Look Receiving: Email Protection (DANE)

Domain-based Authentication of Named Entities (DANE) is an arguably even more secure way to ensure TLS security, however it is more difficult to set up and administer, and it requires special DNS servers (DNSSEC) at your domains' SOA.

DANE has many parts that all need to work together. Some of these parts must be renewed every year, and the remaining parts updated to match the newly renewed parts. Many parts and constant updates means DANE requires ongoing maintenance and testing.

CheckTLS not only verifies that a DANE implementation is correct, it exposes all the parts to help you find and fix problems. If you use or are considering DANE, you need CheckTLS.

The tests above test your DANE implementation by default.

Deeper Look Receiving: Test Specific Items

The //email/testTo: allows you to tune the test to target specific features of your email system.

The test parameters you can tune are documented in the More Options instructions and in the Test Documentation, and includes items like:

Output Format
show more or less information about each server
Show Test Progress
show test results one at a time in real time
MX Host/Port
test a specific single host, possibly at a non-standard port
useful when debugging one particular server
IPv4/IPv6
test via IPv4 and/or IPv6
MX Count
only test a subset of all MX hosts
Ignore No Connects
Check CRL/OCSP
see if a security certificate has been revoked (maybe compromised or stolen)
SSL Version
check what SSL/TLS version(s) work
SSL Cipher List
check what SSL Cipher(s) work
CA Certs
verify using your own Certificate Authority
Auth User/Pass
test private email systems that authenticate with UserID/Password
Client Cert/Key
test private email systems that authenticate with a client certificate

Open the More Options section here:

(opens a new window, scroll down through More Options)

Deeper Look: Sending Email

The //email/testFrom: above that reported on whether or not you can send email with TLS encryption can also tell you the details of the encryption your emailer can do, and it can report on other protections that the Internet has developed to improve your email reliability, deliver-ability, and security.

Deeper Look Sending: SSL Version and Cipher List

If you include the strings "SSL Version Used" and "SSL Cipher Used" in the body of the email you send us, CheckTLS will include that information in the results email we send back.
The return email will have additional information about your implementation of SSL:

    From: CheckTLS Test Sender TLS <testsender@CheckTLS.com>
 Subject: SUCCESSFUL

SUCCESSFUL //email/test From:

Your email was sent securely using TLS.

SSLVersion:TLSv1_3
SSLCipher:TLS_AES_256_GCM_SHA384

(this email intentionally has limited formatting)

See TestSender for more about this test.

Deeper Look Sending: Email Protection (SPF, DKIM, DMARC)

Sender Policy Framework (SPF) DNS records list what IP addresses are allowed to send your email. When email gets delivered, the receiver checks that it came from one of your published IP addresses. SPF prevents someone else from sending an email that pretends to be from you.

Domain Keys Identified Mail (DKIM) protects the email from modification. It adds a private-key encrypted checksum of various parts of an email to the email header. The receiver uses a DKIM DNS record public-key to decrypt the checksums and thereby verify each part. Protecting the email headers assures the email really came from you. Protecting the email content assures no one changed the message.

Domain-based Message Authentication, Reporting, and Conformance (DMARC) works with SPF and DKIM to further protect email. It adds instructions for working with SPF and DKIM and what to do if one fails.

If you include the strings "SPF", "DKIM", and/or "DMARC" in the body of the email you send us, CheckTLS will check your implementation of those security features.

Unlike other on-line tests that test your SPF, DKIM, and DMARC settings, we test SPF, DKIM, and DMARC on a real email from your live email system.

See TestSender for more about this test.

More Than Just Email

CheckTLS.com testing is comprehensive. Our tests look for everything we can find out about every server we can find. By looking at everything, we can find weaknesses or vulnerabilities that do not show during normal operations. Exploits and data loss are usually the result of a bad actor exploiting a weakness that no one knew about.

For example, many sites on the Internet will check your webserver by fetching a webpage and seeing if it was secure. By changing the Port from 25 to 443, the same //email/testTo: that reports on email servers can do a comprehensive test of your https web infrastructure:

(opens a new window)

Use CheckTLS.com whenever you want to look at your SSL infrastructure in real time!

Our site is designed like a computer directory. The root is the home page, which we refer to as // or //home. The major branches are the top-level menu choices on the horizontal bar on the top of every page:
| email | cloud | help | subscription | faq | | |
which are referred to as
//email
//cloud
//help
//subscription
//faq
The remaining menu items are Contact Us (), Search (), and Translate ().

The major branches have sub-branches, for example:

//email/testTo:
TestReceiver
//email/testFrom:
TestSender
//subscription/signup
New Subscription Sign-Up

Work Efficiently

Our design lets you start small but then slowly dig deeper one step at a time. Move easily from a systemic view to very specific feature testing. Parameters are saved from one test run to the next, so you only change what you need.

DNS is a big piece of complex email systems, and working with DNS is hard because caching and TTL mean you have to wait for changes to take effect. Our tests have options to bypass caching and TTL, so you can make changes and see their effects immediately.

Simple versions of CheckTLS tests are available other places on the Internet. Much of the deep testing we do is available from command line or installable tools. CheckTLS puts lots of email tools together in one place with all the power of command line and installed utilities.

By making incremental testing easy and by using fresh data, we can do hours of testing in a few minutes. By putting lots of email tools together in one place with all the power of command line and installed utilities, we can do all your testing in one place. We think you'll find that CheckTLS.com is indispensable for working on email systems.

Require Email Encryption ("Mandatory TLS")

Most modern email systems can do strong email encryption using TLS, and they can be told to require it. So why not turn on this so called "Mandatory TLS" and guarantee that all Internet email is protected?

Because 10% of email systems are not capable of TLS, and no one is willing to forego 10% of their email. Especially since email bounces are inconsistent: they can take minutes, hours, days, or sometimes the sender is never informed that their email was not delivered.

Some companies do use Mandatory TLS with selective trading partners. Two companies with solid TLS support can turn on Mandatory TLS between themselves and protect their email that way.

Of course, if both sides have working TLS, then how do you know that your email won't fall back to plain text if the other side stops doing TLS? CheckTLS designed tests that can verify that your Mandatory TLS will not fall back to plain text. And like many tests, it can then monitor your Mandatory TLS to be sure it doesn't fall back in the future as things change.

Mandatory TLS: Email You Receive

Assuredness Factor: (displays here)

Mandatory TLS: Email You Send

a message for us to test, and just like the above test we will email you back the test results. Mandatory TLS testing takes a little longer since we have to try to send insecurely first.

Run Our Tests On Your Computers Or Website (WebServices)

Most CheckTLS tests are available as webservices. You can embed them into web pages on your site, or call them from your production systems.

WebServices: Put CheckTLS Tests On Your Website

You can embed our tests onto your website and make them look like your own tests. For example, the page you are reading has many of our tests embedded in it the same way as our customers embed these tests on their own sites. View the HTML and JavaScript source to this page for examples, and see our embed page for more information.

WebServices: Machine Readable Results (XML)

Healthcare companies that deliver results via email directly from their patient care systems can use our //email/testTo: ("TestReceiver") test stay HIPAA compliant. They program their RIS to call our webservice before emailing the result.

Verify Your Email End-To-End

CheckTLS can test your email system end-to-end, watching it receive a message and then turn around and send it back to us. We call this a "Batch Thru" test, and you can format the results many ways, but a typical result looks like:

<CheckTLS test="G_2_29_20180811105434" version="V03.02.01"> <Results> <Result> <Score>100</Score> <Target>CheckTLS-Reply@CheckTLS.com</Target> <SendToSeconds>2</SendToSeconds> <TurnAroundSeconds>60</TurnAroundSeconds> <ReceiptFromSeconds>0</ReceiptFromSeconds> <SentToTarget><![CDATA[ === Trying mail6.CheckTLS.com:25... === Connected to mail6.CheckTLS.com. <- 220 www6.CheckTLS.com ESMTP Sendmail 8.14.7/8.14.7; Sat, 11 Aug 2018 10:54:35 -0400 -> EHLO www6.CheckTLS.com ...[lines deleted] === Connection closed with remote host. ]]></SentToTarget> <ReceiptFromTarget><![CDATA[ <-- 220 ts6.checktls.com ESMTP TestSender Sat, 11 Aug 2018 10:55:36 -0400 --> EHLO www6.CheckTLS.com ...[lines deleted] ]]></ReceiptFromTarget> </Result> <Totals> <Average>100.000</Average> </Totals> </Results> </CheckTLS>

You can get information about how your email system received the email, forwarded it, and sent it back, and how long each step took. The timing numbers are useful for monitoring the overall health of your email system.

See the next section below for more information about Batch testing, and the Thru section of the Batch Test documentation for specifics of the Thru test.

Check Lots Of Addresses At Once

You can send a "Batch" of addresses to CheckTLS and have them all tested. Batches have many uses: all your different email addresses, a group of important addresses you send to, the new vendors in your purchasing system, etc.

A Batch typically runs our //email/testTo: ("TestReceiver") on the list of addresses. All of the options available in //email/testTo: ("TestReceiver") can be tested in the Batch.

BatchTest results can be just a score:

100 Dwalin.com 87 Balin.com 50 Kili.com 92 Fili.com 100 Dori.com 100 Nori.com 100 Ori.com 75 Gloin.com 67 Bifur.com 100 Bofur.com 57 Bombur.com 110 Thorin.com

or a pass/fail:

Dwalin.com PASS (100>=75) Balin.com PASS (87>=75) Kili.com FAIL (50>=75) Fili.com PASS (92>=75) Dori.com PASS (100>=75) Nori.com PASS (100>=75) Ori.com PASS (100>=75) Gloin.com PASS (75>=75) Bifur.com FAIL (67>=75) Bofur.com PASS (100>=75) Bombur.com FAIL (57>=75) Thorin.com PASS (110>=75)

or show details:

<CheckTLS test="BatchTestreceiver" version="V03.02.04"> <Results format="xml-matrix"> <Result> <eMailAddress>gmail.com</eMailAddress> <ConfidenceFactor>100</ConfidenceFactor> <MXConfidenceFactor>100</MXConfidenceFactor> <MXCount>5</MXCount> <Answer>100</Answer> <Connect>100</Connect> <HELO>100</HELO> <TLS>100</TLS> <Cert>100</Cert> <Secure>100</Secure> <From>100</From> <To>100</To> <MX exchange="gmail-smtp-in.l.google.com[74.125.70.27]" preference="5"> <Answer>0.045804</Answer> <Connect>0.12831</Connect> <HELO>0.165975</HELO> <TLS>0.200658</TLS> <Cert>0.287659</Cert> <Secure>0.322298</Secure> <From>0.356059</From> <To>0.507987</To> <MXStep name="To">7</MXStep> </MX> <MX exchange="alt1.gmail-smtp-in.l.google.com[173.194.68.27]" preference="10"> [lines deleted] </MX> <MX exchange="alt2.gmail-smtp-in.l.google.com[74.125.141.27]" preference="20"> [lines deleted] </MX> <MX exchange="alt3.gmail-smtp-in.l.google.com[64.233.190.26]" preference="30"> [lines deleted] </MX> <MX exchange="alt4.gmail-smtp-in.l.google.com[209.85.203.27]" preference="40"> [lines deleted] </MX> </Result> <Result> [lines deleted] </Result> <Result> [lines deleted] </Result> <Result> [lines deleted] </Result> <Totals> <Average>100.000</Average> </Totals> </Results> </CheckTLS>

See BatchTest Output for more results formats.

Schedule Repeated Testing

Batches can be stored on CheckTLS and scheduled to run regularly: monthly, weekly, daily, hourly, or any combination. The Batch can be programmed to only alert you if something changes. Protect yourself without signing up for a lot of useless noise.

Continuously Monitor Your Email

You can monitor scheduled batches so you know that silence is golden. When you set a Batch to only alert you if something changes, you need to protect against the Batch itself failing, not the thing(s) it was testing. Our Monitor webservice tells you when a Batch last ran and what it's result was. Hook this to Nagios, OpenView, Tivoli, etc. and know you tested your systems and they passed.

For example, we monitor our own email end-to-end every ten minutes checking this result:

<CheckTLS test="thru"> <Description>Monitor CheckTLS</Description> <LastRun>2020-12-25T14:54:12-0500</LastRun> <LastTotal>110.000000</LastTotal> </CheckTLS>

Test Other TLS Services (Web, POP, IMAP, etc)

CheckTLS tests are focused on Internet servers and SMTP, but by tuning test options, tests can be used to examine other services.

Check for TLS on a POP or IMAP Server

The //email/testTo: ("TestReceiver") test can check that an email provider's POP or IMAP service can do encrypted (POPS, IMAPS) communications using these settings under More Options:

eMail Target: yourdomain.com Output Format: Score Show Test Progress: CHECKED MX Host: pop.yourdomain.com MX Port: 995 Stop After: CONNECT Direct TLS: CHECKED

MX Host should be the POP or IMAP server that your email client uses to connect to your email provider. MX Port is 995 for secure POP and 993 for secure IMAP.

With Output Format set to Score, a successful result looks like:

CheckTLS ConfidenceFactor for "checktls.com at [mail.checktls.com:995]": 100 of 100 (100%, 121 max)

Setting Output Format set to Matrix adds this:

MX Server Pref Answer Cert Secure MTASTS DANE Score
mail.checktls.com
[104.131.168.30:995]
0 OK
(5ms)
OK
(-3ms)
OK
(4ms)
not tested not tested 100
Average 100% 100% 100% 100

Setting Output Format set to Detail adds this:

Checking checktls.com at [mail.checktls.com:995] from www2-do.checktls.com(V03.79.06) at 2025-01-06T18:44:53Z:

seconds lookup result
[000.001]      DNS LOOKUPS
[000.019]      SEARCHLIST104.131.108.216,134.209.169.224,1.1.1.1,8.8.8.8,67.207.67.3
[000.019]      using supplied MX(s)mail.checktls.com
[000.040]      MX:CNAME-->mail.checktls.commailbox1-do.checktls.com
[000.042]      MX:A-->mailbox1-do.checktls.com104.131.168.30
seconds test stage and result
[000.001] Trying TLS on mail.checktls.com[104.131.168.30:995] (0) @2025-01-06T18:44:53.418504Z
[000.005] Server answered
[000.007] SSL_ocsp_mode = SSL_OCSP_FULL_CHAIN
[000.027] Connection converted to SSL
SSLVersion in use: TLSv1_3
Cipher in use: TLS_AES_256_GCM_SHA384
Perfect Forward Secrecy: yes
Session Algorithm in use: Curve X25519 DHE(253 bits)
Certificate #1 of 5 (sent by MX):
Cert VALIDATED: ok
Cert Hostname VERIFIED (mail.checktls.com = *.checktls.com | DNS:*.checktls.com | DNS:checktls.com)
Not Valid Before: Oct  7 12:45:27 2024 GMT
Not Valid After: Nov  8 12:45:27 2025 GMT
subject: /CN=*.checktls.com
issuer: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./OU=http://certs.godaddy.com/repository//CN=Go Daddy Secure Certificate Authority - G2
Certificate #2 of 5 (sent by MX):
Cert VALIDATED: ok
Not Valid Before: May  3 07:00:00 2011 GMT
Not Valid After: May  3 07:00:00 2031 GMT
subject: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./OU=http://certs.godaddy.com/repository//CN=Go Daddy Secure Certificate Authority - G2
issuer: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./CN=Go Daddy Root Certificate Authority - G2
Certificate #3 of 5 (added from CA Root Store):
Cert VALIDATED: ok
Not Valid Before: Sep  1 00:00:00 2009 GMT
Not Valid After: Dec 31 23:59:59 2037 GMT
subject: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./CN=Go Daddy Root Certificate Authority - G2
issuer: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./CN=Go Daddy Root Certificate Authority - G2
Certificate #4 of 5 (sent by MX):
Cert VALIDATED:
Not Valid Before: Jan  1 07:00:00 2014 GMT
Not Valid After: May 30 07:00:00 2031 GMT
subject: /C=US/ST=Arizona/L=Scottsdale/O=GoDaddy.com, Inc./CN=Go Daddy Root Certificate Authority - G2
issuer: /C=US/O=The Go Daddy Group, Inc./OU=Go Daddy Class 2 Certification Authority
Certificate #5 of 5 (sent by MX, also in CA Root Store):
Cert VALIDATED:
Not Valid Before: Jun 29 17:06:20 2004 GMT
Not Valid After: Jun 29 17:06:20 2034 GMT
subject: /C=US/O=The Go Daddy Group, Inc./OU=Go Daddy Class 2 Certification Authority
issuer: /C=US/O=The Go Daddy Group, Inc./OU=Go Daddy Class 2 Certification Authority
[000.081] TLS successfully started on this server
[000.081] <~~ +OK Dovecot ready.
[000.081] We are allowed to connect
[000.081] ~~> QUIT
[000.084] <~~ +OK Logging out