Lio*_*ion 8 c# timezone localization docker asp.net-core
我想使用德语日期格式作为我的 ASP.NET Core 2.2 应用程序的默认值。在我使用德语/布局的 Win10 机器上,它可以工作,所以我认为必须在我的 Dockerfile 中设置时区。根据Alpine wiki,我这样做了:
FROM mcr.microsoft.com/dotnet/core/sdk:2.2-alpine3.9 AS build-env
ENV TZ=Europe/Berlin
WORKDIR /app
COPY *.csproj ./
RUN dotnet restore
RUN apk add tzdata \
&& cp /usr/share/zoneinfo/${TZ} /etc/localtime \
&& echo "${TZ}" > /etc/timezone
COPY . ./
RUN dotnet publish -c Production -o dist
ENTRYPOINT ["dotnet", "./dist/MyApp.dll"]
Run Code Online (Sandbox Code Playgroud)
根据date
命令,这有效:
/app # date
Sun Apr 7 13:50:42 CEST 2019
/app # date -u
Sun Apr 7 11:50:40 UTC 2019
Run Code Online (Sandbox Code Playgroud)
但是DateTime
在我的模型中有一个来自数据库的对象
<td>@article.PublishedTime.ToString("g")</td>
Run Code Online (Sandbox Code Playgroud)
我得到4/7/19 12:16 AM
了我的德国 Win10 机器显示的位置07.04.2019 00:16
。为什么这不起作用?由于 ASP.NET Core 使用系统时区,它现在应该使用 linux 中设置的 24 小时时间格式。
Lio*_*ion 11
发现我们需要设置语言,因为这是用于格式化的:
ENV TZ=Europe/Berlin
ENV LANG de_DE.UTF-8
ENV LANGUAGE ${LANG}
ENV LC_ALL ${LANG}
Run Code Online (Sandbox Code Playgroud)
这有效并生成德国 24 小时日期时间格式。
我同意在大多数情况下这应该由应用程序控制,应用程序在例如用户指定的设置上使用不同的格式。由于这是一个仅适用于我的简单应用程序,因此它是将服务器设置设置为我的本地化的最简单方法。从任何类型的设置传递文化信息都会产生开销而没有优势。
但正如我所说,这仅适用于我的情况。在生产环境中,您可能希望指定 colture 并允许国际用户使用不同的文化。
归档时间: |
|
查看次数: |
6899 次 |
最近记录: |