{"package":"express","ecosystem":"npm","latest_version":"5.2.1","description":"Fast, unopinionated, minimalist web framework","license":"MIT","license_risk":"permissive","commercial_use_notes":"Permissive: commercial closed-source use OK; preserve the copyright notice.","homepage":"https://expressjs.com/","repository":"https://github.com/expressjs/express","downloads_weekly":102848052,"health":{"score":100,"risk":"low","breakdown":{"maintenance":25,"popularity":20,"security":25,"maturity":15,"community":15,"popularity_floor":0},"deprecated":false,"max_score":100},"vulnerabilities":{"count":0,"critical":0,"high":0,"medium":0,"low":0,"details":[]},"versions":{"latest":"5.2.1","total_count":288,"recent":["4.18.1","4.18.2","4.18.3","4.19.0","4.19.1","5.0.0-beta.2","4.19.2","5.0.0-beta.3","4.20.0","5.0.0","4.21.0","4.21.1","5.0.1","4.21.2","5.1.0","4.22.0","5.2.0","5.2.1","4.22.1","4.22.2"]},"metadata":{"deprecated":false,"deprecated_message":null,"maintainers_count":5,"first_published":"2010-12-29T19:38:25.450Z","last_published":"2025-12-01T20:49:43.268Z","dependencies_count":28,"dependencies":["qs","depd","etag","once","send","vary","debug","fresh","cookie","router","accepts","type-is","parseurl","statuses","encodeurl","mime-types","proxy-addr","body-parser","escape-html","http-errors","on-finished","content-type","finalhandler","range-parser","serve-static","cookie-signature","merge-descriptors","content-disposition"]},"github_stats":{"stars":69066,"forks":23504,"open_issues":214,"is_archived":false,"pushed_at":"2026-05-17T14:48:35Z","subscribers_count":1668},"bundle":{"size_kb":586.4,"gzip_kb":236.1,"dependency_count":28,"has_js_module":false,"has_side_effects":true,"scoped":false,"source":"bundlephobia"},"typescript":{"score":7,"has_types":true,"types_source":"definitely-typed","types_package":"@types/express"},"known_issues":{"bugs_count":1,"bugs_severity":{"high":1},"status_breakdown":{"closed":1},"link":"/api/bugs/npm/express","scope":"all","details":[{"title":"app.use() with string path and trailing slash does not match subpaths","severity":"high","status":"closed","affected_version":"5.0.0","fixed_version":"5.0.1","url":"https://github.com/expressjs/express/issues/6014"}]},"historical_compromise":null,"recommendation":{"action":"safe_to_use","issues":[],"use_version":"5.2.1","version_hint":null,"summary":"express@5.2.1 is safe to use (health: 100/100)","alternatives":[{"name":"fastify","reason":"2-3x faster, schema validation built-in","builtin":false},{"name":"hono","reason":"Ultra-light, edge/serverless ready","builtin":false}]},"version_scoped":null,"_meta":{"endpoint":"check","tier":"full","philosophy":"DepScope is free. Use the cheapest endpoint that answers your real question.","cheaper_alternatives":[{"endpoint":"/api/exists/npm/express","tokens_estimated":12,"use_when":"you only need to know if the package exists (hallucination guard)"},{"endpoint":"/api/health/npm/express","tokens_estimated":80,"use_when":"you only need a 0-100 score for go/no-go (>=70 = safe)"},{"endpoint":"/api/prompt/npm/express","tokens_estimated":280,"use_when":"you want a plain-text LLM-friendly brief instead of JSON"},{"endpoint":"POST /api/check_bulk","tokens_estimated":60,"use_when":"you have 5+ packages to check; sends one round-trip instead of N"}],"docs":"https://depscope.dev/integrate","hint_bulk":"You've called /api/check 96 times in 60s. Save bandwidth + tokens with POST /api/check_bulk (1 round-trip for N pkgs)."},"requested_version":null,"_cache":"hit","_response_ms":0,"_powered_by":"depscope.dev — free package intelligence for AI agents","typosquat":{"is_suspected":false},"maintainer_trust":{"available":true,"bus_factor_3m":null,"active_contributors_12m":null,"primary_author_ratio":null,"owner_account_age_days":null,"is_archived":false,"stars":null,"alerts":[]},"malicious":{"is_malicious":false},"scorecard":{"available":true,"score":8.9,"tier":"strong"},"quality":{"available":true,"criticality_score":0.873,"criticality_tier":"critical","velocity_pct":2.6,"velocity_trend":"stable","publish_security":"signed"},"breaking_changes_link":{"url":"/api/breaking/npm/express","count":5,"hint":"Use this endpoint to get version-pair breaking changes + migration hints."},"alternatives_link":{"url":"/api/alternatives/npm/express","count":2},"co_used_with":[{"package":"lodsh","occurrences":163},{"package":"reqeusts","occurrences":163},{"package":"scan:2pkgs","occurrences":146},{"package":"scan_sbom:1pkgs","occurrences":137},{"package":"axios","occurrences":106}],"version_history_summary":{"total_versions":20,"first_release_age_days":5631,"last_release_days_ago":180,"avg_days_between_releases":296,"release_velocity":"moderate"}}