Risk Level | Number of Alerts |
---|---|
High
|
0
|
Medium
|
2
|
Low
|
7
|
Informational
|
10
|
False Positives:
|
0
|
For each step: result (Pass/Fail) - risk (of highest alert(s) for the step, if any).
Name | Risk Level | Number of Instances |
---|---|---|
Content Security Policy (CSP) Header Not Set | Medium | 2 |
Missing Anti-clickjacking Header | Medium | 2 |
Cookie No HttpOnly Flag | Low | 2 |
Cookie Without Secure Flag | Low | 2 |
Cookie without SameSite Attribute | Low | 4 |
Insufficient Site Isolation Against Spectre Vulnerability | Low | 6 |
Permissions Policy Header Not Set | Low | 2 |
Strict-Transport-Security Header Not Set | Low | 4 |
Timestamp Disclosure - Unix | Low | 1 |
Base64 Disclosure | Informational | 1 |
Modern Web Application | Informational | 2 |
Non-Storable Content | Informational | 4 |
Re-examine Cache-control Directives | Informational | 2 |
Sec-Fetch-Dest Header is Missing | Informational | 2 |
Sec-Fetch-Mode Header is Missing | Informational | 2 |
Sec-Fetch-Site Header is Missing | Informational | 2 |
Sec-Fetch-User Header is Missing | Informational | 2 |
Session Management Response Identified | Informational | 1 |
Storable and Cacheable Content | Informational | 2 |
Medium |
Content Security Policy (CSP) Header Not Set |
---|---|
Description |
Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header.
|
Reference |
https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy
https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html https://www.w3.org/TR/CSP/ https://w3c.github.io/webappsec-csp/ https://web.dev/articles/csp https://caniuse.com/#feat=contentsecuritypolicy https://content-security-policy.com/ |
CWE Id | 693 |
WASC Id | 15 |
Plugin Id | 10038 |
Medium |
Missing Anti-clickjacking Header |
---|---|
Description |
The response does not protect against 'ClickJacking' attacks. It should include either Content-Security-Policy with 'frame-ancestors' directive or X-Frame-Options.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | x-frame-options |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | x-frame-options |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Modern Web browsers support the Content-Security-Policy and X-Frame-Options HTTP headers. Ensure one of them is set on all web pages returned by your site/app.
If you expect the page to be framed only by pages on your server (e.g. it's part of a FRAMESET) then you'll want to use SAMEORIGIN, otherwise if you never expect the page to be framed, you should use DENY. Alternatively consider implementing Content Security Policy's "frame-ancestors" directive.
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Frame-Options |
CWE Id | 1021 |
WASC Id | 15 |
Plugin Id | 10020 |
Low |
Cookie No HttpOnly Flag |
---|---|
Description |
A cookie has been set without the HttpOnly flag, which means that the cookie can be accessed by JavaScript. If a malicious script can be run on this page then the cookie will be accessible and can be transmitted to another site. If this is a session cookie then session hijacking may be possible.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | TS016fc3b0 |
Attack | |
Evidence | Set-Cookie: TS016fc3b0 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | TS011b8e23 |
Attack | |
Evidence | Set-Cookie: TS011b8e23 |
Other Info | |
Instances | 2 |
Solution |
Ensure that the HttpOnly flag is set for all cookies.
|
Reference | https://owasp.org/www-community/HttpOnly |
CWE Id | 1004 |
WASC Id | 13 |
Plugin Id | 10010 |
Low |
Cookie Without Secure Flag |
---|---|
Description |
A cookie has been set without the secure flag, which means that the cookie can be accessed via unencrypted connections.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | TS016fc3b0 |
Attack | |
Evidence | Set-Cookie: TS016fc3b0 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | TS011b8e23 |
Attack | |
Evidence | Set-Cookie: TS011b8e23 |
Other Info | |
Instances | 2 |
Solution |
Whenever a cookie contains sensitive information or is a session token, then it should always be passed using an encrypted channel. Ensure that the secure flag is set for cookies containing such sensitive information.
|
Reference | https://owasp.org/www-project-web-security-testing-guide/v41/4-Web_Application_Security_Testing/06-Session_Management_Testing/02-Testing_for_Cookies_Attributes.html |
CWE Id | 614 |
WASC Id | 13 |
Plugin Id | 10011 |
Low |
Cookie without SameSite Attribute |
---|---|
Description |
A cookie has been set without the SameSite attribute, which means that the cookie can be sent as a result of a 'cross-site' request. The SameSite attribute is an effective counter measure to cross-site request forgery, cross-site script inclusion, and timing attacks.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | BIGipServerPOOL_Z5_PROD_MOP_HTTP |
Attack | |
Evidence | Set-Cookie: BIGipServerPOOL_Z5_PROD_MOP_HTTP |
Other Info | |
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | TS016fc3b0 |
Attack | |
Evidence | Set-Cookie: TS016fc3b0 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | BIGipServerPOOL_TAS_SDDC_HTTP |
Attack | |
Evidence | Set-Cookie: BIGipServerPOOL_TAS_SDDC_HTTP |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | TS011b8e23 |
Attack | |
Evidence | Set-Cookie: TS011b8e23 |
Other Info | |
Instances | 4 |
Solution |
Ensure that the SameSite attribute is set to either 'lax' or ideally 'strict' for all cookies.
|
Reference | https://tools.ietf.org/html/draft-ietf-httpbis-cookie-same-site |
CWE Id | 1275 |
WASC Id | 13 |
Plugin Id | 10054 |
Low |
Insufficient Site Isolation Against Spectre Vulnerability |
---|---|
Description |
Cross-Origin-Resource-Policy header is an opt-in header designed to counter side-channels attacks like Spectre. Resource should be specifically set as shareable amongst different origins.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Cross-Origin-Resource-Policy |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | Cross-Origin-Resource-Policy |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Cross-Origin-Embedder-Policy |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | Cross-Origin-Embedder-Policy |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Cross-Origin-Opener-Policy |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | Cross-Origin-Opener-Policy |
Attack | |
Evidence | |
Other Info | |
Instances | 6 |
Solution |
Ensure that the application/web server sets the Cross-Origin-Resource-Policy header appropriately, and that it sets the Cross-Origin-Resource-Policy header to 'same-origin' for all web pages.
'same-site' is considered as less secured and should be avoided.
If resources must be shared, set the header to 'cross-origin'.
If possible, ensure that the end user uses a standards-compliant and modern web browser that supports the Cross-Origin-Resource-Policy header (https://caniuse.com/mdn-http_headers_cross-origin-resource-policy).
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Cross-Origin_Resource_Policy |
CWE Id | 693 |
WASC Id | 14 |
Plugin Id | 90004 |
Low |
Permissions Policy Header Not Set |
---|---|
Description |
Permissions Policy Header is an added layer of security that helps to restrict from unauthorized access or usage of browser/client features by web resources. This policy ensures the user privacy by limiting or specifying the features of the browsers can be used by the web resources. Permissions Policy provides a set of standard HTTP headers that allow website owners to limit which features of browsers can be used by the page such as camera, microphone, location, full screen etc.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that your web server, application server, load balancer, etc. is configured to set the Permissions-Policy header.
|
Reference |
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Permissions-Policy
https://developer.chrome.com/blog/feature-policy/ https://scotthelme.co.uk/a-new-security-header-feature-policy/ https://w3c.github.io/webappsec-feature-policy/ https://www.smashingmagazine.com/2018/12/feature-policy/ |
CWE Id | 693 |
WASC Id | 15 |
Plugin Id | 10063 |
Low |
Strict-Transport-Security Header Not Set |
---|---|
Description |
HTTP Strict Transport Security (HSTS) is a web security policy mechanism whereby a web server declares that complying user agents (such as a web browser) are to interact with it using only secure HTTPS connections (i.e. HTTP layered over TLS/SSL). HSTS is an IETF standards track protocol and is specified in RFC 6797.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/sitemap.xml |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | |
Instances | 4 |
Solution |
Ensure that your web server, application server, load balancer, etc. is configured to enforce Strict-Transport-Security.
|
Reference |
https://cheatsheetseries.owasp.org/cheatsheets/HTTP_Strict_Transport_Security_Cheat_Sheet.html
https://owasp.org/www-community/Security_Headers https://en.wikipedia.org/wiki/HTTP_Strict_Transport_Security https://caniuse.com/stricttransportsecurity https://datatracker.ietf.org/doc/html/rfc6797 |
CWE Id | 319 |
WASC Id | 15 |
Plugin Id | 10035 |
Low |
Timestamp Disclosure - Unix |
---|---|
Description |
A timestamp was disclosed by the application/web server. - Unix
|
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | Set-Cookie |
Attack | |
Evidence | 1821575946 |
Other Info | 1821575946, which evaluates to: 2027-09-22 01:19:06. |
Instances | 1 |
Solution |
Manually confirm that the timestamp data is not sensitive, and that the data cannot be aggregated to disclose exploitable patterns.
|
Reference | https://cwe.mitre.org/data/definitions/200.html |
CWE Id | 497 |
WASC Id | 13 |
Plugin Id | 10096 |
Informational |
Base64 Disclosure |
---|---|
Description |
Base64 encoded data was disclosed by the application/web server. Note: in the interests of performance not all base64 strings in the response were analyzed individually, the entire response should be looked at by the analyst/security team/developer(s).
|
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | /ruxitagentjs_ICA7NVfgqrux_10307250124095659 |
Other Info | ����֠z{c���U~ ����};5ۍ=�} |
Instances | 1 |
Solution |
Manually confirm that the Base64 data does not leak sensitive information, and that the data cannot be aggregated/used to exploit other vulnerabilities.
|
Reference | https://projects.webappsec.org/w/page/13246936/Information%20Leakage |
CWE Id | 319 |
WASC Id | 13 |
Plugin Id | 10094 |
Informational |
Modern Web Application |
---|---|
Description |
The application appears to be a modern web application. If you need to explore it automatically then the Ajax Spider may well be more effective than the standard one.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | <script src="runtime.d6a6630ec5ba3aa9.js" type="module"></script> |
Other Info | No links have been found while there are scripts, which is an indication that this is a modern web application. |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | <script type="text/javascript" src="./ruxitagentjs_ICA7NVfgqrux_10307250124095659.js" data-dtconfig="rid=RID_-360055349|rpid=365985016|domain=pole-emploi.intra|reportUrl=https://bf95196pdg.bf.dynatrace.com/bf|app=9a5c863c7cc45039|coo=1|cors=1|featureHash=ICA7NVfgqrux|rdnt=1|uxrgce=1|cuc=feikm4qw|chw=api^bs.francetravail^bs.fr|mel=100000|expw=1|dpvc=1|lastModification=1744737887288|tp=500,50,0|apn=webpackChunkpn322_portailsimulateurs|agentUri=./ruxitagentjs_ICA7NVfgqrux_10307250124095659.js"></script> |
Other Info | No links have been found while there are scripts, which is an indication that this is a modern web application. |
Instances | 2 |
Solution |
This is an informational alert and so no changes are required.
|
Reference | |
CWE Id | |
WASC Id | |
Plugin Id | 10109 |
Informational |
Non-Storable Content |
---|---|
Description |
The response contents are not storable by caching components such as proxy servers. If the response does not contain sensitive, personal or user-specific information, it may benefit from being stored and cached, to improve performance.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | 308 |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | |
Attack | |
Evidence | 308 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | 308 |
Other Info | |
URL | https://candidat.pole-emploi.fr/sitemap.xml |
Method | GET |
Parameter | |
Attack | |
Evidence | 308 |
Other Info | |
Instances | 4 |
Solution |
The content may be marked as storable by ensuring that the following conditions are satisfied:
The request method must be understood by the cache and defined as being cacheable ("GET", "HEAD", and "POST" are currently defined as cacheable)
The response status code must be understood by the cache (one of the 1XX, 2XX, 3XX, 4XX, or 5XX response classes are generally understood)
The "no-store" cache directive must not appear in the request or response header fields
For caching by "shared" caches such as "proxy" caches, the "private" response directive must not appear in the response
For caching by "shared" caches such as "proxy" caches, the "Authorization" header field must not appear in the request, unless the response explicitly allows it (using one of the "must-revalidate", "public", or "s-maxage" Cache-Control response directives)
In addition to the conditions above, at least one of the following conditions must also be satisfied by the response:
It must contain an "Expires" header field
It must contain a "max-age" response directive
For "shared" caches such as "proxy" caches, it must contain a "s-maxage" response directive
It must contain a "Cache Control Extension" that allows it to be cached
It must have a status code that is defined as cacheable by default (200, 203, 204, 206, 300, 301, 404, 405, 410, 414, 501).
|
Reference |
https://datatracker.ietf.org/doc/html/rfc7234
https://datatracker.ietf.org/doc/html/rfc7231 https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html |
CWE Id | 524 |
WASC Id | 13 |
Plugin Id | 10049 |
Informational |
Re-examine Cache-control Directives |
---|---|
Description |
The cache-control header has not been set properly or is missing, allowing the browser and proxies to cache content. For static assets like css, js, or image files this might be intended, however, the resources should be reviewed to ensure that no sensitive content will be cached.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | cache-control |
Attack | |
Evidence | max-age=120 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | cache-control |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
For secure content, ensure the cache-control HTTP header is set with "no-cache, no-store, must-revalidate". If an asset should be cached consider setting the directives "public, max-age, immutable".
|
Reference |
https://cheatsheetseries.owasp.org/cheatsheets/Session_Management_Cheat_Sheet.html#web-content-caching
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control https://grayduck.mn/2021/09/13/cache-control-recommendations/ |
CWE Id | 525 |
WASC Id | 13 |
Plugin Id | 10015 |
Informational |
Sec-Fetch-Dest Header is Missing |
---|---|
Description |
Specifies how and where the data would be used. For instance, if the value is audio, then the requested resource must be audio data and not any other type of resource.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Sec-Fetch-Dest |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | Sec-Fetch-Dest |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that Sec-Fetch-Dest header is included in request headers.
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Dest |
CWE Id | 352 |
WASC Id | 9 |
Plugin Id | 90005 |
Informational |
Sec-Fetch-Mode Header is Missing |
---|---|
Description |
Allows to differentiate between requests for navigating between HTML pages and requests for loading resources like images, audio etc.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Sec-Fetch-Mode |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | Sec-Fetch-Mode |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that Sec-Fetch-Mode header is included in request headers.
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Mode |
CWE Id | 352 |
WASC Id | 9 |
Plugin Id | 90005 |
Informational |
Sec-Fetch-Site Header is Missing |
---|---|
Description |
Specifies the relationship between request initiator's origin and target's origin.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Sec-Fetch-Site |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | Sec-Fetch-Site |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that Sec-Fetch-Site header is included in request headers.
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Site |
CWE Id | 352 |
WASC Id | 9 |
Plugin Id | 90005 |
Informational |
Sec-Fetch-User Header is Missing |
---|---|
Description |
Specifies if a navigation request was initiated by a user.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | Sec-Fetch-User |
Attack | |
Evidence | |
Other Info | |
URL | https://candidat.pole-emploi.fr/robots.txt |
Method | GET |
Parameter | Sec-Fetch-User |
Attack | |
Evidence | |
Other Info | |
Instances | 2 |
Solution |
Ensure that Sec-Fetch-User header is included in user initiated requests.
|
Reference | https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-User |
CWE Id | 352 |
WASC Id | 9 |
Plugin Id | 90005 |
Informational |
Session Management Response Identified |
---|---|
Description |
The given response has been identified as containing a session management token. The 'Other Info' field contains a set of header tokens that can be used in the Header Based Session Management Method. If the request is in a context which has a Session Management Method set to "Auto-Detect" then this rule will change the session management to use the tokens identified.
|
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | BIGipServerPOOL_TAS_SDDC_HTTP |
Attack | |
Evidence | 1821575946.20480.0000 |
Other Info | cookie:BIGipServerPOOL_TAS_SDDC_HTTP cookie:TS011b8e23 |
Instances | 1 |
Solution |
This is an informational alert rather than a vulnerability and so there is nothing to fix.
|
Reference | https://www.zaproxy.org/docs/desktop/addons/authentication-helper/session-mgmt-id |
CWE Id | |
WASC Id | |
Plugin Id | 10112 |
Informational |
Storable and Cacheable Content |
---|---|
Description |
The response contents are storable by caching components such as proxy servers, and may be retrieved directly from the cache, rather than from the origin server by the caching servers, in response to similar requests from other users. If the response data is sensitive, personal or user-specific, this may result in sensitive information being leaked. In some cases, this may even result in a user gaining complete control of the session of another user, depending on the configuration of the caching components in use in their environment. This is primarily an issue where "shared" caching servers such as "proxy" caches are configured on the local network. This configuration is typically found in corporate or educational environments, for instance.
|
URL | https://candidat.pole-emploi.fr/ |
Method | GET |
Parameter | |
Attack | |
Evidence | max-age=120 |
Other Info | |
URL | https://candidat.pole-emploi.fr/simucalculreprise |
Method | GET |
Parameter | |
Attack | |
Evidence | |
Other Info | In the absence of an explicitly specified caching lifetime directive in the response, a liberal lifetime heuristic of 1 year was assumed. This is permitted by rfc7234. |
Instances | 2 |
Solution |
Validate that the response does not contain sensitive, personal or user-specific information. If it does, consider the use of the following HTTP response headers, to limit, or prevent the content being stored and retrieved from the cache by another user:
Cache-Control: no-cache, no-store, must-revalidate, private
Pragma: no-cache
Expires: 0
This configuration directs both HTTP 1.0 and HTTP 1.1 compliant caching servers to not store the response, and to not retrieve the response (without validation) from the cache, in response to a similar request.
|
Reference |
https://datatracker.ietf.org/doc/html/rfc7234
https://datatracker.ietf.org/doc/html/rfc7231 https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html |
CWE Id | 524 |
WASC Id | 13 |
Plugin Id | 10049 |