要找个主题去发表一下,面对技术人士,还真难拿出什么来讲。写个啥。
参考: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#region Model

private int _u_id;

private string _u_name;

private string _u_pass;

private string _u_mail;



public int U_ID


{


set
{ _u_id = value; }


get
{ return _u_id; }

}


public string U_Name


{


set
{ _u_name = value; }


get
{ return _u_name; }

}


public string U_Pass


{


set
{ _u_pass = value; }


get
{ return _u_pass; }

}


public string U_Mail


{


set
{ _u_mail = value; }


get
{ return _u_mail; }

}

#endregion Model

}

}

4、 IDAL层(IUserInfo.cs):
添加引用Model
using System;

using System.Data;


namespace personalOA.IDAL



{


/**//// <summary>

/// 接口层IUserInfo 的摘要说明。

/// </summary>

public interface IUserInfo


{


成员方法#region 成员方法


/**//// <summary>

/// 是否存在该记录

/// </summary>

bool Exists(string U_Name,string U_Pass);

#endregion 成员方法

}

}
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()


{ }


成员方法#region 成员方法



/**//// <summary>

/// 是否存在该记录

/// </summary>

public bool Exists(string U_Name,string U_Pass)


{

StringBuilder strSql = new StringBuilder();

strSql.Append("select count(1) from UserInfo where U_Name='" + U_Name + "' and U_Pass='" + U_Pass + "'");

object obj = DbHelperSQL.GetSingle(strSql.ToString());

int cmdresult;

if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))


{

cmdresult = 0;

}

else


{

cmdresult = int.Parse(obj.ToString());

}

if (cmdresult == 0)


{

return false;

}

else


{

return true;

}

}

#endregion 成员方法

}

}

在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;

}

}

}

注意:引用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);

}

}

}

备注:在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()


{ }


成员方法#region 成员方法


/**//// <summary>

/// 是否存在该记录

/// </summary>

public bool Exists(string U_Name,string U_Pass)


{

IUserInfo dal = personalOA.DALFactory.UserInfo.Create();

return dal.Exists(U_Name,U_Pass);

}


#endregion 成员方法

}

}

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");

}

}

9、 运行,成功!