.net 使用JQuery 调用Ashx 后面直接写方法名,通过反射找到对应的方法

using System.Reflection;
public class Industry_Manager : IHttpHandler
{
    HttpRequest gRequest = null;
    HttpContext gContext = null;
    HttpResponse gResponse = null;
    string func = string.Empty;
    string result = string.Empty;
    string pageUrl = string.Empty;

    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/plain";
        gContext = context;
        gRequest = context.Request;
        gResponse = context.Response;
        func = gRequest["func"];
        MethodInfo method = typeof(Industry_Manager).GetMethod(func);
        if (method != null)
        {
            object[] args = new object[] { result };
            method.Invoke(this, args);
            result = (string)args[0];
        }
        gResponse.Write(result);
    }

js 代码

  url: "http://www.cnblogs.com/Ashx/Industry_Manager.ashx?func=GetIndustryList", //请求数据的页面,后面参数直接跟方法名就可以了,后台通过反射自动查找,并返回数据

 public void GetIndustryList(out string result)
    {
        int count = 0;
        string sort = string.IsNullOrEmpty(gRequest["sort"]) ? "rectime_11022" : gRequest["sort"];
        string order = string.IsNullOrEmpty(gRequest["order"]) ? "desc" : gRequest["order"];
        string sector = gRequest["sector"];
        string name = gRequest["name"];
        string sWhere = "";

        if (!string.IsNullOrEmpty(sector) && sector != "请选择")
        {
            sWhere += " and  f002v_10202='" + sector + "'";
        }

        if (!string.IsNullOrEmpty(name))
        {
            sWhere += " and  f004v_10202 like '" + name + "%'";
        }
        sWhere = sWhere.TrimStart(" and".ToCharArray());
        BLL.vm_dms_allIndustry bll = new BLL.vm_dms_allIndustry();
        List<Model.vm_dms_allIndustry> list = bll.GetListRowNumber("vm_dms_allIndustry", "", sWhere, GetPageIndex(), sort, order, GetPageSize(), "*", "f001g_10202", ref count);
        string strResult = Newtonsoft.Json.JsonConvert.SerializeObject(list);
        strResult = JsonHelper.JsonReplaceDate1(strResult);
        strResult = "{ \"total\":" + count + ",\"rows\":" + strResult + "}";
        result = strResult;
    }

这样就可以避免写一堆 的switch  case 了

类似于这种代码的可以不用写了

public class News_Manager : IHttpHandler
{

    HttpRequest gRequest = null;
    HttpContext gContext = null;
    HttpResponse gResponse = null;
    string func = string.Empty;
    string result = string.Empty;
    string pageUrl = string.Empty;

    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/plain";
        gContext = context;
        gRequest = context.Request;
        gResponse = context.Response;
        pageUrl = gRequest.UrlReferrer.AbsolutePath;      
        func = gRequest["func"];
        if (!string.IsNullOrEmpty(func))
        {
            switch (func)
            {
                case "Get_News_General_List":
                    Get_News_General_List(out result);
                    break;
                case "News_General_Stock_Edit":
                    News_General_Stock_Edit(out result);
                    break;
                case "Get_News_General_ById":
                    Get_News_General_ById(out result);
                    break;
                case "News_General_Stock_Delete":
                    News_General_Stock_Delete(out result);
                    break;
                case "Get_News_General_ByGuid":
                    Get_News_General_ByGuid(out result);
                    break;
                case "News_General_Indus_Edit":
                    News_General_Indus_Edit(out result);
                    break;
                case "News_General_Industry_Delete":
                    News_General_Industry_Delete(out result);
                    break;
                case "Save":
                    Save(out result);
                    break;
                case "GetNewsById":
                    GetNewsById(out result);
                    break;
                case "Get_News_General_Industry_ById":
                    Get_News_General_Industry_ById(out result);
                    break;
                case "CreateGuid":
                    CreateGuid(out result);
                    break;
                case "GetStockByIndustry":
                    GetStockByIndustry(out result);
                    break;
                case "GetPLByNewsIDAndType":
                    GetPLByNewsIDAndType(out result);
                    break;
                default:
                    break;
            }
        }
        gResponse.Write(result);
    }
posted @ 2012-10-16 14:21  晓风拂月  阅读(2005)  评论(2编辑  收藏  举报