わかりました、私は何をすべきかを見つけました。この方法でカスタム DefaultContractResolver を使用する必要があります。
public class ExcludeEntityKeyContractResolver : DefaultContractResolver
{
private static Type mCollectionType = typeof(System.Data.Objects.DataClasses.RelatedEnd);
protected override IList<JsonProperty> CreateProperties(Type type, MemberSerialization memberSerialization)
{
var members = GetSerializableMembers(type);
IList<JsonProperty> properties = base.CreateProperties(type, memberSerialization);
IList<JsonProperty> serializeProperties = new List<JsonProperty>();
for (int i = 0; i < properties.Count; i++)
{
var memberInfo = members.Find(p => p.Name == properties[i].PropertyName);
if (!memberInfo.GetCustomAttributes(false).Any(a => a is SoapIgnoreAttribute) && properties[i].PropertyType != typeof(System.Data.EntityKey))
{
serializeProperties.Add(properties[i]);
}
}
return serializeProperties;
}
}
そしてGlobal.asaxで:
JsonSerializerSettings serializerSettings = new JsonSerializerSettings();
serializerSettings.ContractResolver = new ExcludeEntityKeyContractResolver();
var jsonMediaTypeFormatter = new JsonMediaTypeFormatter();
jsonMediaTypeFormatter.SerializerSettings = serializerSettings;
GlobalConfiguration.Configuration.Formatters.Insert(0, jsonMediaTypeFormatter);
CreateProperties は、アプリケーションの全期間にわたってすべてのタイプに対して 1 回だけ呼び出されるため、パフォーマンスについて心配する必要はありません :)