参考:LTP代码生成器,PetShop4.0,正题:
数据库设计:
同样很重要的一个过程,直接与后期测试、发布与维护的成功与否相关。
UserInfo:
1 U_ID int 4 0
0 U_Name varchar 20 0
0 U_Pass varchar 32 0
0 U_Mail varchar 100 1
备注:此数据表只为熟悉三层设计,其他的数据表因注意其他设计,加入必须的AddBy、AddTime、AddIp、UpdateBy、UpdateTime、UpdateIp、Remark、standbyCol等。
设计步骤:
1、 新建网站与解决方案personalOA,配置IIS,新建数据库。
2、 逐个新建类库Model、IDAL、SQLServerDAL、DALFactory、BLL,最后新建网站Web。
注意:每个类库与网站都要设为personalOA引用程序集,即在属性里增加personalOA.。
3、 Model层(UserInfo.cs):
using System;
namespace personalOA.Model
{
/// <summary>
/// 实体类UserInfo
/// </summary>
public class UserInfo
{
public UserInfo()
{ }
Model Model
}
}
namespace personalOA.Model
{
/// <summary>
/// 实体类UserInfo
/// </summary>
public class UserInfo
{
public UserInfo()
{ }
Model Model
}
}
4、 IDAL层(IUserInfo.cs):
添加引用Model
using System;
using System.Data;
namespace personalOA.IDAL
{
/// <summary>
/// 接口层IUserInfo 的摘要说明。
/// </summary>
public interface IUserInfo
{
成员方法 成员方法
}
}
using System.Data;
namespace personalOA.IDAL
{
/// <summary>
/// 接口层IUserInfo 的摘要说明。
/// </summary>
public interface IUserInfo
{
成员方法 成员方法
}
}
5、 SQLServerDAL层(UserInfo.cs):
添加引用Model、IDAL和System.Configuration
using System;
using System.Data;
using System.Text;
using System.Data.SqlClient;
using personalOA.IDAL;
namespace personalOA.SQLServerDAL
{
/// <summary>
/// 数据访问类UserInfo。
/// </summary>
public class UserInfo : IUserInfo
{
public UserInfo()
{ }
成员方法 成员方法
}
}
using System.Data;
using System.Text;
using System.Data.SqlClient;
using personalOA.IDAL;
namespace personalOA.SQLServerDAL
{
/// <summary>
/// 数据访问类UserInfo。
/// </summary>
public class UserInfo : IUserInfo
{
public UserInfo()
{ }
成员方法 成员方法
}
}
在SQLServerDAL里还有一个基础库类DbHelperSQL.cs,因为太多,将它独立拿出写到其他日志里。
注意:在DbHelperSQL.cs中用到Using.Configuration;在引用中添加using Configuration,即是用ConfigurationManager来代替ConfigurationSettings,否则在2.0中会出现过时警告:警告 “System.Configuration.ConfigurationSettings.AppSettings”已过时:“This method is obsolete, it has been replaced by System.Configuration!System.Configuration.ConfigurationManager.AppSettings”
备注:在PetShop4.0中把基础库类写到类库DBUtility里,我觉得没有必要为它重新加一个类库,只是为了方便理解。
6、 DALFactory层(UserInfo.cs):
添加引用IDAL和System.Web、System.Configuration
using System;
using System.Reflection;
using System.Configuration;
using personalOA.IDAL;
namespace personalOA.DALFactory
{
/// <summary>
/// 工厂类UserInfo 的摘要说明。
/// web.config 需要加入配置:(利用工厂模式+反射机制+缓存机制,实现动态创建不同的数据层对象接口)
/// DataCache类在导出代码的文件夹里
/// <appSettings>
/// <add key="DAL" value="personalOA.SQLServerDAL" /> (这里的命名空间根据实际情况更改为自己项目的命名空间)
/// </appSettings>
/// </summary>
public class UserInfo
{
public static IUserInfo Create()
{
string path =ConfigurationManager.AppSettings["DAL"];
string CacheKey = path + ".UserInfo";
object objType = DataCache.GetCache(CacheKey);
if (objType == null)
{
try
{
objType = Assembly.Load(path).CreateInstance(CacheKey);
DataCache.SetCache(CacheKey, objType);// 写入缓存
}
catch { }
}
return (IUserInfo)objType;
}
}
}
using System.Reflection;
using System.Configuration;
using personalOA.IDAL;
namespace personalOA.DALFactory
{
/// <summary>
/// 工厂类UserInfo 的摘要说明。
/// web.config 需要加入配置:(利用工厂模式+反射机制+缓存机制,实现动态创建不同的数据层对象接口)
/// DataCache类在导出代码的文件夹里
/// <appSettings>
/// <add key="DAL" value="personalOA.SQLServerDAL" /> (这里的命名空间根据实际情况更改为自己项目的命名空间)
/// </appSettings>
/// </summary>
public class UserInfo
{
public static IUserInfo Create()
{
string path =ConfigurationManager.AppSettings["DAL"];
string CacheKey = path + ".UserInfo";
object objType = DataCache.GetCache(CacheKey);
if (objType == null)
{
try
{
objType = Assembly.Load(path).CreateInstance(CacheKey);
DataCache.SetCache(CacheKey, objType);// 写入缓存
}
catch { }
}
return (IUserInfo)objType;
}
}
}
注意:引用System.Web是为了设置工厂模式与反射机制。
在DALFactory里还有DataCache.cs,它提供了GetCache与SetCache两种方法提供反射机制,当然可以直接用System.Web定义,为了方便理解,这样分开更直观。
DataCache.cs:
using System;
using System.Web;
namespace personalOA.DALFactory
{
/// <summary>
/// 缓存相关的操作类
/// </summary>
public class DataCache
{
/// <summary>
/// 获取当前应用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <returns></returns>
public static object GetCache(string CacheKey)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
return objCache[CacheKey];
}
/// <summary>
/// 设置当前应用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <param name="objObject"></param>
public static void SetCache(string CacheKey, object objObject)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(CacheKey, objObject);
}
}
}
using System;
using System.Web;
namespace personalOA.DALFactory
{
/// <summary>
/// 缓存相关的操作类
/// </summary>
public class DataCache
{
/// <summary>
/// 获取当前应用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <returns></returns>
public static object GetCache(string CacheKey)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
return objCache[CacheKey];
}
/// <summary>
/// 设置当前应用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <param name="objObject"></param>
public static void SetCache(string CacheKey, object objObject)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(CacheKey, objObject);
}
}
}
备注:在PetShop4.0中,把这2个类写到了DataAccess.cs里,区别不大。
7、 BLL层(UserInfo.cs):
添加引用DALFactory、IDAL和Model
using System;
using System.Data;
using System.Data.SqlClient;
using System.Text;
using personalOA.IDAL;
namespace personalOA.BLL
{
/// <summary>
/// 业务逻辑类UserInfo 的摘要说明。
/// </summary>
public class UserInfo
{
public UserInfo()
{ }
成员方法 成员方法
}
}
using System.Data;
using System.Data.SqlClient;
using System.Text;
using personalOA.IDAL;
namespace personalOA.BLL
{
/// <summary>
/// 业务逻辑类UserInfo 的摘要说明。
/// </summary>
public class UserInfo
{
public UserInfo()
{ }
成员方法 成员方法
}
}
8、 Web层(LoginIn.aspx):
引用BLL、Model和SQLServerDAL。
以下是BtnLoginIn_Click事件的代码:
protected void BtnLoginIn_Click(object sender, EventArgs e)
{
string PName, PPwd;
PName = TxtPName.Text.Trim();
PPwd = TxtPPwd.Text.Trim();
UserInfo b=new UserInfo();
if (b.Exists(PName,PPwd) == true)
{
Response.Redirect("Main.aspx");
}
else
{
Response.Write("<script>alert('输入错误!')</script>");
Response.Redirect("LoginIn.aspx");
}
}
{
string PName, PPwd;
PName = TxtPName.Text.Trim();
PPwd = TxtPPwd.Text.Trim();
UserInfo b=new UserInfo();
if (b.Exists(PName,PPwd) == true)
{
Response.Redirect("Main.aspx");
}
else
{
Response.Write("<script>alert('输入错误!')</script>");
Response.Redirect("LoginIn.aspx");
}
}
9、 运行,成功!