源代码:13033480群共享
如果我说,“编程,与编程无关”,你一定觉得不可思议;那,你又如何理解网上那句非常流行的名言,“我爱你,与你无关”?
讲一个真实的故事吧,我原来在企业的时候,单位有个专职翻译,他曾把一个有2万词汇量的词典交给我,让我随便问。我问了,他真的一个都没记错。
后来,总工把一个设备使用说明交给我,让我翻译,我一个晚上,9点—12点,3个小时,很轻松地翻好,交给了总工。(为此,总工欣赏了我好几年,直到我调走,仍然无私关怀,这里,再次深深地说一声:谢谢!)
后来,我又知道,在我之前,这个翻译,已经翻了一个月了,没翻出来......
难道,翻译,与翻译无关????
我英语,自然烂得很,这个,不是谦虚;而这套设备,我差不多已经玩烂了,这个也不是谦虚!
这是让我翻这个使用说明,我用了三个小时,如果让我自己写一个使用说明,我一个小时都不需要!
这个故事告诉我,玩烂一个东西,再写这个东西,比什么都重要。
现在,让我们玩玩这个登录系统吧......
一、登录系统的使用逻辑
运行一下这个登录程序,其实逻辑是这样的:
1、在文本框如分别输入用户名和密码;
2、点击“注册”按钮,如果:
(1)用户名、密码正确,就跳转到了Default.aspx;
(2)用户名或密码不正确,就弹出一个消息框,提示用户名或密码错误。
二、登录系统的实现逻辑
熟悉了登录系统的使用逻辑,也就有了它的实现逻辑:
在点击“登录”按钮时,
1、获取用户名和密码对应文本框中输入的值txtUserName.Text和txtPassword.Text;
2、查询数据库NetShop中表Users中用户名为txtUserName.Text,密码为txtPassword.Text的项,获得一个SqlDataReader;
3、判断这个SqlDataReader是否为空,如果:
(1)SqlDataReader不为空,就跳转到Default.aspx;
(2)SqlDataReader为空,就弹出消息框,提示“用户名或密码错误!”。
很多语言都有登录系统,这些登录的逻辑,都是这个逻辑。也就是说,你按照这个逻辑编程,而与使用什么语言编,一点关系都没有,不是吗??
有人已经看出来了,这个逻辑,其实就是“算法”,谭浩强早就指出“算法才是编程的灵魂”!
(其实,我更喜欢把这种所谓的算法,叫做“解决问题的步骤”)
下面我们看看,ASP.NET使用C#是怎么实现这个逻辑的:
protected void btnLogin_Click(object sender, EventArgs e) { bool blIsAuthenticated = false; string strConnection = ConfigurationManager.ConnectionStrings["NetShopConnString"].ConnectionString.ToString(); SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection(strConnection)) { conn.Open(); cmd.Connection = conn; cmd.CommandType = CommandType.Text; cmd.CommandText = "SELECT UserName FROM Users WHERE UserName='" + txtUserName.Text + "' AND Password='" + txtPassword.Text + "'"; SqlDataReader rdr = cmd.ExecuteReader(); if (rdr.Read()) { blIsAuthenticated = true; } rdr.Close(); } if (blIsAuthenticated == true) { Session["UserName"] = txtUserName.Text; Response.Redirect("Default.aspx"); } else { Response.Write("<script>alert('用户名或密码错误!')</script>"); } }
这个代码里,我使用了using()结构;使用了比较成熟的登录系统特有的一个变量blIsAuthenticated来判断是否登录成功;使用了类ConfigurationManager从Web.config中读取连接字符串。如果,我直接使用前面讲的最基本的数据库连接代码,你会看到,那将会是直接使用计算机语言来翻译我前面的实现逻辑了。
这个登录系统的结构,在这里,就略一下吧......
写诗的人常会说,“功夫在诗外”,相信这句话吧,编程,功夫在编程之外......