Check Detail
zelfy.com · HEADER
Passed
Grade C
73.1%
Result Detail
HEADERAlerts
- Content-Security-Policy: Content-Security-Policy missing
- Expect-CT: Expect-CT missing
- X-Permitted-Cross-Domain-Policies: Header missing
- Access-Control-Allow-Origin: Access-Control-Allow-Origin missing
- Server: Sensitive header exposed
Normalized headers
date | Tue, 14 Oct 2025 23:57:05 GMT |
---|---|
content-type | text/html; charset=UTF-8 |
content-length | 7224 |
accept-ch | Sec-CH-UA-Bitness, Sec-CH-UA-Arch, Sec-CH-UA-Full-Version, Sec-CH-UA-Mobile, Sec-CH-UA-Model, Sec-CH-UA-Platform-Version, Sec-CH-UA-Full-Version-List, Sec-CH-UA-Platform, Sec-CH-UA, UA-Bitness, UA-Arch, UA-Full-Version, UA-Mobile, UA-Model, UA-Platform-Version, UA-Platform, UA |
cf-mitigated | challenge |
critical-ch | Sec-CH-UA-Bitness, Sec-CH-UA-Arch, Sec-CH-UA-Full-Version, Sec-CH-UA-Mobile, Sec-CH-UA-Model, Sec-CH-UA-Platform-Version, Sec-CH-UA-Full-Version-List, Sec-CH-UA-Platform, Sec-CH-UA, UA-Bitness, UA-Arch, UA-Full-Version, UA-Mobile, UA-Model, UA-Platform-Version, UA-Platform, UA |
cross-origin-embedder-policy | require-corp |
cross-origin-opener-policy | same-origin |
cross-origin-resource-policy | same-origin |
origin-agent-cluster | ?1 |
permissions-policy | accelerometer=(),autoplay=(),browsing-topics=(),camera=(),clipboard-read=(),clipboard-write=(),geolocation=(),gyroscope=(),hid=(),interest-cohort=(),magnetometer=(),microphone=(),payment=(),publickey-credentials-get=(),screen-wake-lock=(),serial=(),sync-xhr=(),usb=() |
referrer-policy | same-origin |
server-timing | chlray;desc="98eb045c7c7fdc6c" |
x-content-type-options | nosniff |
x-frame-options | SAMEORIGIN |
cache-control | private, max-age=0, no-store, no-cache, must-revalidate, post-check=0, pre-check=0 |
expires | Thu, 01 Jan 1970 00:00:01 GMT |
strict-transport-security | max-age=31536000; includeSubDomains; preload |
speculation-rules | "/cdn-cgi/speculation" |
server | cloudflare |
cf-ray | 98eb045c7c7fdc6c-FRA |
alt-svc | h3=":443"; ma=86400 |
Transport
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Strict-Transport-Security | ✅ OK | max-age=31536000; includeSubDomains; preload | max-age>=15768000; includeSubDomains; preload | HSTS policy robust | Critical | Strict-Transport-Security: max-age=63072000; includeSubDomains; preload |
Expect-CT | ⚠️ Attention | enforce; max-age>=86400 | Expect-CT missing | Medium | Expect-CT: enforce, max-age=86400, report-uri="https://report.example.com" |
Content Security
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Content-Security-Policy | ⚠️ Attention | default-src 'self'; frame-ancestors 'none' | Content-Security-Policy missing | Critical | Content-Security-Policy: default-src 'self'; frame-ancestors 'none' |
MIME
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
X-Content-Type-Options | ✅ OK | nosniff | nosniff | Value matches recommendation | High | X-Content-Type-Options: nosniff |
Framing
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
X-Frame-Options | ✅ OK | SAMEORIGIN | DENY or SAMEORIGIN | Value accepted | High | X-Frame-Options: DENY |
Privacy
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Referrer-Policy | ✅ OK | same-origin | strict-origin-when-cross-origin / same-origin | strict-origin-when-cross-origin | Medium | Referrer-Policy: strict-origin-when-cross-origin |
Browser Features
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Permissions-Policy | ✅ OK | accelerometer=(),autoplay=(),browsing-topics=(),camera=(),clipboard-read=(),clipboard-write=(),geolocation=(),gyroscope=(),hid=(),interest-cohort=(),magnetometer=(),microphone=(),payment=(),publickey-credentials-get=(),screen-wake-lock=(),serial=(),sync-xhr=(),usb=() | camera=(); geolocation=(); microphone=() | camera=(); geolocation=(); microphone=() | Medium | Permissions-Policy: camera=(), geolocation=(), microphone=() |
Cross-Origin
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Cross-Origin-Opener-Policy | ✅ OK | same-origin | same-origin | Value matches recommendation | High | Cross-Origin-Opener-Policy: same-origin |
Cross-Origin-Embedder-Policy | ✅ OK | require-corp | require-corp | Value matches recommendation | High | Cross-Origin-Embedder-Policy: require-corp |
Cross-Origin-Resource-Policy | ✅ OK | same-origin | same-origin | Value matches recommendation | Medium | Cross-Origin-Resource-Policy: same-origin |
Origin-Agent-Cluster | ✅ OK | ?1 | ?1 | Value matches recommendation | Low | Origin-Agent-Cluster: ?1 |
Caching
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Cache-Control | ✅ OK | private, max-age=0, no-store, no-cache, must-revalidate, post-check=0, pre-check=0 | no-store, private, max-age=0 | no-store, private, max-age=0 | High | Cache-Control: no-store, private, max-age=0 |
Legacy
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
X-Permitted-Cross-Domain-Policies | ⚠️ Attention | none | Header missing | Low | X-Permitted-Cross-Domain-Policies: none |
CORS
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Access-Control-Allow-Origin | ⚠️ Attention | Scoped origin (no wildcard) | Access-Control-Allow-Origin missing | Medium | Access-Control-Allow-Origin: https://app.example.com |
Information Disclosure
Check name | Status | Actual | Expected | Detail | Severity | Recommendation |
---|---|---|---|---|---|---|
Server | ⚠️ Attention | cloudflare | Header removed or generic | Sensitive header exposed | High | Remove Server header or set to a generic token |
X-Powered-By | ✅ OK | Header removed | Header not exposed | High | Remove X-Powered-By header | |
X-AspNet-Version | ✅ OK | Header removed | Header not exposed | Medium | Remove framework version headers |
Raw headers
HTTP/2 403 date: Tue, 14 Oct 2025 23:57:05 GMT content-type: text/html; charset=UTF-8 content-length: 7224 accept-ch: Sec-CH-UA-Bitness, Sec-CH-UA-Arch, Sec-CH-UA-Full-Version, Sec-CH-UA-Mobile, Sec-CH-UA-Model, Sec-CH-UA-Platform-Version, Sec-CH-UA-Full-Version-List, Sec-CH-UA-Platform, Sec-CH-UA, UA-Bitness, UA-Arch, UA-Full-Version, UA-Mobile, UA-Model, UA-Platform-Version, UA-Platform, UA cf-mitigated: challenge critical-ch: Sec-CH-UA-Bitness, Sec-CH-UA-Arch, Sec-CH-UA-Full-Version, Sec-CH-UA-Mobile, Sec-CH-UA-Model, Sec-CH-UA-Platform-Version, Sec-CH-UA-Full-Version-List, Sec-CH-UA-Platform, Sec-CH-UA, UA-Bitness, UA-Arch, UA-Full-Version, UA-Mobile, UA-Model, UA-Platform-Version, UA-Platform, UA cross-origin-embedder-policy: require-corp cross-origin-opener-policy: same-origin cross-origin-resource-policy: same-origin origin-agent-cluster: ?1 permissions-policy: accelerometer=(),autoplay=(),browsing-topics=(),camera=(),clipboard-read=(),clipboard-write=(),geolocation=(),gyroscope=(),hid=(),interest-cohort=(),magnetometer=(),microphone=(),payment=(),publickey-credentials-get=(),screen-wake-lock=(),serial=(),sync-xhr=(),usb=() referrer-policy: same-origin server-timing: chlray;desc="98eb045c7c7fdc6c" x-content-type-options: nosniff x-frame-options: SAMEORIGIN cache-control: private, max-age=0, no-store, no-cache, must-revalidate, post-check=0, pre-check=0 expires: Thu, 01 Jan 1970 00:00:01 GMT strict-transport-security: max-age=31536000; includeSubDomains; preload speculation-rules: "/cdn-cgi/speculation" server: cloudflare cf-ray: 98eb045c7c7fdc6c-FRA alt-svc: h3=":443"; ma=86400