Asp.Net+Extjs实现登录
通过对Ext的学习,发现学习分三部曲:1.看官网的Demo,宏观了解Ext能做什么;2.看相关书籍,做理论指导;3.实现官网的Demo,体会Ext的真谛。
在完毕了第一、二部后,如今我们须要做的是实现第三步,我的目标效果是用Extjs画页面,用Asp.Net的一般处理程序做后台server实现登录功能。
宏观上的指导有了,以下进行细分,我整理了实现过程,思路例如以下:
1.画一个登录的Panel--loginPanel;
2.定义一个检測是否登录成功的函数CheckLogin;
3.定义一个登录窗口--win,将loginPanel加入到登录窗口中;
4.在登录窗口中加入“确定”和“取消”,为“确定”button绑定登录验证函数CheckLogin;
5.为登录窗口绑定一个最小化事件;
6.定义一个登录成功弹出新窗口函数loginSuccess
有了理论指导,以下进行代码实现:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<link href="css/ext-all.css" rel="stylesheet" type="text/css" />
<script src="js/ext-base.js" type="text/javascript"></script>
<script src="js/ext-all.js" type="text/javascript"></script>
<script type="text/javascript" language="javascript">
var loginPanel;
Ext.onReady(function () {
//1.画一个登录的Panel
loginPanel = new Ext.form.FormPanel({
labelWidth: 40,
width: 230,
height: 120,
frame: true,
bodyStyle: "padding:20", //给这个面板加入内间距
items: [
{ xtype: "textfield", id: "userName", fieldLabel: "username", style: "margin:1 3 15 3", labelWidth: 10, emptyText: "请输入username...", allowBlank: false, blankText: "username不能为空" },
{ xtype: "textfield", id: "userPass", fieldLabel: "密 码", style: "margin:1 3 15 3", labelWidth: 10, inputType: "password" }
]
}); //2.定义一个检測是否登录成功的函数CheckLogin
function CheckLogin() {
var userName = Ext.getCmp("userName").getValue(); //username
var userPass = Ext.getCmp("userPass").getValue(); //密 码 if (Ext.util.Format.trim(userName) == "" || Ext.util.Format.trim(userPass) == "") {//username和password不能为空
Ext.Msg.alert("提示", "username或password不能为空");
return;
} Ext.Ajax.request({
url: "Extjs.ashx?userName=" + userName + "&passWord=" + userPass, //将username和password传送到url
method: "get",
success: function (response) {
var getData = response.responseText; //获取服务器数据
if (getData == "ok") {
loginSuccess(); //登录成功了
} else {
Ext.Msg.alert("警告", "登录失败!");
}
}, failure: function (response, options) { alert("失败"); }
});
} //3.定义一个登录窗口--win,将loginPanel加入到登录窗口中;
var win = new Ext.Window({
title: "登录窗口",
minimizable: true, //最小化
maximizable: true, //最大化
width: 240,
height: 186,
frame: true,
items: [loginPanel],
//4.在登录窗口中加入“确定”和“取消”,为“确定”按钮绑定登录验证函数CheckLogin
buttons: [{ text: "确定", handler: CheckLogin }, { text: "取消"}]
}); //5.为登录窗口绑定一个最小化事件
win.minimize = function () {
Ext.MessageBox.confirm("提示", "是否要最小化", minwindow);
function minwindow(btn) {
if (btn == "yes") {
Ext.Msg.alert("提示", "确定最小化么", function () { alert("成功最小化"); });
}
}
} //6.定义一个登录成功弹出新窗口函数loginSuccess;
function loginSuccess() {
var winLoginSuccess = new Ext.Window({
title: "登录成功后的窗口",
minimizable: true, //最小化
maximizable: true, //最大化
collapsible: true,
width: 550,
height: 550,
frame: true,
items: [{ xtype: "button", frame: true, text: "我是登录成功后窗口的一个按钮"}]
});
win.hide(); //登录窗口隐藏
winLoginSuccess.show(); //显示登录成功后的窗口
} win.show(); //显示窗口
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
</div>
</form>
</body>
</html>
后台Extjs一般处理程序的代码实现:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace Demo
{
/// <summary>
/// Extjs 的摘要说明
/// </summary>
public class Extjs : IHttpHandler
{ public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string userName = context.Request.QueryString["userName"];
string userPass = context.Request.QueryString["passWord"];
if (userName == "quwenzhe" && userPass == "123")
{
context.Response.Write("ok"); //假设验证成功则返回ok
}
else
{
context.Response.Write("fail");//假设验证失败则返回fail
}
context.Response.End(); } public bool IsReusable
{
get
{
return false;
}
}
}
}
代码的运行过程:当点击确定button后,会触发CheckLogin函数,CheckLogin通过Ajax将获取的数据传到Extjs一般处理程序进行检验,并获取Extjs一般处理程序的返回值。假设返回值是ok,则调用loginSuccess函数弹出新窗口;否则,则弹出登录失败的提示。
执行代码后,登录页面效果图例如以下:
登录成功后的效果图例如以下:
到此,用Extjs实现的登录功能已经完毕。此外, 在学习过程中,发现自己存在浅尝辄止的问题,刚学会一点就以为自己明确了,希望大家能引以为戒,不要犯相同的错误。
Ext是个非常好的框架,学好它在非常大程度上能帮助我们学习DWZ,希望大家能用心学习这块。
Asp.Net+Extjs实现登录的更多相关文章
- ASP.NET MVC 用户登录Login
ASP.NET MVC 用户登录Login一.先来看个框架例子:(这个是网上收集到的) 第一步:创建一个类库ClassLibrary831. 第二步:编写一个类实现IHttpM ...
- 教你开发asp.net的单点登录系统
单点登录系统,简称SSO.以下是我花了几个小时写的一个简单实现.特把实现思路和大家分享. 背景:某项目使用ASP.NET MemberShip来做会员系统,需要同时登录多个系统.而项目的开发人员无法在 ...
- ASP.NET会员注册登录模块(MD5加密,Parameters防止SQL注入,判断是否注册)
MD5加密,Parameters防止SQL注入: protected void btnLog_Click(object sender, EventArgs e) { //获取验 ...
- asp.net web 开发登录相关操作的控件LoginName、LoginStatus和LoginView控件使用详解
http://book.51cto.com/art/200909/154039.htm http://book.51cto.com/art/200909/154041.htm ASP.NET提供了一套 ...
- 解決 IE10 浏览器无法使用 ASP.NET From 验证登录的问题
最近应项目用到ASP.Net表单验证机制(FormsAuthentication),来判断用户是否已经登录,一切测试顺利,最后发布到IIS中后在IE10测试是发现始终判断用户没登录(其他浏览器一切正常 ...
- ASP.NET5使用FaceBook登录
原版教程 使用VS2015创建Web应用: 此教程使用的是FaceBook账号登录,需要添加相关的类,打开Nuget: 搜索Microsoft.AspNet.Authentication.Facebo ...
- asp.net 完善注册登录+sqlite数据库
结合sqlite数据库,完善asp.net制作的web网页中的注册和登录操作. 1. Account-Register.aspx <%@ Page Title="" Lang ...
- ASP.NET Cookie的登录验证
做用户登录,我一直用form验证的方式.有时候,为了节省时间,用户希望用户名输入框能够记住用户名,省得下次重新输入.这个时候光用form验证是不行的,因为form验证的话,用户一退出系统就失效了,所以 ...
- ASP.NET MVC4 Forms 登录验证
Web.config配置: 在<system.web>节下: <authentication mode="Forms"> <forms loginUr ...
随机推荐
- 软件测试技术(三)——使用因果图法进行的UI测试
目标程序 较上次增加两个相同的输入框 使用方法介绍 因果图法 在Introduction to Software Testing by Paul一书中,将软件测试的覆盖标准划分为四类,logical ...
- Oracle中表结构和表内容复制
处理该问题注意以下几点: 1. 清空表中数据SQL:truncate table table_name; 2.复制表结构SQL:create table table_name1 as select * ...
- 动态执行linq 语句 NLinq
using Evaluant.NLinq.Memory;using System.Collections.Generic;using Evaluant.NLinq;using System.Colle ...
- g++安装 Gnome/Gtk+开发库 的 环境安装(安装widgets的必要条件)
sudo yum install gcc-c++ 我在更新软件源后,看了看最新版的GTK开发版是3.0的. 所以,基本可以照搬. sudo yum -t install gtk3 sudo yum - ...
- 过度拟合(overfitting)
我们之前解决过一个理论问题:机器学习能不能起作用?现在来解决另一个理论问题:过度拟合. 正如之前我们看到的,很多时候我们必须进行nonlinear transform.但是我们又无法确定Q的值.Q过小 ...
- Java-note-输入流
java不像C中拥有scanf这样功能强大的函数,大多是通过定义输入输出流对象.常用的类有BufferedReader,Scanner.实例程序:一,利用 Scanner 实现从键盘读入integer ...
- Hadoop学习之--Capaycity Scheduler配置参数说明
以下列举出来的是capacity关于queue和user资源使用量相关的参数说明: mapred.capacity-scheduler.queue.xxx.capacity: 队列的资源容量百分比,所 ...
- Cocos2dx游戏源码合集(BY懒骨头+持续更新+2014.02.21)
转自:http://blog.csdn.net/iamlazybone/article/details/19612941 声明: <萝莉快跑><喵汪大战>两个demo的原作者b ...
- homework03
代码实现真的是大问题……在第二次作业还没有真正实现的情况下只能写这么一篇博客来整理一下从各位大神那里看到的东西. 两个弱菜加起来同样是弱菜,所以我和我的小伙伴的配合就是悲剧的聚合. 首先,大家都说C# ...
- 终于弄好了 homework-09
近一周的时间,顶着编译大作业严重搁置的压力,天天搞,终于把网页动态展示的搞出来了!恩,还挺好看~ 因为是最后一次作业了,也是因为天生的完美主义强迫症,做到自己满意才放心停下来.不过,这个过程,看着同学 ...