← 返回
效率工具
中文
HTTP
Use HTTP correctly with proper methods, status codes, headers, and caching.
正确使用 HTTP,包括适当的方法、状态码、头部和缓存。
ivangdavila
效率工具
clawhub
v1.0.0 1 版本 99774.5 Key: 无需
#latest
概述
Redirects (Often Confused)
- 307 vs 308: both preserve method; 307 temporary, 308 permanent—use these for POST/PUT redirects
- 301/302 may change POST to GET (browser behavior)—don't use for API redirects with body
- Include
Location header with absolute URL—relative may fail in older clients - Redirect loops: limit to 5-10 follows; infinite loops crash clients
Caching Combinations
Cache-Control: no-store for sensitive data—never written to diskno-cache still caches but revalidates every time—not "don't cache"private, max-age=0, must-revalidate for user-specific, always-fresh contentpublic, max-age=31536000, immutable for versioned static assetsVary: Accept-Encoding, Authorization when response depends on these headers—forgetting Vary breaks caching
Conditional Requests
ETag + If-None-Match: prefer for APIs—content hash based- Strong vs weak ETags:
"abc" vs W/"abc"—weak allows semantically equivalent responses If-Match for optimistic locking: fail update if resource changed since read- 412 Precondition Failed when
If-Match fails—not 409 Conflict
CORS Preflight Triggers
- Custom headers (anything not Accept, Accept-Language, Content-Language, Content-Type simple values)
- Content-Type other than: application/x-www-form-urlencoded, multipart/form-data, text/plain
- PUT, DELETE, PATCH methods—even to same origin if other conditions met
- ReadableStream body—triggers preflight
- Preflight cached per
Access-Control-Max-Age—set to 86400 to reduce OPTIONS spam
Security Headers (Always Set)
Strict-Transport-Security: max-age=31536000; includeSubDomains—HSTS, once set can't easily undoX-Content-Type-Options: nosniff—prevents MIME sniffing attacksX-Frame-Options: DENY or SAMEORIGIN—prevents clickjackingContent-Security-Policy—complex but essential; start with report-only mode
Range Requests
Accept-Ranges: bytes signals support—clients can request partial contentRange: bytes=0-1023 requests first 1024 bytes; bytes=-500 requests last 500- Return 206 Partial Content with
Content-Range: bytes 0-1023/5000 - 416 Range Not Satisfiable if range invalid—include
Content-Range: bytes */5000
Error Response Best Practices
- Structured JSON errors:
{"error": {"code": "VALIDATION_FAILED", "message": "...", "details": [...]}} - Include request ID in error response—enables log correlation
- Don't leak stack traces in production—log server-side, return generic message
- 409 Conflict for business rule violations (duplicate email, insufficient funds)—not just 400
Retry Patterns
- Retry only idempotent methods by default—GET, PUT, DELETE, HEAD
- POST retry needs idempotency key—
Idempotency-Key: - Exponential backoff: 1s, 2s, 4s, 8s... with jitter—prevents thundering herd
- Respect
Retry-After header—can be seconds or HTTP date - Set reasonable timeout (30s typical)—don't wait forever
Headers Often Forgotten
Vary: must include headers that affect response—CORS without Vary: Origin breaksContent-Disposition: attachment; filename="report.pdf" for downloadsX-Request-ID: generate if not present, propagate to downstream servicesAccept-Language for localized responses—respect with graceful fallback
Connection Behavior
- HTTP/1.1 without
Content-Length or chunked = connection close after response Transfer-Encoding: chunked for streaming—can't set Content-Length- HTTP/2 is binary, multiplexed—no head-of-line blocking at HTTP level
- WebSocket upgrade: GET with
Connection: Upgrade, Upgrade: websocket
版本历史
共 1 个版本
-
v1.0.0
当前
2026-03-28 11:17 安全 安全
安全检测
腾讯云安全 (Sanbu)
安全,无风险
查看报告
🔗 相关推荐
productivity
ide-rea
使用百度AI搜索引擎(BDSE)进行网络搜索。适用于获取实时信息、文档资料或研究课题。
★ 237
📥 105,446
productivity
ivangdavila
创建、检查和编辑 Microsoft Word 文档及 DOCX 文件,支持样式、编号、修订记录、表格、分节符及兼容性检查等功能。
★ 438
📥 147,453
productivity
steipete
获取当前天气和预报(无需API密钥)
★ 445
📥 226,223