ExtJS实战(7)-登陆

本文介绍了一个使用ExtJS实现的简单登录应用实例,包括前端页面和表单的设计,以及后端Struts框架处理登录请求的过程。
上篇文章我们已经把最核心的ExtJS代码贴出来了。慢慢消化着,我们先来一个完整的登陆应用。登陆页面如下:

1.login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W<chmetcnv w:st="on" unitname="C" sourcevalue="3" hasspace="False" negative="False" numbertype="1" tcsc="0">3C</chmetcnv>//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Insert title here</title>

<link rel="stylesheet" type="text/css" href="resources/css/ext-all.css">

<script type="text/javascript" src="resources/js/ext-base.js"></script>

<script type="text/javascript" src="resources/js/ext-all.js"></script>

<script type="text/javascript" src="resources/js/ext-lang-zh_CN.js"></script>

<script type="text/javascript" src="resources/js/login.js"></script>

</head>

<body>

</body>

</html>

2.其中使用到的login.js

Ext.onReady(function() {

Ext.state.Manager.setProvider(new Ext.state.CookieProvider());

// 使用表单提示

Ext.QuickTips.init();

Ext.form.Field.prototype.msgTarget = 'side';

// 定义表单

var login = new Ext.FormPanel({

labelWidth : 75,

monitorValid : true,// 把有formBind:true的按钮和验证绑定

baseCls : 'x-plain',

defaults : {

width : 150

},

defaultType : 'textfield',// 默认字段类型

// 定义表单元素

items : [{

fieldLabel : '帐户',

name : 'login.uname',// 元素名称

// anchor:'95%',//也可用此定义自适应宽度

allowBlank : false,// 不允许为空

blankText : '帐户不能为空!'// 错误提示内容

}, {

inputType : 'password',

fieldLabel : '密码',

// anchor:'95%',

name : 'login.upass',

allowBlank : false,

blankText : '密码不能为空!'

}],

buttons : [{

text : '登陆',

formBind : true,

type : 'submit',

// 定义表单提交事件

handler : function() {

if (simple.form.isValid()) {// 验证合法后使用加载进度条

Ext.MessageBox.show({

title : '请稍等',

msg : '正在登陆...',

progressText : '',

width : 300,

progress : true,

closable : false,

animEl : 'loading'

});

// 控制进度速度

var f = function(v) {

return function() {

var i = v / 11;

Ext.MessageBox

.updateProgress(i, '');

};

};

for (var i = 1; i < 12; i++) {

setTimeout(f(i), i * 150);

}

// 提交到服务器操作

login.form.doAction('submit', {

url : 'login.do',// 文件路径

method : 'post',// 提交方法postget

params : '',

// 提交成功的回调函数

success : function(form, action) {

if (action.result.msg == 'ok') {

window.location = 'index.jsp';

} else {

Ext.Msg

.alert(

'登陆失败',

action.result.msg);

}

},

// 提交失败的回调函数

failure : function() {

Ext.Msg.alert('错误',

'服务器出现错误请稍后再试!');

}

});

}

}

}, {

text : '取消',

handler : function() {

login.form.reset();

}// 重置表单

}]

});

// 定义窗体

var win = new Ext.Window({

id : 'loginWin',

title : '用户登陆',

layout : 'fit', // 布局方式fit,自适应布局

width : 300,

height : 150,

modal : true,

plain : true,

bodyStyle : 'padding:5px;',

maximizable : false,// 禁止最大化

closeAction : 'close',

closable : false,// 禁止关闭

collapsible : true,// 可折叠

plain : true,

buttonAlign : 'center',

items : login

// 将表单作为窗体元素嵌套布局

});

win.show();// 显示窗体

});

看了上篇文章中的JS代码,这里的登陆JS真是小巫见大巫,简单的不行。我们看到,上面主要是一个窗口和一个表单,这个表单提交的URLlogin.do,那我们服务器端就要一个Action组件来对此进行响应。接下来我们就来看下服务器端的代码:

package org.leno.houseHire.action;

import java.io.PrintWriter;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.apache.struts.action.Action;

import org.apache.struts.action.ActionForm;

import org.apache.struts.action.ActionForward;

import org.apache.struts.action.ActionMapping;

import org.leno.houseHire.service.ILoginService;

import org.leno.houseHire.service.LoginDTO;

public class LoginAction extends Action {

private ILoginService loginService;

public void setLoginService(ILoginService loginService) {

this.loginService = loginService;

}

public ActionForward execute(ActionMapping mapping, ActionForm form,

HttpServletRequest request, HttpServletResponse response) throws Exception {

response.setCharacterEncoding("utf-8");

PrintWriter pw = response.getWriter();

LoginForm lForm = (LoginForm) form;

LoginDTO dto = lForm.getLogin();

boolean flag = loginService.valid(dto);

if(flag){

request.getSession().setAttribute("USER_INFO", dto);

pw.print("{success:true,msg:'ok'}");

}else{

pw.print("{success:true,msg:'用户名或密码错误!'}");

}

return null;

}

}

这里有几个地方要提醒下大家,首先是我们这里的Action也是利用Service做事,所以是由Spring来管理的,其次,我们依然采用实体DTO对象做ActionForm的属性,最后,也是最重要的一点,结合客户端的回调代码分析,要清楚服务器端返回给客户端的是一个JSON对象!这里使用到的其它JAVA类如下:

1.数据访问层(DAO及其实现)

package org.leno.houseHire.dao;

public interface ILoginDAO {

内容概要:本文介绍了一种基于蒙特卡洛模拟和拉格朗日优化方法的电动汽车充电站有序充电调度策略,重点针对分时电价机制下的分散式优化问题。通过Matlab代码实现,构建了考虑用户充电需求、电网负荷平衡及电价波动的数学模【电动汽车充电站有序充电调度的分散式优化】基于蒙特卡诺和拉格朗日的电动汽车优化调度(分时电价调度)(Matlab代码实现)型,采用拉格朗日乘子法处理约束条件,结合蒙特卡洛方法模拟大量电动汽车的随机充电行为,实现对充电功率和时间的优化分配,旨在降低用户充电成本、平抑电网峰谷差并提升充电站运营效率。该方法体现了智能优化算法在电力系统调度中的实际应用价值。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事新能源汽车、智能电网相关领域的工程技术人员。; 使用场景及目标:①研究电动汽车有序充电调度策略的设计与仿真;②学习蒙特卡洛模拟与拉格朗日优化在能源系统中的联合应用;③掌握基于分时电价的需求响应优化建模方法;④为微电网、充电站运营管理提供技术支持和决策参考。; 阅读建议:建议读者结合Matlab代码深入理解算法实现细节,重点关注目标函数构建、约束条件处理及优化求解过程,可尝试调整参数设置以观察不同场景下的调度效果,进一步拓展至多目标优化或多类型负荷协调调度的研究。
内容概要:本文围绕面向制造业的鲁棒机器学习集成计算流程展开研究,提出了一套基于Python实现的综合性计算框架,旨在应对制造过程中数据不确定性、噪声干扰面向制造业的鲁棒机器学习集成计算流程研究(Python代码实现)及模型泛化能力不足等问题。该流程集成了数据预处理、特征工程、异常检测、模型训练与优化、鲁棒性增强及结果可视化等关键环节,结合集成学习方法提升预测精度与稳定性,适用于质量控制、设备故障预警、工艺参数优化等典型制造场景。文中通过实际案例验证了所提方法在提升模型鲁棒性和预测性能方面的有效性。; 适合人群:具备Python编程基础和机器学习基础知识,从事智能制造、工业数据分析及相关领域研究的研发人员与工程技术人员,尤其适合工作1-3年希望将机器学习应用于实际制造系统的开发者。; 使用场景及目标:①在制造环境中构建抗干扰能力强、稳定性高的预测模型;②实现对生产过程中的关键指标(如产品质量、设备状态)进行精准监控与预测;③提升传统制造系统向智能化转型过程中的数据驱动决策能力。; 阅读建议:建议读者结合文中提供的Python代码实例,逐步复现整个计算流程,并针对自身业务场景进行数据适配与模型调优,重点关注鲁棒性设计与集成策略的应用,以充分发挥该框架在复杂工业环境下的优势。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值