HTTP
CORS
- 默认允许头
- Cache-Control
- Content-Language
- Content-Type
- Expires
- Last-Modified
- Pragma
- access-control-expose-headers - 控制暴露头
# 请求
Access-Control-Request-Headers: authorization
Access-Control-Request-Method: GET
# 响应
Access-Control-Allow-Headers: authorization
Access-Control-Allow-Methods: POST,GET
Access-Control-Allow-Origin: http://127.0.0.1:3000
# 默认 5s、最大 86400=24h
Access-Control-Max-Age: 86400
OPTIONS
- preflight 请求
- ContentType application/json 会触发,text/plain、application/x-www-form-urlencoded、multipart/form-data 不会触发
- 自定义头会触发
- https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#preflighted_requests
HTTP2
QUIC
- Quick UDP Internet Connections
- SwitchyOmega#706 - Support QUIC proxies
- chrome://net-internals/#quic
- https://en.wikipedia.org/wiki/QUIC
- https://github.com/curl/curl/wiki/QUIC
- https://www.chromium.org/quic
- https://github.com/mholt/caddy/wiki/QUIC
- QUIC 希望能够提供等同于 SSL/TLS 层级的网络安全保护,减少数据传输及创建连接时的延迟时间,双向控制带宽,以避免网络拥塞。
Digest
- Digest access authentication
- 现在使用 digest 场景比较少 - 因为需要存储明文
- SIP 使用 digest
- 一般使用 Basic over HTTPS
- 算法
- MD5
- MD5-sess - HA1 = MD5(MD5(username:realm:password):nonce:cnonce)
- SHA-256
- SHA-256-sess
- SHA-512
- SHA-512-sess
- qop - quality of protection
- auth
- HA2 = MD5(method:digestURI)
- response = MD5(HA1:nonce:nonceCount:cnonce:qop:HA2)
- auth-int
- HA2 = MD5(method:digestURI:MD5(entityBody))
- response = MD5(HA1:nonce:nonceCount:cnonce:qop:HA2)
- 无 - response = MD5(HA1:nonce:HA2)
- auth
HA1 = MD5(username:realm:password)
HA2 = MD5(method:digestURI)
response = MD5(HA1:nonce:HA2)
服务端返回 challange
HTTP/1.0 401 Unauthorized
Server: HTTPd/0.9
Date: Sun, 10 Apr 2014 20:26:47 GMT
WWW-Authenticate: Digest realm="testrealm@host.com",
qop="auth,auth-int",
nonce="dcd98b7102dd2f0e8b11d0f600bfb0c093",
opaque="5ccc069c403ebaf9f0171e9517f40e41"
带 Auth 请求
GET /dir/index.html HTTP/1.0
Host: localhost
Authorization: Digest username="Mufasa",
realm="testrealm@host.com",
nonce="dcd98b7102dd2f0e8b11d0f600bfb0c093",
uri="/dir/index.html",
qop=auth,
nc=00000001,
cnonce="0a4f113b",
response="6629fae49393a05397450978507c4ef1",
opaque="5ccc069c403ebaf9f0171e9517f40e41"
Forwarded
- X-Forwarded-For
- X-ProxyUser-Ip
X-Real-IP: 127.0.0.1
X-Forwarded-For: 127.0.0.1
X-Forwarded-Host: example.com
X-Forwarded-Port: 443
X-Forwarded-Proto: https
X-Forwarded-Scheme: https
X-Scheme: https
X-Request-ID: -
# Proxy 自身信息
Via:
# 新的标准
Forwarded: by=<identifier>;for=<identifier>;host=<host>;proto=<http|https>
X-Content-Type-Options
- nosniff
- 要求使用头中的 mime 类型,避免探测 mime 类型
- X-Content-Type-Options
- since Microsoft IE 8
Strict-Transport-Security
- STS
Encoding
- Transfer-Encoding
- chunked
- 也可以指定压缩
- Content-Encoding
- deflate - zlib
- gzip - LZ77
- br - brotli
- identity
- compress - LZW - Lempel-Ziv-Welc - 不再使用
- sdch - Shared Dictionary Compression for HTTP - Chrome v59 (2017-06-05)移除
- Content-Length=Transfer-Length=Entity-Length
- 当不同时不应该设置
- 如果有压缩,则为压缩后的大小