作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在研究网络和 Stackoverflow,但在解决我遇到的问题时遇到了一些麻烦。
我正在尝试将我的 ASP.NET Core 应用程序加入 Docker。我有以下证书,我们称之为“FooCert.pfx”。我也有一份 FooCert.pfx 作为 .PEM 文件(FooCert.pem)。我试图让我的应用程序在运行时找到证书。我有一个用于构建和启动容器的 docker-compose.yml 文件;我有一些环境变量链接到证书在 Windows 主机上的位置;最后,我有一个 DockerFile 包装了我的应用程序预期的行为。
我的应用程序在尝试从 linux 容器上的证书存储中读取时抛出异常。它说它找不到证书并且无法识别商店。以下是我的 dockerfile 中的相关行:
FROM mcr.microsoft.com/dotnet/core/aspnet:2.2 AS base
WORKDIR /app
EXPOSE 80
FROM mcr.microsoft.com/dotnet/core/sdk:2.2 AS build
WORKDIR /src
...
COPY ./FooCert.pem /etc/ssl/certs/FooCert.pem
COPY ./FooCert.pem /usr/local/share/ca-certificates/FooCert.pem
COPY ./FooCert.pfx /usr/local/share/ca-certificates/FooCert.pfx
RUN openssl pkcs12 -in /usr/local/share/ca-certificates/FooCert.pfx -nocerts -nodes | sed -ne '/-BEGIN PRIVATE KEY-/,/-END PRIVATE KEY-/p' > FooCert.key
RUN openssl pkcs12 -in /usr/local/share/ca-certificates/FooCert.pfx -clcerts -nokeys | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > FooCertClientcert.cer
RUN openssl pkcs12 -in /usr/local/share/ca-certificates/FooCert.pfx -cacerts -nokeys -chain | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > FooCertcacerts.cer
COPY ./FooCert.pem /etc/ssl/certs/FooCert.pem
COPY ./FooCert.pem /usr/local/share/ca-certificates/FooCert.pem
RUN ls /usr/local/share/ca-certificates
RUN ls /etc/ssl/certs
RUN update-ca-certificates
...
[code to expose ports, define entrypoint, etc here]
var certStore = new X509Store(StoreName.CertificateAuthority, StoreLocation.LocalMachine);
最佳答案
我发现的一种解决方案如下:
docker-compose.yml
中挂载证书目录:version: '3.6'
services:
dockertemplate:
image: ${DOCKER_REGISTRY-}dockertemplate
build:
context: .
dockerfile: DockerTemplate/Dockerfile
ports:
#bind [host port]:[container port]
- 8000:80
- 5051:443
- 5050:5050
environment:
- "ASPNETCORE_URLS=https://+;http://+"
- Kestrel__Certificates__Default__Path=/https/aspnetapp.pfx
- Kestrel__Certificates__Default__Password=changeit
volumes:
- ~/.aspnet/https:/https:ro #this is very important
我的 Dockerfile:
#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY ["DockerTemplate/DockerTemplate.csproj", "DockerTemplate/"]
RUN dotnet restore "DockerTemplate/DockerTemplate.csproj"
COPY . .
WORKDIR "/src/DockerTemplate"
RUN dotnet build "DockerTemplate.csproj" -c Release -o /app/build
FROM build AS publish
RUN dotnet publish "DockerTemplate.csproj" -c Release -o /app/publish
FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "DockerTemplate.dll"]
而在您的
Program.cs
:
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
webBuilder.UseKestrel(options => options.ListenAnyIP(5050, listenOptions => listenOptions.UseHttps(
adapterOptions =>
{
adapterOptions.ServerCertificate = new X509Certificate2("/https/aspnetapp.pfx", "changeit");
})));
});
确保您已配置共享必要的权限,以共享您选择授予访问权限的目录。如果您在系统上没有看到配置的目录,请务必重新启动计算机。您可以尝试重新启动 docker 实例,但重新启动我的计算机对我来说是成功的。
关于c# - 如何在 ASP.NET Core 应用程序中的 Docker 上正确安装证书?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59205160/
我是一名优秀的程序员,十分优秀!