Quenchworks

aspnet 8

Runtime · Runtime base · standard · v8

0 fixable CVEs nonroot cosign signed SPDX SBOM SLSA provenance amd64 · arm64

Hardened ASP.NET Core runtime for web apps and APIs. Build on the dotnet image, run here. Lines 8/9/10.

Version line

The latest line lives at the base page; older lines have their own page so you can pin and verify exactly that version.

Image
ghcr.io/quenchworks/images/aspnet:8
Signed
cosign keyless
SBOM
SPDX, on digest
Provenance
SLSA build
Architectures
amd64, arm64
Runs as
nonroot (uid 1001)
Image size
71.2 MB
SBOM packages
23
Last rebuilt
2026-06-11

Use it as a base image

Reference it in the FROM line of your Dockerfile. Nonroot, read-only root filesystem, built for amd64 and arm64.

FROM ghcr.io/quenchworks/images/aspnet:8

Or pull it directly

docker pull ghcr.io/quenchworks/images/aspnet:8
Version line
8
Latest line
8, 9, 10
Architectures
amd64, arm64
Runs as
nonroot (uid 1001)
Root filesystem
read-only
License
MIT

Verify the supply chain

This image is cosign-signed and carries an SPDX SBOM and a SLSA build-provenance attestation on the same digest. Check all three before you build on it:

# 1. signature — built and signed by QuenchWorks CI
cosign verify ghcr.io/quenchworks/images/aspnet:8 \
  --certificate-identity-regexp 'https://github.com/quenchworks/.+' \
  --certificate-oidc-issuer https://token.actions.githubusercontent.com

# 2. SLSA build provenance — which workflow built it, from what
gh attestation verify oci://ghcr.io/quenchworks/images/aspnet:8 --owner quenchworks

# 3. SPDX SBOM — the package inventory
gh attestation verify oci://ghcr.io/quenchworks/images/aspnet:8 --owner quenchworks \
  --predicate-type https://spdx.dev/Document

See the SBOM & provenance guide for reading the SBOM and using these checks in CI.

Best-practice Dockerfile for 8

aspnet is a runtime base you copy a published web app onto, not something you build in. Here dotnet publish runs in an SDK build stage and the aspnet image is the final stage that serves it.

ghcr.io/quenchworks/images/aspnet:8 71.2 MB rebuilt 4 days ago 23 SBOM pkgs
# Build stage: restore and publish with the full SDK.
FROM ghcr.io/quenchworks/images/dotnet:8 AS build
USER root
WORKDIR /src
ENV NUGET_PACKAGES=/tmp/nuget \
DOTNET_CLI_TELEMETRY_OPTOUT=1
COPY ["App.csproj", "./"]
RUN ["dotnet", "restore", "App.csproj"]
COPY . .
RUN ["dotnet", "publish", "App.csproj", "-c", "Release", "-o", "/app/publish", "--no-restore"]
# This image is the final runtime stage: the ASP.NET Core runtime, nonroot.
FROM ghcr.io/quenchworks/images/aspnet:8 AS runtime
WORKDIR /app
ENV ASPNETCORE_URLS=http://+:8080
COPY --from=build /app/publish ./
USER 1001
EXPOSE 8080
ENTRYPOINT ["dotnet", "App.dll"]

This Dockerfile is pinned to the 8 line. For the line-by-line walkthrough and ecosystem variants (npm/Yarn, pip/uv/Poetry, Maven/Gradle), see the Build a .NET app guide.

Upstream project: https://github.com/dotnet/runtime