你是對的 - invocation.Method
將是屬性訪問器,而不是屬性。
這裏是一個要找到對應於它的存取方法之一PropertyInfo
實用方法:
public static PropertyInfo PropertyInfoFromAccessor(MethodInfo accessor)
{
PropertyInfo result = null;
if (accessor != null && accessor.IsSpecialName)
{
string propertyName = accessor.Name;
if (propertyName != null && propertyName.Length >= 5)
{
Type[] parameterTypes;
Type returnType = accessor.ReturnType;
ParameterInfo[] parameters = accessor.GetParameters();
int parameterCount = (parameters == null ? 0 : parameters.Length);
if (returnType == typeof(void))
{
if (parameterCount == 0)
{
returnType = null;
}
else
{
parameterCount--;
returnType = parameters[parameterCount].ParameterType;
}
}
if (returnType != null)
{
parameterTypes = new Type[parameterCount];
for (int index = 0; index < parameterTypes.Length; index++)
{
parameterTypes[index] = parameters[index].ParameterType;
}
try
{
result = accessor.DeclaringType.GetProperty(
propertyName.Substring(4),
returnType,
parameterTypes);
}
catch (AmbiguousMatchException)
{
}
}
}
}
return result;
}
使用這種方法,你的代碼將成爲:
var _attribute = Attribute.GetCustomAttribute(invocation.Method, typeof(OneToManyAttribute), true);
if (_attribute == null && invocation.Method.IsSpecialName)
{
var property = PropertyInfoFromAccessor(invocation.Method);
if (property != null)
{
_attribute = Attribute.GetCustomAttribute(property, typeof(OneToManyAttribute), true);
}
}
如果您OneToManyAttribute
僅適用於性能,不是方法,你可以省略第一個電話GetCustomAttribute
:
var property = PropertyInfoFromAccessor(invocation.Method);
var _attribute = (property == null) ? null : Attribute.GetCustomAttribute(property, typeof(OneToManyAttribute), true);