频 道 直 达 - 新闻 - 培训 - 软件 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 读书 - 博客 - BBS
51CTO.COM_中国最大的网络技术网站
找资料:

14.3.2 功能实现

作者: 明日科技 张跃廷 房大伟 苏宇 出处:人民邮电出版社  2008-04-11 00:09    砖    好    评论   进入论坛
阅读提示:《ASP.NET 2.0网络编程自学手册》适用于ASP.NET初、中级用户,也可作为大、中院校师生和培训班的教材,对于网络编程爱好者,本书也有非常好的参考价值。本文介绍了如何进行功能实现。

14.3.2  功能实现

登录页面运行结果如图14.4所示。

主要实现步骤如下。

(1)创建Web窗体,命名为landing.aspx。

图14.4  登录页面

(2)在Default窗体中添加控件。添加的主要控件及用途如表14.6所示。

表14.6 landing.aspx页面中控件及其用途

   

标准/TextBox控件

TextName

输入会员名

TextPass

输入密码

TextBoxYzm

输入验证码

标准/Button控件

ButtonLanding

“登录”按钮

HtML/Input(Reset)控件

Reset1

用于重置

标准/Image控件

Image1

用于显示验证码

标准/ LinkButton控件

LinkButton1

用于链接注册页面

LinkButton2

重新链接验证码

(3)主要程序代码如下。

在“登录”按钮的Click事件中判断验证码、及用户输入的会员名和密码是否正确,如果正确需要把当前登录的会员名和当前登录时间添加到登录日志数据库中。Click事件的代码如下。

protected void Button1_Click(object sender, EventArgs e)
{   //创建连接
SqlConnection con = new SqlConnection("server=.;database=login;uid=sa;pwd=;");
if (Session["CheckCode"].ToString().Equals(TextBoxYzm.Text.ToString()))
{
try
{
con.Open();
SqlCommand com = new SqlCommand("select count(*) from loginInfo
where  Name= @name and Pass=@ps", con);
com.Parameters.Add(new SqlParameter("@name", SqlDbType.VarChar, 50));
com.Parameters["@name"].Value = TextName.Text;
com.Parameters.Add(new SqlParameter("@ps", SqlDbType.VarChar, 50));
com.Parameters["@ps"].Value = 
FormsAuthentication.HashPasswordForStoringInConfigFile(TextPass.Text, "MD5");
int i = (int)com.ExecuteScalar();
if (i > 0)
{
//添加登陆日志
com = new SqlCommand("insert EntryLog values('" + TextName.Text
+  "','" + DateTime.Now.ToString() + "')", con);
com.ExecuteNonQuery();
con.Close();
Response.Redirect("index.aspx");
}
else
{
Response.Write("<script>alert('密码或用户名错误!')</script>");
}
}
catch (Exception error)
{
Response.Write(error.ToString());
}
}
else
Response.Write("<script>alert('验证码错误!')</script>");          
}

登录成功后效果如图14.5所示。

图14.5  登录成功页面

在此页面的Page_Load事件中需要通过Image1控件的ImageUrl属性来绑定验证码。Page_Load事件的代码如下。

protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
this.Image1.ImageUrl = "ValidateCode.aspx";

}
}

为了防止验证码看不清,需要在验证码后添加LinkButton控件,重新绑定一下Image控件的ImageUrl属性。LinkButton2控件的Click事件代码如下。

protected void LinkButton2_Click(object sender, EventArgs e)
{
this.Image1.ImageUrl = "ValidateCode.aspx";
}

回书目   上一节   下一节
关于 ASP  .NET
专题
ASP.NET 2.0基础开发指南
.NET移动与嵌入式技术专题
.NET Framework新手入门专题
VS.NET实用开发专题
ADO.NET实用技巧专题
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 最 大 的 网 络 技 术 网 站 ·
技 术 成 就 梦 想
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
LAMP技术精解
LAMP技术精解
Apache技术专题
Apache技术专题
三层交换技术专题
三层交换技术专题
· 三层交换技术专题
· 2008年上半年全国软考..
· 微软出价446亿美元收购..
· 首届中国IT工程师生态..
· 视频访谈:网管员如何踏..
· 企业数据恢复指南
· Linux——从菜鸟到高手
· 交换机故障解决指南
· OSPF路由协议专栏
· 勇闯IT培训黑色围城
· 见证中国网络安全二十年
· 技术人求职简历完备手册
· 华为员工自杀频频拷问..
· 思科全球CEO钱伯斯第七..
· 北漂技术人90天求职纪实
· 2007年互联网大会
ARP攻击防范与解决方案
ARP攻击防范与解决方案
iSCSI应用与发展
iSCSI应用与发展
SQL Server 2008/2005全解
SQL Server 2008/2005全解
· SQL Server 2008/2005..
· SOA 面向服务架构
· SQL Server 2008/2005..
· iSCSI应用与发展
· RAID——磁盘阵列基础
· Apache技术专题
· 中间件应用技术专题
· 三层交换技术专题
· SQL Server入门到精通
· Apache技术专题
· 国际文档格式标准开战
· 路由器设置与口令恢复
· Linux防火墙
· 打造安全服务器
· SOA 面向服务架构
· PHP开发应用手册
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
iSCSI应用与发展
iSCSI应用与发展
· iSCSI应用与发展
· 中间件应用技术专题
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· Apache技术专题
· iSCSI应用与发展
· 三层交换技术专题
· Apache技术专题
· RAID——磁盘阵列基础
· 企业数据恢复指南
· 路由器设置与口令恢复
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· ADSL应用面面俱到
· ADSL应用面面俱到