我试图以这样一种方式组织代码,以减少/避免代码重复,我遇到了一个有趣的问题。每次我的代码调用一个存储的proc时,我需要传递一些存储的proc通用的变量:比如用户名、域、server_ip和client_ip。这些都来自HttpRequest对象或system.environment对象。
因为它们被传递给每个存储的proc,所以我最初的想法是创建一个实用程序类,它是一个数据库包装器,每次都会初始化并传递它们,这样我就不必在代码中这样做了。问题是c#类(在App_Code文件夹中)看不到Httprequest对象。当然,我可以将此作为参数传递给包装器,但这将违背创建包装器的全部目的。我是不是漏掉了什么?
我意识到每次调用存储的proc时重复4行代码并不是什么大问题,但我宁愿在非常早的阶段消除代码重复。
发布于 2009-02-26 02:02:01
设置您的数据层以从包含这些值的4个属性的基类继承。使公共构造函数需要这4个属性。
然后在业务层基类中使用构造函数中的这4个属性执行类似的操作。
然后UI执行新用户名(请求“BusObj”,... ).method()
在数据层中,您可以使用一个方法来构建一个具有这4个属性的SQLParameter数组,然后每个方法都可以向该数组添加额外的参数。
发布于 2009-02-26 01:32:26
作为一般规则,不管使用哪种编程语言,如果您可以斜视眼睛,并且代码看起来是一样的,那么您应该创建一个函数/方法/消息,并传递参数。
另一件需要注意的事情是,一旦你有了接受大量参数的方法(4是一个很好的经验法则,但它绝对是逐个情况的基础),是时候让该方法将对象作为参数而不是单个参数了。99.99999999999999999999%的时间,这样的对象应该是不可变的(没有可写的实例变量)。
发布于 2009-02-26 01:18:19
HttpContext.Current具有与您在HttpRequest中找到的信息相似的信息,更重要的是,它在App_Code中可用。
https://stackoverflow.com/questions/588699
复制相似问题