CVE-2026-34786
MEDIUM5.3EPSS 0.04%Rack:: Static header_rules bypass via URL-encoded paths
描述
## Summary `Rack::Static#applicable_rules` evaluates several `header_rules` types against the raw URL-encoded `PATH_INFO`, while the underlying file-serving path is decoded before the file is served. As a result, a request for a URL-encoded variant of a static path can serve the same file without the headers that `header_rules` were intended to apply. In deployments that rely on `Rack::Static` to attach security-relevant response headers to static content, this can allow an attacker to bypass those headers by requesting an encoded form of the path. ## Details `Rack::Static#applicable_rules` matches rule types such as `:fonts`, `Array`, and `Regexp` directly against the incoming `PATH_INFO`. For example: ```ruby when :fonts /\.(?:ttf|otf|eot|woff2|woff|svg)\z/.match?(path) when Array /\.(#{rule.join('|')})\z/.match?(path) when Regexp rule.match?(path) ``` These checks operate on the raw request path. If the request contains encoded characters such as `%2E` in place of `.`, the rule may fail to match even though the file path is later decoded and served successfully by the static file server. For example, both of the following requests may resolve to the same file on disk: ```text /fonts/test.woff /fonts/test%2Ewoff ``` but only the unencoded form may receive the headers configured through `header_rules`. This creates a canonicalization mismatch between the path used for header policy decisions and the path ultimately used for file serving. ## Impact Applications that rely on `Rack::Static` `header_rules` to apply security-relevant headers to static files may be affected. In affected deployments, an attacker can request an encoded variant of a static file path and receive the same file without the intended headers. Depending on how `header_rules` are used, this may bypass protections such as clickjacking defenses, content restrictions, or other response policies applied to static content. The practical impact depends on the configured rules and the types of files being served. If `header_rules` are only used for non-security purposes such as caching, the issue may have limited security significance. ## Mitigation * Update to a patched version of Rack that applies `header_rules` to a decoded path consistently with static file resolution. * Do not rely solely on `Rack::Static` `header_rules` for security-critical headers where encoded path variants may reach the application. * Prefer setting security headers at the reverse proxy or web server layer so they apply consistently to both encoded and unencoded path forms. * Normalize or reject encoded path variants for static content at the edge, where feasible.
受影響套件(2)
- Debian/ruby-rackfrom 0
- RubyGems/rackfrom 0, < 2.2.23
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM5.3 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |
參考連結(5)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-34786
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-34786
- PATCHhttps://github.com/rack/rack
- WEBhttps://github.com/rack/rack/security/advisories/GHSA-q4qf-9j86-f5mh
- WEBhttps://github.com/rubysec/ruby-advisory-db/blob/master/gems/rack/CVE-2026-34786.yml