`

Ext与Struts2结合使用

阅读更多
Ext js2.2登陆(struts2+json)方法

1、struts2类包
Commons-logging-1.0.4.jar
Freemarker-2.3.12.jar
Ognl-2.6.11.jar
Struts2-core-2.1.2.jar
Xwork-2.1.1.jar
Commons-fileupload-1.2.1.jar
Commons-io-1.3.2.jar

2、web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
3、struts.xml
<!DOCTYPE struts PUBLIC
     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
     "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<package name="user" extends="struts-default">
<action name="login" class="org.ext.service.loginAction">
<result name="success">jsondate.jsp</result>
</action>
</package>
</struts>
4、login.jsp
<%@ page language="java" pageEncoding="gbk"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>wayfoon</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<link rel="stylesheet" type="text/css" href="./ext/css/ext-all.css">
<script type="text/javascript" src="./ext/js/ext-base.js"></script>
<script type="text/javascript" src="./ext/js/ext-all.js"></script>
<script type="text/javascript" src="./ext/js/ext-lang-zh_CN.js"></script>
<style type="text/css">
.user {
background: url(./images/user.gif) no-repeat 1px 2px;
}

.key {
background: url(images/key.gif) no-repeat 1px 2px;
}

.key,.user {
background-color: #FFFFFF;
padding-left: 20px;
font-weight: bold;
color: #000033;
}
</style>
<script type="text/javascript">
Ext.onReady(function() {
// 开启表单提示
Ext.QuickTips.init();
// 设置提示信息位置为边上
Ext.form.Field.prototype.msgTarget = 'side';
var win = new Ext.Window({
id : 'login-win',
title : '登陆',
iconCls : 'tabs',
width : 300,
height : 120,
collapsible : true,
plain : true,
// 初始化表单面板
items : new Ext.form.FormPanel({
id : 'login-form',
labelWidth : 50, // 默认标签宽度板
labelAlign : 'right',
buttonAlign : 'center',
// 不设置该值,表单将保持原样,设置后表单与窗体完全融合
baseCls : 'header',
layout : 'form',
defaults : {
width : 200
},
// 默认字段类型
defaultType : 'textfield',
items : [{
name: 'username',
cls: 'user',
fieldLabel : '账号',
allowBlank : false,
blankText:'帐户不能为空'//错误提示内容
// 禁止为空
}, {
name : 'password',
inputType : 'password',
fieldLabel : '密码',
cls:'key',
allowBlank : false,
blankText:'密码不能为空'
}],
// 初始化按钮
buttons : [{
text : '登陆',
type : 'submit',
handler : function() {
var but = this;
                    but.setDisabled(true);
                    this.setText('正在登陆');
    Ext.getCmp('login-form').getForm().submit({
waitMsg : '正在登录  ',
url : 'login.action',
method : 'POST',
success : function(form, action) {
Ext.Msg.alert('信息','成功');
but.setDisabled(false);
},
failure : function() {
Ext.Msg.alert('信息','失败');
but.setText("登陆");
but.setDisabled(false);
}
});
}
},{
               text: '取消',
              handler:function(){Ext.getCmp('login-form').getForm().reset();}//重置表单
            }]
})
});
// 将窗口显示出来
win.show();
});
</script>
</head>
<body>
</body>
</html>
4.1 html、js分离模式
Login.jsp源码
<%@ page language="java" pageEncoding="gbk"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>wayfoon</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<link rel="stylesheet" type="text/css" href="./ext/css/ext-all.css">
<script type="text/javascript" src="./ext/js/ext-base.js"></script>
<script type="text/javascript" src="./ext/js/ext-all.js"></script>
<script type="text/javascript" src="./ext/js/ext-lang-zh_CN.js"></script>
<script type="text/javascript" src="./js/login.js"></script>
<style type="text/css">
.user {
background: url(./images/user.gif) no-repeat 1px 2px;
}
.key {
background: url(images/key.gif) no-repeat 1px 2px;
}
.key,.user {
background-color: #FFFFFF;
padding-left: 20px;
font-weight: bold;
color: #000033;
}
</style>
</head>
<body>
</body>
</html>
Login.js源码
Ext.onReady(function() {
// 开启表单提示
Ext.QuickTips.init();
// 设置提示信息位置为边上
Ext.form.Field.prototype.msgTarget = 'side';
var win = new Ext.Window({
id : 'login-win',
title : '登陆',
iconCls : 'tabs',
width : 300,
height : 120,
collapsible : true,
plain : true,
// 初始化表单面板
items : new Ext.form.FormPanel({
id : 'login-form',
labelWidth : 50, // 默认标签宽度板
labelAlign : 'right',
buttonAlign : 'center',
// 不设置该值,表单将保持原样,设置后表单与窗体完全融合
baseCls : 'header',
layout : 'form',
defaults : {
width : 200
},
// 默认字段类型
defaultType : 'textfield',
items : [{
name: 'username',
cls: 'user',
fieldLabel : '账号',
allowBlank : false,
blankText:'帐户不能为空'//错误提示内容
// 禁止为空
}, {
name : 'password',
inputType : 'password',
fieldLabel : '密码',
cls:'key',
allowBlank : false,
blankText:'密码不能为空'
}],
// 初始化按钮
buttons : [{
text : '登陆',
type : 'submit',
handler : function() {
var but = this;
                    but.setDisabled(true);
                    this.setText('正在登陆');
    Ext.getCmp('login-form').getForm().submit({
waitMsg : '正在登录  ',
url : 'login.action',
method : 'POST',
success : function(form, action) {
Ext.Msg.alert('信息','成功');
window.location.href ='main.jsp';
but.setDisabled(false);
},
failure : function() {
Ext.Msg.alert('信息','失败');
but.setText("登陆");
but.setDisabled(false);
}
});
}
},{
               text: '取消',
               handler:function(){Ext.getCmp('login-form').getForm().reset();}//重置表单
            }]
})
});
// 将窗口显示出来
win.show();
});

5、jsondate.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
  <%@ taglib prefix="s" uri="/struts-tags" %>
<s:property value="jsondate" escape="false"/>
6、loginAction.java
package org.ext.service;
public class loginAction {
  private String username;
  private String password;
  private String jsondate="";
public String getUsername() {
return username;
}
public String getJsondate() {
return jsondate;
}
public void setJsondate(String jsondate) {
this.jsondate = jsondate;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String execute() throws Exception
{
if(username.equals("zjw") && password.equals("1234"))
{
this.jsondate="{success:true}";
}
else {
this.jsondate="{failure : true}";
}
return "success";
}
}
分享到:
评论

相关推荐

    Ext和struts2实例

    之前要用到Ext和struts2结合,在网上搜了很久一直出错,原来是jar包冲突,现在解决了。

    EXT+STRUTS2 经典例子

    EXT 结合struts2,用json方式与ACTION通信,非常经典的入门例子! 里面对ext.extend用的很好!

    Ext+Struts2多文件上传

    ext结合struts2.0实现文件上传,代码详细,加载项目即可以看到效果。

    ext3+struts2+hibernate+spring的CRUD+分页

    利用ext3+struts2+hibernate+spring的CRUD+分页这四个框架实现crud,详细说明grid的用法,

    Ext Desktop+struts2 实例

    最近在开发Ext的桌面程序结合struts2自带的json序列化,如需要了解更深请留言

    Ext2.0+struts2+spring2.5+ibatis2

    Ext2.0+struts2+spring2.5+ibatis2 结合的例子

    struts2结合ext3批量下载文件

    NULL 博文链接:https://ninggy.iteye.com/blog/645307

    EXTJS4+STRUTS2+JAVA增删改查

    eclipse下EXTJS4+STRUTS2+JAVA增删改查的完整例子

    ext JS+ssh的一个简单Dome

    Ext JS+struts2+spring+hibernate的一个简单Dome

    Ext与SSH结合案例

    用ExtJS打造的华丽页面,为客户提供了超级体验,通过向struts发送请求调用Hibernate访问数据库最终得到Json数据显示在页面,并可进行增、删、修操作。

    图书管理系统(struts+hibernate+spring+ext)130221.rar

    同时,该系统还结合了Hibernate框架,这是一个开源的对象关系映射(ORM)框架,它简化了数据库操作,允许开发者使用面向对象的方式来处理数据库,而无需关注底层SQL语句的细节。Spring框架的引入则是为了依赖注入和...

    JSP网盘(运用Struts+Ext上传技术)

    ExtJS 2.2+Java写的图书管理系统,TOMCAT5.0以上版本,数据库MSSQL2000+SP4,源文件件最好用eclipse打开,本套图片管理系统初次完工,主要是结合EXTJS技术,JSP的朋友可以很容易就调试起来,不管是学习可是使用都...

    Extjs结合Struts版的demo

    运用ext控制表现层,代码有详细说明,是初学ext的好例子

    基于EXT技术的网上订单管理系统

    本系统采用EXT技术构建页面并与MySql数据库有机结合,实现了网上订单管理的功能。具有前台数据更新和后台管理的功能,主要采用了struts和hibernate框架,以MVC设计模式为基础,大多数页面采用了EXT技术实现。主要...

    ext4教程,里面包含的是中文教程,目前没有全部的教程

    考虑到ExtJS与主流服务端框架的整合越来越紧密,《ExtJS Web应用程序开发指南(第2版)》还特意讲解了Struts和Struts 2框架的整合与配置。最后全面细致地讲解了ExtJS 4.0中新增的主题、图形和图表部分,真正实现完全...

    JSP Ext spring级联分页程序.rar

    JSP Ext spring级联分页程序,JSP分页程序示例,结合漂亮的extjs框架实现。由于空间问题web-inf/lib里的jar文件未引入,本项目是在struts2 hibernate spring构架下的,所以需要引入这些jar包。

    源码基于JSP的龙门物流管理系统(Ext+SSH).rar

    这个压缩包内包含了一套完整的物流管理系统源代码,使用Java Server Pages(JSP)作为前端展示技术,并结合了ExtJS框架以增强用户界面交互体验。系统后端采用了强大的Spring框架,Spring框架提供了全面的企业级支持...

    ExtJS Web应用程序开发指南(第2版)

    考虑到ExtJS与主流服务端框架的整合越来越紧密,《ExtJS Web应用程序开发指南(第2版)》还特意讲解了Struts和Struts 2框架的整合与配置。最后全面细致地讲解了ExtJS 4.0中新增的主题、图形和图表部分,真正实现完全...

    ExtJS Web应用程序开发指南(10-15)完毕

    考虑到 ExtJS与主流服务端框架的整合也越来越紧密,本书还特意讲解了Struts和Struts2框架的整合与配置。本书全面细致地讲解了ExtJS实现的 Portal实例,真正实现完全整合应用ExtJS技术。. 本书语言通俗易懂、版式...

    ExtJS Web应用程序开发指南(1-10)

    考虑到 ExtJS与主流服务端框架的整合也越来越紧密,本书还特意讲解了Struts和Struts2框架的整合与配置。本书全面细致地讲解了ExtJS实现的 Portal实例,真正实现完全整合应用ExtJS技术。. 本书语言通俗易懂、版式...

Global site tag (gtag.js) - Google Analytics