PostHog makes it easy to get data about traffic and usage of your Astro app. Integrating PostHog into your site enables analytics about user behavior, custom events capture, session recordings, feature flags, and more.
This guide walks you through integrating PostHog into your Astro app using the JavaScript Web SDK.
Beta: integration via LLM
Try our prompt-based integration for Astro using Cursor, Bolt, and other agent-like tools that can run terminal commands. Paste this into your chat:
Let's integrate PostHog. Run the following command; don't write any code until it completes:npx --yes @posthog/wizard@latest --default --region us
Or, to integrate manually, continue with the rest of this guide.
Installation
In your src/components
folder, create a posthog.astro
file:
cd ./src/components# or 'cd ./src && mkdir components && cd ./components' if your components folder doesnt existtouch posthog.astro
In this file, add your Web snippet
which you can find in your project settings. Be sure to include the is:inline
directive to prevent Astro from processing it, or you will get Typescript and build errors that property 'posthog' does not exist on type 'Window & typeof globalThis'.
---// src/components/posthog.astro---<script is:inline>!function(t,e){var o,n,p,r;e.__SV||(window.posthog=e,e._i=[],e.init=function(i,s,a){function g(t,e){var o=e.split(".");2==o.length&&(t=t[o[0]],e=o[1]),t[e]=function(){t.push([e].concat(Array.prototype.slice.call(arguments,0)))}}(p=t.createElement("script")).type="text/javascript",p.crossOrigin="anonymous",p.async=!0,p.src=s.api_host+"/static/array.js",(r=t.getElementsByTagName("script")[0]).parentNode.insertBefore(p,r);var u=e;for(void 0!==a?u=e[a]=[]:a="posthog",u.people=u.people||[],u.toString=function(t){var e="posthog";return"posthog"!==a&&(e+="."+a),t||(e+=" (stub)"),e},u.people.toString=function(){return u.toString(1)+".people (stub)"},o="capture identify alias people.set people.set_once set_config register register_once unregister opt_out_capturing has_opted_out_capturing opt_in_capturing reset isFeatureEnabled onFeatureFlags getFeatureFlag getFeatureFlagPayload reloadFeatureFlags group updateEarlyAccessFeatureEnrollment getEarlyAccessFeatures getActiveMatchingSurveys getSurveys getNextSurveyStep onSessionId".split(" "),n=0;n<o.length;n++)g(u,o[n]);e._i.push([i,s,a])},e.__SV=1)}(document,window.posthog||[]);posthog.init('<ph_project_api_key>', {api_host:'https://us.i.posthog.com',defaults: '2025-05-24'})</script>
The next step is to a create a Layout where we will use posthog.astro
. Create a new file PostHogLayout.astro
in your src/layouts
folder:
cd .. && cd .. # move back to your base directory if you're still in src/components/posthog.astrocd ./src/layouts# or 'cd ./src && mkdir layouts && cd ./layouts' if your layouts folder doesn't exist yettouch PostHogLayout.astro
Add the following code to PostHogLayout.astro
:
---import PostHog from '../components/posthog.astro'---<head><PostHog /></head>
Lastly, update index.astro
to wrap your existing app components with the new Layout:
---import PostHogLayout from '../layouts/PostHogLayout.astro';---<PostHogLayout><!-- your existing app components --></PostHogLayout>
Set up a reverse proxy (recommended)
We recommend setting up a reverse proxy, so that events are less likely to be intercepted by tracking blockers.
We have our own managed reverse proxy service included in the platform add-ons, which routes through our infrastructure and makes setting up your proxy easy.
If you don't want to use our managed service then there are several other options for creating a reverse proxy, including using Cloudflare, AWS Cloudfront, and Vercel.
Grouping products in one project (recommended)
If you have multiple customer-facing products (e.g. a marketing website + mobile app + web app), it's best to install PostHog on them all and group them in one project.
This makes it possible to track users across their entire journey (e.g. from visiting your marketing website to signing up for your product), or how they use your product across multiple platforms.
Next steps
For any technical questions for how to integrate specific PostHog features into Astro (such as analytics, feature flags, A/B testing, surveys, etc.), have a look at our JavaScript Web SDK docs.
Alternatively, the following tutorials can help you get started: