Skip to content
https://adage.com

Security

· 12 checks — HTTP headers, CSP, TLS handshake, and cookie hygiene rolled into one auditable list.
SCORE
69
GRADE
D
FIX
5
REVIEW
3
PASS
4
INFO
0
Checks
12
4 PASS 3 REVIEW 5 FIX
F
Security Headers
Action
3 of 10 headers properly configured
FIX
3 of 10 headers properly configured
Critical::
HSTS header is missing
Strict-Transport-Security forces browsers to use HTTPS, preventing downgrade attacks. Add the header with a max-age of at least 1 year.
Expected: max-age=31536000; includeSubDomains
Warning::
X-Content-Type-Options header is missing
This header prevents MIME-type sniffing, which can lead to XSS attacks. Set it to 'nosniff'.
Expected: nosniff
Warning::
X-Frame-Options header is missing
This header prevents clickjacking by controlling who can embed your page in a frame. Set it to DENY or SAMEORIGIN.
Expected: DENY
Warning::
Referrer-Policy header is missing
Controls how much referrer information is sent with requests. Set to 'strict-origin-when-cross-origin' or stricter.
Expected: strict-origin-when-cross-origin
Warning::
Permissions-Policy header is missing
Controls which browser features (camera, microphone, geolocation) are allowed. Set it to restrict unused features.
Expected: geolocation=(), camera=(), microphone=()
Info::
Content-Security-Policy is present
Got: upgrade-insecure-requests
Warning::
Cross-Origin-Opener-Policy header is missing
COOP isolates your browsing context, preventing cross-origin side-channel attacks. Set to 'same-origin'.
Expected: same-origin
Warning::
Cross-Origin-Embedder-Policy header is missing
COEP prevents loading cross-origin resources without explicit permission. Required for SharedArrayBuffer and high-resolution timers.
Expected: require-corp
Info::
X-Powered-By header is not present
Info::
Server header is present without version info
Got: openresty

Strict-Transport-Security forces browsers to use HTTPS, preventing downgrade attacks. Add the header with a max-age of at least 1 year.

Expected: max-age=31536000; includeSubDomains
Why this matters

Without HSTS, a network attacker can downgrade the very first connection to HTTP and steal the user's session.

Learn more

HSTS tells browsers 'never speak HTTP to this domain again.' Without it, a network attacker (public WiFi, malicious ISP, hostile DNS) intercepts the first HTTP attempt and serves a downgraded version of your site. One header, big surface reduction.

Source: RFC 6797 / OWASP

This header prevents MIME-type sniffing, which can lead to XSS attacks. Set it to 'nosniff'.

Expected: nosniff
Why this matters

MIME sniffing lets browsers run uploaded files as JavaScript, turning a file upload into an XSS.

Learn more

Setting X-Content-Type-Options: nosniff tells browsers to trust your declared Content-Type instead of guessing. Without it, an attacker who uploads a polyglot file can sometimes get it executed as a script. One header, no downside.

Source: OWASP / MDN

This header prevents clickjacking by controlling who can embed your page in a frame. Set it to DENY or SAMEORIGIN.

Expected: DENY
Why this matters

Without frame protection, your site can be embedded in a hostile page and used for clickjacking.

Learn more

Clickjacking overlays your site under a transparent malicious page so users click invisible buttons. Setting X-Frame-Options: DENY (or a modern frame-ancestors CSP directive) blocks the embedding entirely. There's almost never a legitimate reason to allow it.

Source: OWASP / MDN

Controls how much referrer information is sent with requests. Set to 'strict-origin-when-cross-origin' or stricter.

Expected: strict-origin-when-cross-origin
Why this matters

Default browser behavior leaks full URLs (including query params and tokens) to every third-party resource — set a strict policy.

Learn more

Without a Referrer-Policy header, browsers send the full referring URL with images, scripts, and fonts loaded from third-party origins. URLs containing tokens, user IDs, or session params end up in third-party logs. Set `Referrer-Policy: strict-origin-when-cross-origin` (or stricter) to limit leakage.

Source: MDN / W3C

Controls which browser features (camera, microphone, geolocation) are allowed. Set it to restrict unused features.

Expected: geolocation=(), camera=(), microphone=()
Why this matters

Permissions-Policy locks down browser APIs you don't use — without it, every page can request camera/mic/geolocation if XSS lands.

Learn more

By default every page can request the camera, microphone, geolocation, payment APIs, and dozens more. Permissions-Policy turns off the ones you don't need so a future bug can't quietly start using them. It's a defense-in-depth header — one line, big surface reduction.

Source: MDN / W3C

COOP isolates your browsing context, preventing cross-origin side-channel attacks. Set to 'same-origin'.

Expected: same-origin
Why this matters

COOP isolates your top-level browsing context from cross-origin windows — without it, popup-based side-channel attacks remain possible.

Learn more

Cross-Origin-Opener-Policy: same-origin prevents cross-origin pages from sharing a browsing-context group with yours. This blocks cross-window references that enable Spectre-style timing attacks and tab-nabbing. Required if you want to enable SharedArrayBuffer.

Source: MDN / web.dev

COEP prevents loading cross-origin resources without explicit permission. Required for SharedArrayBuffer and high-resolution timers.

Expected: require-corp
Why this matters

COEP enforces that all embedded resources opt-in to cross-origin embedding — required for cross-origin isolation features.

Learn more

Cross-Origin-Embedder-Policy: require-corp ensures every embedded resource (script, iframe, image) explicitly allows being loaded cross-origin. Combined with COOP, this enables the cross-origin-isolated context that unlocks SharedArrayBuffer, high-resolution timers, and other powerful APIs.

Source: MDN / web.dev

D
Subresource Integrity
Action
1 of 64 external resources have SRI
FIX
1 of 64 external resources have SRI
Warning::
External script from scripts.clarity.ms lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://scripts.clarity.ms/0.8.59/clarity.js
Warning::
External script from www.clarity.ms lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://www.clarity.ms/tag/uet/343049411?insights=1
Warning::
External script from www.googletagmanager.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://www.googletagmanager.com/gtag/js?id=AW-1052425953&cx=c&gtm=4e64h1
Warning::
External script from www.redditstatic.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://www.redditstatic.com/ads/pixel.js
Info::
script from www.gstatic.com has SRI protection
Warning::
External script from analytics.tiktok.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://analytics.tiktok.com/i18n/pixel/static/identify_5cff1caf.js
Warning::
External script from analytics.tiktok.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://analytics.tiktok.com/i18n/pixel/static/main.MWE0ZWQ3ZWQwOA.js
Warning::
External script from tags.srv.stackadapt.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://tags.srv.stackadapt.com/events.js
Warning::
External script from www.recaptcha.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://www.recaptcha.net/recaptcha/enterprise.js?render=6LecrmQqAAAAADFyMy9b-gCGZq4rs8ljMafjIZYB
Warning::
External script from applepay.cdn-apple.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://applepay.cdn-apple.com/jsapi/v1/apple-pay-sdk.js
Warning::
External script from static.ads-twitter.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: //static.ads-twitter.com/uwt.js
Warning::
External script from snap.licdn.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://snap.licdn.com/li.lms-analytics/insight.min.js
Warning::
External script from analytics.tiktok.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://analytics.tiktok.com/i18n/pixel/events.js?sdkid=C3D2UGQTO1NMNN16J3LG&lib=ttq
Warning::
External script from js.pelcro.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://js.pelcro.com/ui/plugin/crain-consolidated/main.min.js
Warning::
External script from browser.sentry-cdn.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://browser.sentry-cdn.com/10.49.0/bundle.tracing.min.js
Warning::
External script from cdn.cxense.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.cxense.com/cx.js
Warning::
External script from cdn.cxense.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.cxense.com/cx.cce.js
Warning::
External script from rockstarwriter.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://rockstarwriter.com/5a2865a7fe/e9ad98c3761e3e974c9d42305f56f83f0198.index.js
Warning::
External script from cdn.adage.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.adage.com/api/tinypass.min.js
Warning::
External script from us-assets.i.posthog.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://us-assets.i.posthog.com/static/array.js
Warning::
External script from consent.trustarc.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://consent.trustarc.com/notice?domain=crain-adage.com&c=teconsent&js=nj&noticeType=bb
Warning::
External script from d1mkq4fbm7j30i.cloudfront.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://d1mkq4fbm7j30i.cloudfront.net/108/37fa87d2f87b43fb881d228282445a5a/oHS.js
Warning::
External script from a220.adage.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://a220.adage.com/script.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/launch-64bfee4f4fc5.min.js
Warning::
External link from use.typekit.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://use.typekit.net/coe1lxr.css
Warning::
External script from cdn.sophi.io lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.sophi.io/assets/demeter/1/stable/2412118541.js?d=236
Warning::
External script from consent.trustarc.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://consent.trustarc.com/asset/tcfapi2.2.js
Warning::
External script from consent.trustarc.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://consent.trustarc.com/asset/notice.js/v/v1.7-1729
Warning::
External script from c2.adage.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: //c2.adage.com/xbuilder/experience/load?aid=YGJo1BVkpu&d=236
Warning::
External script from s.go-mpulse.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://s.go-mpulse.net/boomerang/ANX5N-KRKNP-YC2Q2-WTKV5-85AV4
Warning::
External script from js.stripe.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://js.stripe.com/v3
Warning::
External script from connect.facebook.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://connect.facebook.net/signals/config/444187019640480?v=2.9.303&r=canary&domain=adage.com&hme=97937018cefade17726f0472876fc101316b2ce9008a35a6a5a7977d7436151a&ex_m=104%2C205%2C154%2C22%2C72%2C73%2C145%2C68%2C67%2C11%2C162%2C90%2C16%2C138%2C127%2C39%2C75%2C78%2C134%2C159%2C164%2C8%2C4%2C5%2C7%2C6%2C3%2C91%2C101%2C165%2C170%2C219%2C62%2C186%2C187%2C55%2C276%2C30%2C74%2C231%2C230%2C229%2C23%2C33%2C103%2C61%2C10%2C63%2C97%2C98%2C99%2C105%2C130%2C31%2C29%2C132%2C133%2C129%2C128%2C155%2C76%2C158%2C156%2C157%2C50%2C60%2C123%2C15%2C161%2C45%2C263%2C264%2C262%2C64%2C26%2C27%2C28%2C48%2C146%2C77%2C112%2C18%2C20%2C44%2C40%2C42%2C41%2C83%2C92%2C96%2C110%2C144%2C147%2C46%2C111%2C24%2C21%2C119%2C69%2C36%2C149%2C148%2C150%2C141%2C139%2C25%2C35%2C59%2C109%2C160%2C70%2C17%2C152%2C114%2C81%2C66%2C19%2C85%2C86%2C116%2C84%2C136%2C135%2C34%2C269%2C268%2C278%2C293%2C212%2C201%2C202%2C200%2C296%2C288%2C52%2C213%2C107%2C131%2C80%2C121%2C54%2C47%2C49%2C113%2C120%2C126%2C58%2C151%2C115%2C37%2C32%2C53%2C56%2C100%2C163%2C1%2C124%2C14%2C122%2C12%2C2%2C57%2C93%2C65%2C118%2C89%2C88%2C166%2C167%2C94%2C95%2C9%2C125%2C102%2C51%2C142%2C87%2C79%2C71%2C117%2C106%2C43%2C143%2C0%2C82%2C137%2C140%2C153%2C38%2C108%2C13%2C168
Warning::
External script from connect.facebook.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://connect.facebook.net/en_US/fbevents.js
Warning::
External script from static.hotjar.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://static.hotjar.com/c/hotjar-1906520.js?sv=6
Warning::
External script from securepubads.g.doubleclick.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://securepubads.g.doubleclick.net/pagead/managed/js/gpt/m202604170101/pubads_impl.js?cb=31097963
Warning::
External script from js.sentry-cdn.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://js.sentry-cdn.com/c3bcce31053fd1cacfa684e09f5d07cc.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC8cb96f4c9f724404a96f424b911ba9f4-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RCe4281ee3686b46aab9d3344044b0b099-source.min.js
Warning::
External script from cdn.onesignal.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.onesignal.com/sdks/web/v16/OneSignalSDK.page.es6.js?v=160603
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC013f49976e424e5d8c7980c73cd8c84c-source.min.js
Warning::
External script from www.googletagmanager.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://www.googletagmanager.com/gtag/js?id=G-94BVKS4T4Y&l=dataLayer
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC6837275b76e64f1ba4a35f427a848179-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC5617ef44536e4dbba980ffb4a1f1e952-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC67865592b9ca4bd18084cc89a2ab9dfc-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC420c7dd9125244b0beb0d9d32c9093e3-source.min.js
Warning::
External script from static.hotjar.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://static.hotjar.com/c/hotjar-1906529.js?sv=6
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC4d005f2114bf4d188e6fc99cc133c38b-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC83fbf9f669bc4caaa788555b58ad6f3f-source.min.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC3646f41da8fb434fbd978f7cdbcd4622-source.min.js
Warning::
External link from tags.srv.stackadapt.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://tags.srv.stackadapt.com/sa.css
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RCb01fe9eadedd4f3ea8d0c7accad0cfd6-source.min.js
Warning::
External script from bat.bing.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: //bat.bing.com/bat.js
Warning::
External script from bat.bing.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://bat.bing.com/p/action/343049411.js
Warning::
External script from assets.adobedtm.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://assets.adobedtm.com/05852ba8023b/ed9fd9dbe099/a8b9219bf1c5/RC1c86bc026be14c658636c37e8d066ff8-source.min.js
Warning::
External script from us-assets.i.posthog.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://us-assets.i.posthog.com/static/web-vitals.js?v=1.369.5
Warning::
External script from us-assets.i.posthog.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://us-assets.i.posthog.com/static/dead-clicks-autocapture.js?v=1.369.5
Warning::
External script from us-assets.i.posthog.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://us-assets.i.posthog.com/static/surveys.js?v=1.369.5
Warning::
External script from us-assets.i.posthog.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://us-assets.i.posthog.com/array/phc_QX4NPsdY7YPw9O0Ys0N52fLttiv2HupxKBCVJyXWUii/config.js
Warning::
External script from consent.trustarc.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://consent.trustarc.com/asset/uspapi.js
Warning::
External script from d15kdpgjg3unno.cloudfront.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://d15kdpgjg3unno.cloudfront.net/oPS.js?cid=108
Warning::
External script from js.pelcro.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://js.pelcro.com/sdk/main.min.js
Warning::
External script from securepubads.g.doubleclick.net lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://securepubads.g.doubleclick.net/tag/js/gpt.js
Warning::
External script from cdn.onesignal.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://cdn.onesignal.com/sdks/web/v16/OneSignalSDK.page.js
Warning::
External script from js.zi-scripts.com lacks integrity attribute
Without SRI, if this CDN is compromised, attackers could inject malicious code.
Got: https://js.zi-scripts.com/zi-tag.js
SRI Coverage 1 / 64 of external resources have integrity hashes
TagDomainIntegrity
<script>scripts.clarity.ms Missing
<script>www.clarity.ms Missing
<script>www.googletagmanager.com Missing
<script>www.redditstatic.com Missing
<script>www.gstatic.com Protected
<script>analytics.tiktok.com Missing
<script>analytics.tiktok.com Missing
<script>tags.srv.stackadapt.com Missing
<script>www.recaptcha.net Missing
<script>applepay.cdn-apple.com Missing
<script>static.ads-twitter.com Missing
<script>snap.licdn.com Missing
<script>analytics.tiktok.com Missing
<script>js.pelcro.com Missing
<script>browser.sentry-cdn.com Missing
<script>cdn.cxense.com Missing
<script>cdn.cxense.com Missing
<script>rockstarwriter.com Missing
<script>cdn.adage.com Missing
<script>us-assets.i.posthog.com Missing
<script>consent.trustarc.com Missing
<script>d1mkq4fbm7j30i.cloudfront.net Missing
<script>a220.adage.com Missing
<script>assets.adobedtm.com Missing
<link>use.typekit.net Missing
<script>cdn.sophi.io Missing
<script>consent.trustarc.com Missing
<script>consent.trustarc.com Missing
<script>c2.adage.com Missing
<script>s.go-mpulse.net Missing
<script>js.stripe.com Missing
<script>connect.facebook.net Missing
<script>connect.facebook.net Missing
<script>static.hotjar.com Missing
<script>securepubads.g.doubleclick.net Missing
<script>js.sentry-cdn.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<script>cdn.onesignal.com Missing
<script>assets.adobedtm.com Missing
<script>www.googletagmanager.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<script>static.hotjar.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<script>assets.adobedtm.com Missing
<link>tags.srv.stackadapt.com Missing
<script>assets.adobedtm.com Missing
<script>bat.bing.com Missing
<script>bat.bing.com Missing
<script>assets.adobedtm.com Missing
<script>us-assets.i.posthog.com Missing
<script>us-assets.i.posthog.com Missing
<script>us-assets.i.posthog.com Missing
<script>us-assets.i.posthog.com Missing
<script>consent.trustarc.com Missing
<script>d15kdpgjg3unno.cloudfront.net Missing
<script>js.pelcro.com Missing
<script>securepubads.g.doubleclick.net Missing
<script>cdn.onesignal.com Missing
<script>js.zi-scripts.com Missing
D
Email Security
Action
DMARC: none
FIX
DMARC: none
Warning::
DMARC policy is none — monitoring only
This only monitors, it doesn't block spoofed emails. Change to p=quarantine or p=reject.
DMARC
Policy none — monitoring only, does not block spoofing Record v=DMARC1; p=none;

This only monitors, it doesn't block spoofed emails. Change to p=quarantine or p=reject.

Why this matters

DMARC p=none collects reports but doesn't actually block spoofed mail — phishing emails still reach inboxes.

Learn more

DMARC's three policies are p=none (monitor only), p=quarantine (mark as spam), and p=reject (bounce). Most domains start at p=none to gather data, but stay there forever, leaving spoofers unblocked. After 30 days of clean DMARC reports, graduate to p=quarantine, then p=reject.

Source: DMARC.org / NIST

D
Permissions-Policy
Action
No header set
FIX
No header set
Warning::
No Permissions-Policy header
Consider adding a Permissions-Policy header to restrict browser feature access from embedded content.

No Permissions-Policy header set.

Without this header, embedded iframes can request access to sensitive device features.

Suggested header
Permissions-Policy: camera=(), microphone=(), geolocation=(), payment=(), usb=()
D
security.txt
Action
No /.well-known/security.txt published
FIX

security.txt

No security.txt found at /.well-known/security.txt

C
Content Security Policy
Action
2 of 10 CSP checks passed
REVIEW
2 of 10 CSP checks passed
Info::
Raw CSP policy
Got: upgrade-insecure-requests
Warning::
default-src directive is missing
default-src provides a fallback for other directives. Set it to restrict default resource loading.
Expected: default-src 'self'
Info::
No script-src or default-src to check for 'unsafe-inline'
Info::
No script-src or default-src to check for 'unsafe-eval'
Info::
No script-src or default-src to check for wildcard
Info::
object-src falls back to default-src
Warning::
base-uri directive is missing
Without base-uri, attackers can inject a <base> tag to hijack relative URLs. Set it to 'self' or 'none'.
Expected: base-uri 'self'
Warning::
frame-ancestors directive is missing
frame-ancestors controls who can embed your page, preventing clickjacking. Set it to 'self' or 'none'.
Expected: frame-ancestors 'self'
Warning::
form-action directive is missing
form-action restricts where forms can submit data, preventing form hijacking.
Expected: form-action 'self'
Info::
upgrade-insecure-requests is enabled

default-src provides a fallback for other directives. Set it to restrict default resource loading.

Expected: default-src 'self'
Why this matters

Security gaps expose your site and users to attacks, eroding trust.

Without base-uri, attackers can inject a <base> tag to hijack relative URLs. Set it to 'self' or 'none'.

Expected: base-uri 'self'
Why this matters

Missing base-uri in CSP leaves a base-tag injection attack path open even on otherwise strict policies.

Learn more

A common omission: developers add CSP for script-src and frame-ancestors but forget base-uri. The result is a CSP that looks strict but lets an attacker rewrite every URL on the page via <base href>. Add `base-uri 'self'` to close the gap.

Source: MDN CSP

frame-ancestors controls who can embed your page, preventing clickjacking. Set it to 'self' or 'none'.

Expected: frame-ancestors 'self'
Why this matters

Security gaps expose your site and users to attacks, eroding trust.

form-action restricts where forms can submit data, preventing form hijacking.

Expected: form-action 'self'
Why this matters

Security gaps expose your site and users to attacks, eroding trust.

Parsed Policy

upgrade-insecure-requests
B
CORS Configuration
No CORS headers
REVIEW
No CORS headers
Info::
No CORS headers present — secure default
CORS Configuration Secure

No CORS headers detected.

Cross-origin requests are blocked by browser same-origin policy.

Origin reflection test

Some servers mirror the request Origin header, which can be exploited. Test manually:

curl -sI -H "Origin: https://evil.com" <url> | grep -i access-control
B
Transport Security
HTTP/3, HSTS, and TLS version analysis
REVIEW
HTTP/3, HSTS, and TLS version analysis
Info::
HTTP/3 (QUIC) not advertised
HTTP/3 eliminates head-of-line blocking. If your CDN supports it, consider enabling it.
Warning::
Missing Strict-Transport-Security header
HSTS tells browsers to only use HTTPS, preventing SSL stripping attacks.
Info::
TLS 1.3 in use (fastest handshake, 1-RTT)
A+
TLS & Certificates
TLS 1.3, 7 checks passed
PASS
TLS 1.3, 7 checks passed
Info::
TLS 1.3 is used
Got: TLS 1.3
Info::
Strong cipher suite is used
Got: TLS_AES_256_GCM_SHA384
Info::
HTTP/2 is not negotiated
HTTP/2 provides multiplexing and header compression for better performance.
Got: http/1.1
Info::
Certificate is valid (expires in 43 days)
Got: 2026-06-04T13:15:10Z
Info::
Certificate chain has 2 certificates
Info::
Certificate uses modern signature algorithm
Got: SHA256-RSA
Info::
Certificate covers 95 domain(s)
Got: adage.com, arcxp-dev.adage.com, arcxp-dev.automobilwoche.de, arcxp-dev.autonews.com, arcxp-dev.chicagobusiness.com, arcxp-dev.crainscleveland.com, arcxp-dev.crainsdetroit.com, arcxp-dev.crainsgrandrapids.com, arcxp-dev.crainsnewyork.com, arcxp-dev.genomeweb.com, arcxp-dev.hartenergy.com, arcxp-dev.modernhealthcare.com, arcxp-dev.pionline.com, arcxp-dev.plasticsnews.com, arcxp-dev.rubbernews.com, arcxp-dev.tirebusiness.com, arcxp-dev.utech-polyurethane.com, arcxp-prod.automobilwoche.de, arcxp-prod.chicagobusiness.com, arcxp-prod.crainscleveland.com, arcxp-prod.crainsdetroit.com, arcxp-prod.crainsgrandrapids.com, arcxp-prod.crainsnewyork.com, arcxp-prod.genomeweb.com, arcxp-prod.hartenergy.com, arcxp-prod.modernhealthcare.com, arcxp-prod.pionline.com, arcxp-prod.plasticsnews.com, arcxp-prod.rubbernews.com, arcxp-prod.tirebusiness.com, arcxp-prod.utech-polyurethane.com, arcxp-sandbox.adage.com, arcxp-sandbox.automobilwoche.de, arcxp-sandbox.autonews.com, arcxp-sandbox.chicagobusiness.com, arcxp-sandbox.crainscleveland.com, arcxp-sandbox.crainsdetroit.com, arcxp-sandbox.crainsgrandrapids.com, arcxp-sandbox.crainsnewyork.com, arcxp-sandbox.genomeweb.com, arcxp-sandbox.hartenergy.com, arcxp-sandbox.modernhealthcare.com, arcxp-sandbox.pionline.com, arcxp-sandbox.plasticsnews.com, arcxp-sandbox.rubbernews.com, arcxp-sandbox.tirebusiness.com, arcxp-sandbox.utech-polyurethane.com, arcxp-stage.adage.com, arcxp-stage.automobilwoche.de, arcxp-stage.autonews.com, arcxp-stage.chicagobusiness.com, arcxp-stage.crainscleveland.com, arcxp-stage.crainsdetroit.com, arcxp-stage.crainsgrandrapids.com, arcxp-stage.crainsnewyork.com, arcxp-stage.genomeweb.com, arcxp-stage.hartenergy.com, arcxp-stage.modernhealthcare.com, arcxp-stage.pionline.com, arcxp-stage.plasticsnews.com, arcxp-stage.rubbernews.com, arcxp-stage.tirebusiness.com, arcxp-stage.utech-polyurethane.com, crain-adage-dev.web.arc-cdn.net, crain-adage-prod.web.arc-cdn.net, crain-adage-sandbox.web.arc-cdn.net, crain-adage-staging.web.arc-cdn.net, crain-automobilwoche-sandbox.web.arc-cdn.net, crain-automobilwoche-staging.web.arc-cdn.net, crain-automotivenews-dev.web.arc-cdn.net, crain-automotivenews-prod.web.arc-cdn.net, crain-automotivenews-sandbox.web.arc-cdn.net, crain-automotivenews-staging.web.arc-cdn.net, crain-crain-dev.web.arc-cdn.net, crain-crain-prod.web.arc-cdn.net, crain-crain-sandbox.web.arc-cdn.net, crain-crain-staging.web.arc-cdn.net, crain.web.arc-cdn.net, www.adage.com, www.automobilwoche.de, www.autonews.com, www.chicagobusiness.com, www.crainscleveland.com, www.crainsdetroit.com, www.crainsgrandrapids.com, www.crainsnewyork.com, www.genomeweb.com, www.hartenergy.com, www.modernhealthcare.com, www.pionline.com, www.plasticsnews.com, www.rubbernews.com, www.sustainableplastics.com, www.tirebusiness.com, www.utech-polyurethane.com
Info::
Certificate is issued by a trusted CA
Got: CN=R13,O=Let's Encrypt,C=US

HTTP/2 provides multiplexing and header compression for better performance.

Why this matters

HTTP/1.1 forces the browser to make sequential requests, multiplying latency on every page.

Learn more

HTTP/2 (and HTTP/3) multiplex many requests over a single connection, eliminating head-of-line blocking. HTTP/1.1 forces the browser to either queue requests or open many parallel connections — both worse. Most modern web servers support HTTP/2 with one config line.

Source: MDN Web Docs

Connection
Protocol
TLS 1.3
Cipher Suite
TLS_AES_256_GCM_SHA384
HTTP Version
HTTP/1.1

Certificate Chain

Leaf Certificate
Subject CN=crain.web.arc-cdn.netIssuer CN=R13,O=Let's Encrypt,C=USValid 2026-03-06T13:15:11Z → 2026-06-04T13:15:10ZExpires in 43 days SANs adage.com, arcxp-dev.adage.com, arcxp-dev.automobilwoche.de, arcxp-dev.autonews.com, arcxp-dev.chicagobusiness.com, arcxp-dev.crainscleveland.com, arcxp-dev.crainsdetroit.com, arcxp-dev.crainsgrandrapids.com, arcxp-dev.crainsnewyork.com, arcxp-dev.genomeweb.com, arcxp-dev.hartenergy.com, arcxp-dev.modernhealthcare.com, arcxp-dev.pionline.com, arcxp-dev.plasticsnews.com, arcxp-dev.rubbernews.com, arcxp-dev.tirebusiness.com, arcxp-dev.utech-polyurethane.com, arcxp-prod.automobilwoche.de, arcxp-prod.chicagobusiness.com, arcxp-prod.crainscleveland.com, arcxp-prod.crainsdetroit.com, arcxp-prod.crainsgrandrapids.com, arcxp-prod.crainsnewyork.com, arcxp-prod.genomeweb.com, arcxp-prod.hartenergy.com, arcxp-prod.modernhealthcare.com, arcxp-prod.pionline.com, arcxp-prod.plasticsnews.com, arcxp-prod.rubbernews.com, arcxp-prod.tirebusiness.com, arcxp-prod.utech-polyurethane.com, arcxp-sandbox.adage.com, arcxp-sandbox.automobilwoche.de, arcxp-sandbox.autonews.com, arcxp-sandbox.chicagobusiness.com, arcxp-sandbox.crainscleveland.com, arcxp-sandbox.crainsdetroit.com, arcxp-sandbox.crainsgrandrapids.com, arcxp-sandbox.crainsnewyork.com, arcxp-sandbox.genomeweb.com, arcxp-sandbox.hartenergy.com, arcxp-sandbox.modernhealthcare.com, arcxp-sandbox.pionline.com, arcxp-sandbox.plasticsnews.com, arcxp-sandbox.rubbernews.com, arcxp-sandbox.tirebusiness.com, arcxp-sandbox.utech-polyurethane.com, arcxp-stage.adage.com, arcxp-stage.automobilwoche.de, arcxp-stage.autonews.com, arcxp-stage.chicagobusiness.com, arcxp-stage.crainscleveland.com, arcxp-stage.crainsdetroit.com, arcxp-stage.crainsgrandrapids.com, arcxp-stage.crainsnewyork.com, arcxp-stage.genomeweb.com, arcxp-stage.hartenergy.com, arcxp-stage.modernhealthcare.com, arcxp-stage.pionline.com, arcxp-stage.plasticsnews.com, arcxp-stage.rubbernews.com, arcxp-stage.tirebusiness.com, arcxp-stage.utech-polyurethane.com, crain-adage-dev.web.arc-cdn.net, crain-adage-prod.web.arc-cdn.net, crain-adage-sandbox.web.arc-cdn.net, crain-adage-staging.web.arc-cdn.net, crain-automobilwoche-sandbox.web.arc-cdn.net, crain-automobilwoche-staging.web.arc-cdn.net, crain-automotivenews-dev.web.arc-cdn.net, crain-automotivenews-prod.web.arc-cdn.net, crain-automotivenews-sandbox.web.arc-cdn.net, crain-automotivenews-staging.web.arc-cdn.net, crain-crain-dev.web.arc-cdn.net, crain-crain-prod.web.arc-cdn.net, crain-crain-sandbox.web.arc-cdn.net, crain-crain-staging.web.arc-cdn.net, crain.web.arc-cdn.net, www.adage.com, www.automobilwoche.de, www.autonews.com, www.chicagobusiness.com, www.crainscleveland.com, www.crainsdetroit.com, www.crainsgrandrapids.com, www.crainsnewyork.com, www.genomeweb.com, www.hartenergy.com, www.modernhealthcare.com, www.pionline.com, www.plasticsnews.com, www.rubbernews.com, www.sustainableplastics.com, www.tirebusiness.com, www.utech-polyurethane.comSignature SHA256-RSASerial 584ad38cf9133d63ac4a18b67c9da29ecef
Intermediate (CA Certificate)
Subject CN=R13,O=Let's Encrypt,C=USIssuer CN=ISRG Root X1,O=Internet Security Research Group,C=USValid 2024-03-13T00:00:00Z → 2027-03-12T23:59:59ZExpires in 325 days Signature SHA256-RSASerial 5a00f212d8d4b480f3924157ea298305
A+
Cookie Security
No cookies set — no cookie security risks
PASS
No cookies set — no cookie security risks
Info::
No cookies set — no cookie security risks

No cookies detected — no cookie security risks to report.

A+
JS Library Vulnerabilities
No known vulnerabilities
PASS
No known vulnerabilities
Info::
No known JavaScript library vulnerabilities detected

No known JavaScript library vulnerabilities detected.

A+
Information Leakage
No exposures
PASS
No exposures
Info::
No security.txt found
Consider adding a security.txt at /.well-known/security.txt.
Info::
No sensitive files exposed

No sensitive files exposed — all paths returned 404.

PathStatusCategoryRisk
/.git/HEAD Not foundVersion Control
/.git/config Not foundVersion Control
/.svn/entries Not foundVersion Control
/.env Not foundConfiguration
/.env.local Not foundConfiguration
/.env.production Not foundConfiguration
/wp-config.php Not foundConfiguration
/.htaccess Not foundConfiguration
/phpinfo.php Not foundDebug
/server-status Not foundDebug
/server-info Not foundDebug
/.well-known/security.txt Not foundSecurity Policy
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback