执行指定的操作的一般处理程序

using Newtonsoft.Json;
using System;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Text.RegularExpressions;
using System.Web;
using System.Web.SessionState;

namespace Menhub {
    public abstract class PointedMethodHttpHandler<T> : IHttpHandler, IRequiresSessionState {
        public bool IsReusable {
            get { return false; }
        }

        static Lazy<MethodInfo[]> methods = new Lazy<MethodInfo[]>(() => typeof(T).GetMethods());
        protected abstract string ServerMethod { get; }
        protected virtual object Instance {
            get {
                return this;
            }
        }
        public void ProcessRequest(HttpContext context) {
            var methodName = this.GetString(ServerMethod, @"\b[a-zA-Z][a-zA-Z0-9]+\b");
            var method = methods.Value.FirstOrDefault(m => m.Name.ToLower() == methodName.ToLower());
            if (method == null)
                throw this.recordError("if (method == null)");
            object result;
            try {
                result = method.Invoke(this.Instance, null);
            } catch (Exception e) {
                throw this.recordError(e.GetinnerMessage());
            }
            HttpContext.Current.Response.ContentType = "application/json";
            HttpContext.Current.Response.Write(JsonConvert.SerializeObject(result));
        }
        protected bool GetString(string key, string patten, out string value) {
            value = HttpContext.Current.Request[key];
            return Regex.IsMatch((value ?? string.Empty).Trim(), patten);
        }
        protected string GetString(string key) {
            return (HttpContext.Current.Request[key] ?? string.Empty).Trim();
        }
        protected string GetString(string key, bool required) {
            var result = (HttpContext.Current.Request[key] ?? string.Empty).Trim();
            if (result.Length == 0 && required) throw this.recordError("key: {0} is required.", key);
            return result;
        }
        /// <summary>
        /// return a required value. pass patten as null or \"\" if the value is only required.
        /// </summary>
        protected string GetString(string key, string patten) {
            var value = HttpContext.Current.Request[key];
            if ((value ?? string.Empty).Trim().Length == 0 || ((patten ?? string.Empty).Length > 0 && !Regex.IsMatch(value, patten)))
                throw this.recordError("key: {0} is required or doesn't match the patten: {1}.", key, patten);
            return value.Trim();
        }
        protected virtual Exception recordError(string format, params object[] errors) {
            var request = HttpContext.Current.Request;
            var f = File.AppendText(request.MapPath("error-log.txt"));
            f.WriteLine("-------------{0}:{1}", DateTime.Now, request.Path);
            var all = request.Params;
            foreach (var key in all.AllKeys)
                f.WriteLine("key:{0}\n\tvalue:{1}", key, all[key]);
            var errorsText = string.Format(format, errors);
            f.WriteLine(errorsText);
            f.Write("--------------------------------------");
            f.Flush();
            f.Close();
            return new Exception(errorsText);
        }
    }
    public static class ExceptionExtensoin {
        public static string GetinnerMessage(this Exception e) {
            return e == null ? string.Empty : e.InnerException == null ? e.Message : e.InnerException.GetinnerMessage();
        }
    }
}

 

转载于:https://www.cnblogs.com/ly45/p/4510609.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值