| 1. General Results, most used to calculate the result |
A | name "infinityfree.net" is domain, public suffix is ".net", top-level-domain is ".net", top-level-domain-type is "generic", tld-manager is "VeriSign Global Registry Services", num .net-domains preloaded: 9342 (complete: 245733)
|
A | Good: All ip addresses are public addresses
|
A | Good: Minimal 2 ip addresses per domain name found: infinityfree.net has 3 different ip addresses (authoritative).
|
A | Good: Minimal 2 ip addresses per domain name found: www.infinityfree.net has 3 different ip addresses (authoritative).
|
| Warning: No ipv6 address found. Ipv6 is the future with a lot of new features. So every domain name should have an ipv6 address. See https://en.wikipedia.org/wiki/IPv6: infinityfree.net has no ipv6 address.
|
| Warning: No ipv6 address found. Ipv6 is the future with a lot of new features. So every domain name should have an ipv6 address. See https://en.wikipedia.org/wiki/IPv6: www.infinityfree.net has no ipv6 address.
|
A | Good: No asked Authoritative Name Server had a timeout
|
A | https://www.infinityfree.net/ 104.26.8.174
| https://www.infinityfree.com/
| Correct redirect https to https
|
A | https://www.infinityfree.net/ 104.26.9.174
| https://www.infinityfree.com/
| Correct redirect https to https
|
A | https://www.infinityfree.net/ 172.67.71.120
| https://www.infinityfree.com/
| Correct redirect https to https
|
A | Good: destination is https
|
A | Good - only one version with Http-Status 200
|
A | Good: one preferred version: www is preferred
|
A | Good: No cookie sent via http.
|
| HSTS-Preload-Status: unknown. Domain never included in the Preload-list. Check https://hstspreload.org/ to learn some basics about the Google-Preload-List.
|
A | Good: All urls with http status 200/404 have a complete Content-Type header (MediaType / MediaSubType + correct charset)
|
B | https://infinityfree.net/ 104.26.8.174
|
| Missing HSTS-Header
|
B | https://infinityfree.net/ 104.26.9.174
|
| Missing HSTS-Header
|
B | https://infinityfree.net/ 172.67.71.120
|
| Missing HSTS-Header
|
B | https://www.infinityfree.net/ 104.26.8.174
|
| Missing HSTS-Header
|
B | https://www.infinityfree.net/ 104.26.9.174
|
| Missing HSTS-Header
|
B | https://www.infinityfree.net/ 172.67.71.120
|
| Missing HSTS-Header
|
E | http://infinityfree.net/ 104.26.8.174
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
E | http://infinityfree.net/ 104.26.9.174
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
E | http://infinityfree.net/ 172.67.71.120
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
E | http://www.infinityfree.net/ 104.26.8.174
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
E | http://www.infinityfree.net/ 104.26.9.174
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
E | http://www.infinityfree.net/ 172.67.71.120
| https://www.infinityfree.com/
| Wrong redirect one domain http to other domain https. First redirect to https without new dns query, so the server can send the HSTS header. That's fundamental using HSTS (Http Strict Transport Security). First step: Add correct redirects http ⇒ https. Perhaps in your port 80 vHost something like "RewriteEngine on" + "RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent]" (two rows, without the "). Don't add this in your port 443 vHost, that would create a loop. Then recheck your domain, should be Grade C. There is the rule to select one https version as preferred version.
|
A | Good: More then one ip address per domain name found, checking all ip addresses the same http status and the same certificate found: Domain infinityfree.net, 3 ip addresses.
|
A | Good: More then one ip address per domain name found, checking all ip addresses the same http status and the same certificate found: Domain www.infinityfree.net, 3 ip addresses.
|
| Info: Checking the ip addresses of that domain name not exact one certificate found. So it's impossible to check if that domain requires Server Name Indication (SNI).: Domain infinityfree.net, 3 ip addresses.
|
| Info: Checking the ip addresses of that domain name not exact one certificate found. So it's impossible to check if that domain requires Server Name Indication (SNI).: Domain www.infinityfree.net, 3 ip addresses.
|
A | Good: _mta-sts TXT record found (mta-sts: Mail Transfer Agent Strict Transport Security - see RFC 8461). Domainname: _mta-sts.infinityfree.net
|
B | Bad: _mta-sts TXT found, but invalid
|
| 2. Header-Checks (Cross-Origin-* headers are alpha - started 2024-06-05) |
A | www.infinityfree.com
| Content-Security-Policy
| Ok: Header without syntax errors found: base-uri 'self' https://amli.sekindo.com; connect-src 'self' https: data: www.google-analytics.com fundingchoicesmessages.google.com pagead2.googlesyndication.com; default-src 'self'; font-src 'self' fonts.googleapis.com fonts.gstatic.com cdnjs.cloudflare.com; frame-src 'self' https: googleads.g.doubleclick.net error-report.com; img-src 'self' data: https:; media-src 'self' blob: gcdn.2mdn.net video.primis.tech; script-src 'self' 'report-sample' 'unsafe-inline' 'unsafe-eval' https: blob: www.google-analytics.com pagead2.googlesyndication.com; style-src 'self' 'report-sample' 'unsafe-inline' 'unsafe-eval' fonts.googleapis.com cdnjs.cloudflare.com content.quantcount.com live.primis.tech html-load.com; worker-src blob:; block-all-mixed-content; report-to https://o881419.ingest.sentry.io/api/6108064/security/?sentry_key=53507701d302401b97c4a9ec903c141e
|
B |
|
| Info: Header-Element is deprecated. block-all-mixed-content
|
A |
|
| Good: default-src directive only with 'none' or 'self', additional sources are blocked.
|
A |
|
| Good: default-src without 'unsafe-inline' or 'unsave-eval'.
|
E |
|
| Bad: No form-action directive found. Use one to limit the form - action - destinations. form-action is a navigation-directive, so default-src isn't used.
|
E |
|
| Bad: No frame-ancestors directive found. Use one to limit the pages allowed to use this page in frame / iframe / object / embed / applet. frame-ancestors is a navigation-directive, so default-src isn't used.
|
A |
|
| Good: base-uri directive found. That limits the URLs which can be used in a document's <base> element. Because it's a document directive, default-src isn't used, so an own directive is required.
|
A |
|
| Good: No object-src found, but the default-src used as fallback is defined and restricted.
|
F |
|
| Critical: script-src with 'unsafe-inline' or 'unsafe-eval' and without a nonce found. That's dangerous, don't use it. If you really need one of these unsafe directives, add a nonce.
|
F |
|
| Critical: script-src with * or a scheme found. Never allow wildcard - sources.
|
A |
|
| Good: script-src without data: schema found. Why is this important? The data: schema allows hidden code injection. Insert <script src='data:application/javascript;base64,YWxlcnQoJ1hTUycpOw=='></script> in your page and see what happens.
|
A |
|
| Good: frame-src without data: defined or frame-src missing and the default-src used as fallback not allows the data: schema. That blocks hidden code injection. Insert <iframe src="data:text/html;charset=utf-8;base64,PCFET0NUWVBFIGh0bWw+PGh0bWw+PGJvZHk+PHA+YmVmb3JlPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPmFsZXJ0KCdYU1MnKTwvc2NyaXB0PjxwPmFmdGVyPC9ib2R5PjwvaHRtbD4="></iframe> in your page and see what happens.
|
C |
|
| Info: default-src and some other fetch directives have the same list of values. Remove the other fetch directive, default-src is used as fallback. Directives to remove: https://o881419.ingest.sentry.io/api/6108064/security/?sentry_key=53507701d302401b97c4a9ec903c141e
|
A |
| report-to
| Ok: Header without syntax errors found: {"endpoints":[{"url":"https:\/\/a.nel.cloudflare.com\/report\/v4?s=0VbKnd6yhgT8PzVSHbb1Q7hxDbAgn7gthJ%2BjCsiuFYz%2FGyyLFrzl%2Fk3C4vogRWsYsUxtr%2FyfY5fKcAIhQRSmYJ96YDHZNE%2FJsCrYijPXf1IgEr4qvNDude7VJbIKldrDzH7CVfuI09NwymoCoWN1BhLzYQ%3D%3D"}],"group":"cf-nel","max_age":604800}
|
A |
|
| Ok: Header without syntax errors found: {"endpoints":[{"url":"https:\/\/a.nel.cloudflare.com\/report\/v4?s=0VbKnd6yhgT8PzVSHbb1Q7hxDbAgn7gthJ%2BjCsiuFYz%2FGyyLFrzl%2Fk3C4vogRWsYsUxtr%2FyfY5fKcAIhQRSmYJ96YDHZNE%2FJsCrYijPXf1IgEr4qvNDude7VJbIKldrDzH7CVfuI09NwymoCoWN1BhLzYQ%3D%3D"}],"group":"cf-nel","max_age":604800}
|
A |
| X-Content-Type-Options
| Ok: Header without syntax errors found: nosniff
|
A |
| Referrer-Policy
| Ok: Header without syntax errors found: origin
|
A |
| Permissions-Policy
| Ok: Header without syntax errors found: accelerometer=(self), ambient-light-sensor=(self), autoplay=(self), battery=(self), camera=(self), cross-origin-isolated=(self), display-capture=(self), document-domain=*, encrypted-media=(self), execution-while-not-rendered=*, execution-while-out-of-viewport=*, fullscreen=(self), geolocation=(self), gyroscope=(self), magnetometer=(self), microphone=(self), midi=(self), navigation-override=(self), payment=(self), picture-in-picture=*, publickey-credentials-get=(self), screen-wake-lock=(self), sync-xhr=*, usb=(self), web-share=(self), xr-spatial-tracking=(self)
|
A |
| X-Frame-Options
| Ok: Header without syntax errors found: SAMEORIGIN
|
B |
|
| Info: Header is deprecated. May not longer work in modern browsers. SAMEORIGIN. Better solution: Use a Content-Security-Policy Header with a frame-ancestors directive. DENY - use 'none', SAMEORIGIN - use 'self'. If you want to allow some domains to frame your page, add these urls.
|
B | www.infinityfree.com
| Cross-Origin-Embedder-Policy
| Info: Missing Header
|
B | www.infinityfree.com
| Cross-Origin-Opener-Policy
| Info: Missing Header
|
B | www.infinityfree.com
| Cross-Origin-Resource-Policy
| Info: Missing Header
|
| 3. DNS- and NameServer - Checks |
A | Info:: 7 Root-climbing DNS Queries required to find all IPv4- and IPv6-Addresses of 2 Name Servers.
|
A | Info:: 7 Queries complete, 7 with IPv6, 0 with IPv4.
|
A | Good: All DNS Queries done via IPv6.
|
| Ok (4 - 8):: An average of 3.5 queries per domain name server required to find all ip addresses of all name servers.
|
A | Info:: 2 different Name Servers found: beth.ns.cloudflare.com, paul.ns.cloudflare.com, 2 Name Servers included in Delegation: beth.ns.cloudflare.com, paul.ns.cloudflare.com, 2 Name Servers included in 1 Zone definitions: beth.ns.cloudflare.com, paul.ns.cloudflare.com, 1 Name Servers listed in SOA.Primary: beth.ns.cloudflare.com.
|
A | Good: Only one SOA.Primary Name Server found.: beth.ns.cloudflare.com.
|
A | Good: SOA.Primary Name Server included in the delegation set.: beth.ns.cloudflare.com.
|
A | Good: Consistency between delegation and zone. The set of NS records served by the authoritative name servers must match those proposed for the delegation in the parent zone. Ordered list of name servers: beth.ns.cloudflare.com, paul.ns.cloudflare.com
|
A | Good: All Name Server Domain Names have a Public Suffix.
|
A | Good: All Name Server Domain Names ending with a Public Suffix have minimal one IPv4- or IPv6 address.
|
A | Good: All Name Server ip addresses are public.
|
A | Good: Minimal 2 different name servers (public suffix and public ip address) found: 2 different Name Servers found
|
| Warning: All Name Servers have the same Top Level Domain / Public Suffix. If there is a problem with that Top Level Domain, your domain may be affected. Better: Use Name Servers with different top level domains.: 2 Name Servers, 1 Top Level Domain: com
|
| Warning: All Name Servers have the same domain name. If there is a problem with that domain name (or with the name servers of that domain name), your domain may be affected. Better: Use Name Servers with different domain names / different top level domains.: Only one domain name used: cloudflare.com
|
A | Good: Name servers with different Country locations found: 2 Name Servers, 4 Countries: CA, CR, GB, US
|
A | Info: Ipv4-Subnet-list: 6 Name Servers, 3 different subnets (first Byte): 108., 172., 173., 3 different subnets (first two Bytes): 108.162., 172.64., 173.245., 6 different subnets (first three Bytes): 108.162.192., 108.162.193., 172.64.32., 172.64.33., 173.245.58., 173.245.59.
|
A | Good: Name Server IPv4-addresses from different subnet found:
|
A | Info: IPv6-Subnet-list: 6 Name Servers with IPv6, 3 different subnets (first block): 2606:, 2803:, 2a06:, 3 different subnets (first two blocks): 2606:4700:, 2803:f800:, 2a06:98c1:, 4 different subnets (first three blocks): 2606:4700:0050:, 2606:4700:0058:, 2803:f800:0050:, 2a06:98c1:0050:, 4 different subnets (first four blocks): 2606:4700:0050:0000:, 2606:4700:0058:0000:, 2803:f800:0050:0000:, 2a06:98c1:0050:0000:
|
A | Good: Name Server IPv6 addresses from different subnets found.
|
A | Good: Nameserver supports TCP connections: 12 good Nameserver
|
A | Good: Nameserver supports Echo Capitalization: 12 good Nameserver
|
A | Good: Nameserver supports EDNS with max. 512 Byte Udp payload, message is smaller: 12 good Nameserver
|
A | Good: All SOA have the same Serial Number
|
A | Good: CAA entries found, creating certificate is limited: comodoca.com is allowed to create certificates
|
A | Good: CAA entries found, creating certificate is limited: digicert.com is allowed to create certificates
|
A | Good: CAA entries found, creating certificate is limited: letsencrypt.org is allowed to create certificates
|
A | Good: CAA entries found, creating certificate is limited: pki.goog is allowed to create certificates
|
A | Good: CAA entries found, creating certificate is limited: ssl.com is allowed to create certificates
|
A | Good: CAA entries found, creating certificate is limited: comodoca.com is allowed to create wildcard-certificates
|
A | Good: CAA entries found, creating certificate is limited: digicert.com is allowed to create wildcard-certificates
|
A | Good: CAA entries found, creating certificate is limited: letsencrypt.org is allowed to create wildcard-certificates
|
A | Good: CAA entries found, creating certificate is limited: pki.goog is allowed to create wildcard-certificates
|
A | Good: CAA entries found, creating certificate is limited: ssl.com is allowed to create wildcard-certificates
|
| 4. Content- and Performance-critical Checks |
A | Good: All checks /.well-known/acme-challenge/random-filename without redirects answer with the expected http status 404 - Not Found. Creating a Letsencrypt certificate via http-01 challenge should work. If it doesn't work: Check your vHost configuration (apachectl -S, httpd -S, nginx -T). Every combination of port and ServerName / ServerAlias (Apache) or Server (Nginx) must be unique. Merge duplicated entries in one vHost. If you use an IIS, extensionless files must be allowed in the /.well-known/acme-challenge subdirectory. Create a web.config in that directory. Content: <configuration><system.webServer><staticContent><mimeMap fileExtension="." mimeType="text/plain" /></staticContent></system.webServer></configuration>. If you have a redirect http ⇒ https, that's ok, Letsencrypt follows such redirects to port 80 / 443 (same or other server). There must be a certificate. But the certificate may be expired, self signed or with a not matching domain name. Checking the validation file Letsencrypt ignores such certificate errors. Trouble creating a certificate? Use https://community.letsencrypt.org/ to ask.
|
A | Good: Every https result with status 200 and greater 1024 Bytes is compressed (gzip, deflate, br checked).
|
| https://www.infinityfree.com/
|
| Warning: Https + http status 200 + Inline CSS / JavaScript found. Don't use inline CSS / JavaScript. These are compiled and re-used ressources, save these with a long Cache-Control max-age - header.
|
A | Good: Every https result with status 200 has a minified Html-Content with a quota lower then 110 %.
|
A | Good: Every https connection via port 443 supports the http/2 protocol via ALPN.
|
A | Good: Some script Elements (type text/javascript) with a src-Attribute have a defer / async - Attribute. So loading and executing these JavaScripts doesn't block parsing and rendering the Html-Output.
|
| https://www.infinityfree.com/
|
| Critical: Some script Elements (type text/javascript) with a src-Attribute don't have a defer / async - Attribute. Loading and executing these JavaScripts blocks parsing and rendering the Html-Output. That's bad if your site is large or the connection is slow / mobile usage. Use "async" if the js file has only functions (so nothing is executed after parsing the file) or is independend. Use "defer" if the order of the scripts is important. All "defer" scripts are executed before the DOMContentLoaded event is fired. Check https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script to see some details.: 3 script elements without defer/async.
|
| https://www.infinityfree.com/.well-known/acme-challenge/check-your-website-dot-server-daten-dot-de
|
| Critical: Some script Elements (type text/javascript) with a src-Attribute don't have a defer / async - Attribute. Loading and executing these JavaScripts blocks parsing and rendering the Html-Output. That's bad if your site is large or the connection is slow / mobile usage. Use "async" if the js file has only functions (so nothing is executed after parsing the file) or is independend. Use "defer" if the order of the scripts is important. All "defer" scripts are executed before the DOMContentLoaded event is fired. Check https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script to see some details.: 2 script elements without defer/async.
|
A | Good: All CSS / JavaScript files are sent compressed (gzip, deflate, br checked). That reduces the content of the files. 13 external CSS / JavaScript files found
|
A | Good: All images with internal compression not compressed. Some Images (.png, .jpg, .jpeg, .webp, .gif) are already compressed, so an additional compression isn't helpful. 15 images (type image/png, image/jpg, image/jpeg, image/webp, image/gif) found without additional Compression. Not required because these images are already compressed
|
| Warning: CSS / JavaScript files with a missing or too short Cache-Control header found. Browsers should cache and re-use these files. 0 external CSS / JavaScript files without Cache-Control-Header, 0 with Cache-Control, but no max-age, 15 with Cache-Control max-age too short (minimum 7 days), 0 with Cache-Control long enough, 15 complete.
|
| Warning: Images with a missing or too short Cache-Control header found. Browsers should cache and re-use these files. 0 image files without Cache-Control-Header, 0 with Cache-Control, but no max-age, 15 with Cache-Control max-age too short (minimum 7 days), 0 with Cache-Control long enough, 15 complete.
|
A | Good: Some checked attribute values are enclosed in quotation marks (" or ').: 117 Html-Elements checked, 110 without problems.
|
I | Wrong: Attribute values found, not enclosed in quotation marks (" or ').: 7 Html-Elements with attributes and missing enclosed quotation marks found. 7 wrong attributes.
|
A | Good: All img-elements have a valid alt-attribute.: 15 img-elements found.
|
A | Good: Domainname is not on the "Specially Designated Nationals And Blocked Persons List" (SDN). That's an US-list of individuals and companies owned or controlled by, or acting for or on behalf of, targeted countries. It also lists individuals, groups, and entities, such as terrorists and narcotics traffickers designated under programs that are not country-specific. Collectively, such individuals and companies are called "Specially Designated Nationals" or "SDNs." Their assets are blocked and U.S. persons are generally prohibited from dealing with them. So if a domain name is on that list, it's impossible to create a Letsencrypt certificate with that domain name. Check the list manual - https://www.treasury.gov/resource-center/sanctions/sdn-list/pages/default.aspx
|
| https://www.infinityfree.com/.well-known/acme-challenge/check-your-website-dot-server-daten-dot-de
| 2.276 seconds
| Warning: 404 needs more then one second
|
A | Duration: 133697 milliseconds, 133.697 seconds
|