Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

kubectl-proxy changes http-header-keys to capitalized #1673

Open
faxjiangyi opened this issue Oct 18, 2024 · 3 comments
Open

kubectl-proxy changes http-header-keys to capitalized #1673

faxjiangyi opened this issue Oct 18, 2024 · 3 comments
Labels
kind/bug Categorizes issue or PR as related to a bug. needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one.

Comments

@faxjiangyi
Copy link

faxjiangyi commented Oct 18, 2024

What happened:
When I am using kubectl proxy, the past proxy http request header keys are converted to initial capital.
image

What you expected to happen:
HTTP/1.1
According to RFC 7230, section 3.2:

Each header field consists of a case-insensitive field name followed by a colon (":"), optional leading whitespace, the field value, and optional trailing whitespace.

HTTP/2.0
Quoting RFC 7540, section 8.1.2:

Just as in HTTP/1.x, header field names are strings of ASCII
characters that are compared in a case-insensitive fashion.

How to reproduce it (as minimally and precisely as possible):
Use kubectl proxy and log all headers in svc-pods

Anything else we need to know?:
Happened both in aks and local k3s.
I'm not sure if this is a bug or intended?

Environment:
aks

Client Version: v1.29.4
Kustomize Version: v5.0.4-0.20230601165947-6ce0bf390ce3
Server Version: v1.28.9

local

Client Version: v1.29.4
Kustomize Version: v5.0.4-0.20230601165947-6ce0bf390ce3
Server Version: v1.29.3+orb1
@faxjiangyi faxjiangyi added the kind/bug Categorizes issue or PR as related to a bug. label Oct 18, 2024
@k8s-ci-robot k8s-ci-robot added the needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one. label Oct 18, 2024
@k8s-ci-robot
Copy link
Contributor

This issue is currently awaiting triage.

SIG CLI takes a lead on issue triage for this repo, but any Kubernetes member can accept issues by applying the triage/accepted label.

The triage/accepted label can be added by org members by writing /triage accepted in a comment.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository.

@ardaguclu
Copy link
Member

Since the headers are case-insensitive, does it matter that these headers are capitalized or not?. Wouldn't eventually all be considered as same?.

@faxjiangyi
Copy link
Author

faxjiangyi commented Dec 10, 2024

Since the headers are case-insensitive, does it matter that these headers are capitalized or not?. Wouldn't eventually all be considered as same?.

Thanks for your reply.
I don't think it's a serious problem, but I would like to understand why kubectl proxy capitalizes headers.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind/bug Categorizes issue or PR as related to a bug. needs-triage Indicates an issue or PR lacks a `triage/foo` label and requires one.
Projects
None yet
Development

No branches or pull requests

3 participants