Merge pull request #6325 from abpframework/maliming/Serialize-Null

Handle the serialized object as null.
pull/6329/head
liangshiwei 5 years ago committed by GitHub
commit 582d511f54
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,5 +1,6 @@
using System;
using System.Linq;
using JetBrains.Annotations;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Options;
using Volo.Abp.DependencyInjection;
@ -18,17 +19,19 @@ namespace Volo.Abp.Json
ServiceScopeFactory = serviceScopeFactory;
}
public string Serialize(object obj, bool camelCase = true, bool indented = false)
public string Serialize([CanBeNull]object obj, bool camelCase = true, bool indented = false)
{
using (var scope = ServiceScopeFactory.CreateScope())
{
var serializerProvider = GetSerializerProvider(scope.ServiceProvider, obj.GetType());
var serializerProvider = GetSerializerProvider(scope.ServiceProvider, obj?.GetType());
return serializerProvider.Serialize(obj, camelCase, indented);
}
}
public T Deserialize<T>(string jsonString, bool camelCase = true)
public T Deserialize<T>([NotNull]string jsonString, bool camelCase = true)
{
Check.NotNull(jsonString, nameof(jsonString));
using (var scope = ServiceScopeFactory.CreateScope())
{
var serializerProvider = GetSerializerProvider(scope.ServiceProvider, typeof(T));
@ -36,8 +39,10 @@ namespace Volo.Abp.Json
}
}
public object Deserialize(Type type, string jsonString, bool camelCase = true)
public object Deserialize(Type type, [NotNull]string jsonString, bool camelCase = true)
{
Check.NotNull(jsonString, nameof(jsonString));
using (var scope = ServiceScopeFactory.CreateScope())
{
var serializerProvider = GetSerializerProvider(scope.ServiceProvider, type);
@ -45,7 +50,7 @@ namespace Volo.Abp.Json
}
}
protected virtual IJsonSerializerProvider GetSerializerProvider(IServiceProvider serviceProvider, Type type)
protected virtual IJsonSerializerProvider GetSerializerProvider(IServiceProvider serviceProvider, [CanBeNull]Type type)
{
foreach (var providerType in Options.Providers.Reverse())
{

@ -1,10 +1,11 @@
using System;
using JetBrains.Annotations;
namespace Volo.Abp.Json
{
public interface IJsonSerializerProvider
{
bool CanHandle(Type type);
bool CanHandle([CanBeNull]Type type);
string Serialize(object obj, bool camelCase = true, bool indented = false);

@ -1,4 +1,5 @@
using System;
using JetBrains.Annotations;
using Microsoft.Extensions.Options;
using Volo.Abp.DependencyInjection;
@ -13,7 +14,7 @@ namespace Volo.Abp.Json.SystemTextJson
Options = options.Value;
}
public virtual bool Match(Type type)
public virtual bool Match([CanBeNull]Type type)
{
return Options.UnsupportedTypes.Contains(type);
}

Loading…
Cancel
Save