[英]NSwagStudio Generated C# Client Offsets Dates
我正在使用 NSwagStudio 生成 C# 客戶端,總的來說它工作得很好。 但是,我剛剛發現它無法正確識別日期字符串中的時區。 我從 API 收到一個過期的身份驗證令牌。 JSON 中的過期字符串如下所示: 2022-09-21T22:09:34.722Z
。 使用 Z 修飾符,它應該知道它是 UTC。 當我創建一個新應用程序並僅使用DateTime.Parse()
並輸入該字符串時,它會為我提供一個正確反映我當地時區 (GMT-6) 的日期。 但是,當客戶端解析此 object 時,日期值顯示為好像這是我的本地時間(即示例日期將顯示為我的時間晚上 10:09,而實際上應該是 UTC 時間晚上 10:09,這是我的時間下午 4:09 )。
這是我的 nswag.json 文件:
{
"runtime": "Net60",
"defaultVariables": null,
"documentGenerator": {
"fromDocument": {
"json": "",
"url": "*my/swagger/json/location*",
"output": null,
"newLineBehavior": "Auto"
}
},
"codeGenerators": {
"openApiToCSharpClient": {
"clientBaseClass": "ClientBase",
"configurationClass": null,
"generateClientClasses": true,
"generateClientInterfaces": true,
"clientBaseInterface": "IClient",
"injectHttpClient": true,
"disposeHttpClient": true,
"protectedMethods": [],
"generateExceptionClasses": true,
"exceptionClass": "ApiException",
"wrapDtoExceptions": true,
"useHttpClientCreationMethod": false,
"httpClientType": "System.Net.Http.HttpClient",
"useHttpRequestMessageCreationMethod": true,
"useBaseUrl": true,
"generateBaseUrlProperty": true,
"generateSyncMethods": false,
"generatePrepareRequestAndProcessResponseAsAsyncMethods": false,
"exposeJsonSerializerSettings": false,
"clientClassAccessModifier": "internal",
"typeAccessModifier": "public",
"generateContractsOutput": false,
"contractsNamespace": null,
"contractsOutputFilePath": null,
"parameterDateTimeFormat": "s",
"parameterDateFormat": "yyyy-MM-dd",
"generateUpdateJsonSerializerSettingsMethod": true,
"useRequestAndResponseSerializationSettings": false,
"serializeTypeInformation": false,
"queryNullValue": "",
"className": "{controller}Client",
"operationGenerationMode": "MultipleClientsFromFirstTagAndOperationId",
"additionalNamespaceUsages": [],
"additionalContractNamespaceUsages": [],
"generateOptionalParameters": true,
"generateJsonMethods": true,
"enforceFlagEnums": false,
"parameterArrayType": "System.Collections.Generic.IEnumerable",
"parameterDictionaryType": "System.Collections.Generic.IDictionary",
"responseArrayType": "System.Collections.Generic.ICollection",
"responseDictionaryType": "System.Collections.Generic.IDictionary",
"wrapResponses": false,
"wrapResponseMethods": [],
"generateResponseClasses": true,
"responseClass": "SwaggerResponse",
"namespace": "my.namespace",
"requiredPropertiesMustBeDefined": true,
"dateType": "System.DateTime",
"jsonConverters": null,
"anyType": "object",
"dateTimeType": "System.DateTime",
"timeType": "System.TimeSpan",
"timeSpanType": "System.TimeSpan",
"arrayType": "System.Collections.Generic.ICollection",
"arrayInstanceType": "System.Collections.ObjectModel.Collection",
"dictionaryType": "System.Collections.Generic.IDictionary",
"dictionaryInstanceType": "System.Collections.Generic.Dictionary",
"arrayBaseType": "System.Collections.ObjectModel.Collection",
"dictionaryBaseType": "System.Collections.Generic.Dictionary",
"classStyle": "Poco",
"jsonLibrary": "NewtonsoftJson",
"generateDefaultValues": true,
"generateDataAnnotations": true,
"excludedTypeNames": [],
"excludedParameterNames": [],
"handleReferences": false,
"generateImmutableArrayProperties": false,
"generateImmutableDictionaryProperties": false,
"jsonSerializerSettingsTransformationMethod": null,
"inlineNamedArrays": false,
"inlineNamedDictionaries": false,
"inlineNamedTuples": true,
"inlineNamedAny": false,
"generateDtoTypes": true,
"generateOptionalPropertiesAsNullable": false,
"generateNullableReferenceTypes": false,
"templateDirectory": null,
"typeNameGeneratorType": null,
"propertyNameGeneratorType": null,
"enumNameGeneratorType": null,
"serviceHost": null,
"serviceSchemes": null,
"output": "Client.cs",
"newLineBehavior": "Auto"
}
}
}
我可以在調試器中單步調試客戶端,並查看它使用設置創建序列化程序(我目前沒有公開更改)。 以下是序列化程序的相關屬性所說的:
據我所知,它應該正確解析出來,但實際上它並沒有......
誰能告訴我我在這里做錯了什么或如何糾正它?
來自序列化程序的 DateTime 將具有DateTimeKind
的DateTimeKind.Utc
。 不幸的是,將其與另一個 DateTime (即使是DateTimeKind.Local
類型)進行比較,將忽略 Kind 並按原樣進行比較。 如果這是一個問題,您可以與DateTime.UtcNow
進行比較。 或者,您可以反序列化為DateTimeOffset
,這將在進行比較時考慮偏移量。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.