最近在学习一般处理程序,也学习了一些jQuery的异步操作,于是就想着亲手做一个小的登陆,锻炼一下自己。
1、首先新建了一个项目LoginDemo,在此基础上又添加了一个一般处理程序BackLogin.ashx,具体代码如下
///<span style="font-family: Arial, Helvetica, sans-serif;">没有牵扯到数据库查询,在这写的比较简单</span>
public class BackLogin : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string username = context.Request.Form["username"];
string password = context.Request.Form["password"];
if (username == " " || password == " ")
{
context.Response.Write("请填写用户名或密码!");
}
else
{
if (username == "001" && password == "001")
{
context.Response.Write("success");
}
else
{
context.Response.Write("用户名或密码错误,请重新登录!");
}
}
context.Response.End();
}
public bool IsReusable
{
get
{
return false;
}
}
}2、添加一个Web页面Login.aspx,作为登陆页面,浏览器效果图如下所示
3、三种实现方式
1. Form表单形式
<form action="BackLogin.ashx" method="post">
<input type="text" name="username" value="{num}" />
<input type="text" name="password" />
<input type="submit" value="登陆" />
</form>2、异步Post方式
<script type="text/javascript">
$(function () {
$("#Login").click(function () {
$.post("BackLogin.ashx", { "username": $("#username").val(), "password": $("#password").val() },
function (msg) {
if (msg == "success") {
alert("登陆成功");
}
else if (msg == "用户名或密码错误,请重新登录!") {
alert("登录失败!");
}
else {
alert("请输入用户名和密码!");
}
});
});
// $("form1").submit();
})
</script>
3、异步ajax
<script type="text/javascript">
$(document).ready(function () {
$("#Login").click(function () {
$.ajax({
url: "BackLogin.ashx",
type: "POST",
data: "username=" + escape($('#username').val()) + "&password=" + escape($('#password').val()),
dataType: "text/plain",
async: "true",
success: function (msg) {
var data = eval("(" + msg.d + ")");
if (data == "success") {
alert("登陆成功!");
}
else {
alert("登录失败!");
}
}
});
})
});
</script>输入001,0010用户名、密码时浏览器显示如下:
5、反思
第一种实现方式不是异步,不能很好的起到效果,ajax异步比Post操作更底层。
6、易犯错误
1.<input>标签内的name值与一般处理程序中获取form表单的name不一致
2.各种{ }()匹配不准确,造成不易察觉的语法错误
7、总结
编程序一定要先有思路,在思路的引导下,细心再细心
原文:http://blog.csdn.net/ydm19891101/article/details/42806439