当前位置: 首页>>代码示例>>C#>>正文


C# StackTrace.GetCustomAttributes方法代码示例

本文整理汇总了C#中System.Diagnostics.StackTrace.GetCustomAttributes方法的典型用法代码示例。如果您正苦于以下问题:C# StackTrace.GetCustomAttributes方法的具体用法?C# StackTrace.GetCustomAttributes怎么用?C# StackTrace.GetCustomAttributes使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Diagnostics.StackTrace的用法示例。


在下文中一共展示了StackTrace.GetCustomAttributes方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Error

        public static void Error(string errorMessage, string stackTrace, params string[] param)
        {
            try
            {
                MethodBase methodBase = new StackTrace().GetFrame(1).GetMethod();

                string actionName = methodBase.Name;
                string controllerName = methodBase.DeclaringType.Name;

                HttpPostAttribute authorizationAttributes = methodBase.GetCustomAttributes(typeof(HttpPostAttribute), false)
                  .Cast<HttpPostAttribute>().FirstOrDefault();

                if (authorizationAttributes != null)
                {
                    actionName += "[POST]";
                }

                string logMessage = string.Concat(controllerName, "|", actionName, "|", errorMessage, "|", stackTrace, "|", param);

                ErrorLogger.Error(logMessage);
            }
            catch (Exception e)
            {

                ErrorLogger.Error("Unable to log.Error: " + e.Message + ",Stack Trace:" + e.StackTrace);
            }
        }
开发者ID:majurans,项目名称:SriLankaTours,代码行数:27,代码来源:LogManager.cs

示例2: Validate

        /// <summary>
        /// 呼び出し元のメソッド・プロパティ・インデクサ・コンストラクタのパラメーターが NULL かどうかを検証します。
        /// </summary>
        /// <param name="arguments">呼び出し元のパラメーター</param>
        /// <remarks>
        /// <![CDATA[
        /// 呼び出し元メソッド・プロパティ・インデクサ・コンストラクタのパラメーターに RequireAttribute の指定がある引数のみ NULL かどうかを確認します。
        /// 呼び出し元メソッド・プロパティ・インデクサ・コンストラクタのパラメーターの順序、数は一致するように指定してください。
        /// ]]>
        /// </remarks>
        /// <example>
        /// [Require]
        /// public void Hoge(string arg1, string arg2, string arg3)
        /// {
        ///     //throw new ArgumentNullException("arg1");
        ///     RequireAttribute.Validate(arg1, arg2, arg3);
        /// }
        /// public void Hoge([Require]string arg1, string arg2, [Require]string arg3)
        /// {
        ///     //throw new ArgumentNullException("arg1");
        ///     RequireAttribute.Validate(arg1, arg2, arg3);
        /// }
        /// [Require]
        /// public string Hoge
        /// {
        ///     get
        ///     {
        ///         return this._hoge;
        ///     }
        ///     set
        ///     {
        ///         //throw new ArgumentNullException("value");
        ///         RequireAttribute.Validate(value); 
        ///     }
        /// }
        /// [Require]
        /// public int this[int index]
        /// {
        ///     get
        ///     {
        ///         return this._hoge[index];
        ///     }
        ///     set
        ///     {
        ///         //throw new ArgumentNullException("index");
        ///         RequireAttribute.Validate(index, value); 
        ///     }
        /// }
        /// public class Hoge
        /// {
        ///     [Require]
        ///     public Hoge(string arg1, string arg2, string arg3)
        ///     {
        ///         //throw new ArgumentNullException("arg1");
        ///         RequireAttribute.Validate(index, value); 
        ///     }
        /// }
        /// </example>
        /// <exception cref="System.ArgumentException">引数の数が一致しません。</exception>
        public static void Validate(params object[] arguments)
        {
            var call = new StackTrace()
                .GetFrame(1)
                .GetMethod();

            var parameters = call.GetParameters();

            if (parameters.Length != arguments.Length)
            {
                throw new ArgumentException("引数の数が一致しません。");
            }

            var attributeType = typeof(RequireAttribute);

            var isMethodAllCheck = call.IsSpecialName;
            if (isMethodAllCheck == false)
            {
                isMethodAllCheck = call.GetCustomAttributes(attributeType, true).Any();
            }

            for (var i = 0; i < parameters.Length; i++)
            {
                var parameter = parameters[i];

                if (isMethodAllCheck == false && parameter.GetCustomAttributes(attributeType, true).Any() == false)
                {
                    continue;
                }

                if (arguments.ElementAtOrDefault(i) != null)
                {
                    continue;
                }

                throw new ArgumentNullException(parameters[i].Name);
            }
        }
开发者ID:setanamimoi,项目名称:iTunesAdjuster,代码行数:97,代码来源:ArgumentValidator.cs

示例3: Info

        public static void Info(string remoteIp, params string[] param)
        {
            try
            {
                MethodBase methodBase = new StackTrace().GetFrame(1).GetMethod();
                string actionName = methodBase.Name;
                string controllerName = methodBase.DeclaringType.Name;

                HttpPostAttribute authorizationAttributes = methodBase.GetCustomAttributes(typeof(HttpPostAttribute), false)
                    .Cast<HttpPostAttribute>().FirstOrDefault();

                if (authorizationAttributes != null)
                {
                    actionName += "[POST]";
                }

                string paramValues = null;
                for (int i = 0; i < param.Length; i++)
                {
                    paramValues += string.Concat(" | " + param[i]);
                }

                string logMessage = string.Concat(controllerName, "|", actionName, "|", paramValues);

                InfoLogger.Info(logMessage);
            }
            catch (Exception e)
            {
                InfoLogger.Error("Unable to log.Error: " + e.Message + ",Stack Trace:" + e.StackTrace);
            }
        }
开发者ID:majurans,项目名称:SriLankaTours,代码行数:31,代码来源:LogManager.cs


注:本文中的System.Diagnostics.StackTrace.GetCustomAttributes方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。