Spring+Webwork+iBatis 组合

本文介绍了一个基于WebWork和Spring框架结合使用的项目配置案例,详细展示了如何通过配置文件实现WebWork与Spring框架的集成,包括Web应用配置、数据库连接设置、Action定义等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、/WEB-INF/web.xml      (配置WebWork + Spring)

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<filter>
      <filter-name>webwork</filter-name>
      <filter-class>com.opensymphony.webwork.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
      <filter-name>webwork</filter-name>
      <url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
      <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>

 

二、/WEB-INF/applicationContext.xml (配置Spring + iBatis)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN 2.0//EN"
"http://www.springframework.org/dtd/spring-beans-2.0.dtd">

<beans default-autowire="autodetect">


<!-- 读取Mysql驱动信息参数文件      -->
<bean id="propertyConfigurer"
      class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
      <property name="locations">
       <list>
        <value>WEB-INF/jdbc.properties</value>
       </list>
      </property>
</bean>

<!-- C3P0 数据源      -->
<bean id="dataSource"
      class="com.mchange.v2.c3p0.ComboPooledDataSource"
      destroy-method="close">
      <property name="driverClass" value="${jdbc.driverClassName}" />
      <property name="jdbcUrl" value="${jdbc.url}" />
      <property name="user" value="${jdbc.username}" />
      <property name="password" value="${jdbc.password}" />
</bean>

<bean id="sqlMapClient"
      class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
      <property name="configLocation"
       value="WEB-INF/sql-map-config.xml" />
      <property name="dataSource" ref="dataSource" />
</bean>

<bean id="userservices" class="userServices"/>   
<bean id="mymysqldriver" class="MyMysqlDriver"/>  

<!-- 在personservices 对象中注入 sqlMapClient -->
<bean id="personservices" class="PersonServices"> 
  <property name="sqlMapClient" ref="sqlMapClient"/> 
</bean>

</beans>

 

三、/WEB-INF/jdbc.properties (配置 iBatis 的数据库驱动(MySql驱动))

 

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mysql1
jdbc.username=root
jdbc.password=1234

  

四、/classes/xwork.xml (配置 WebWork )

 

<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.1.1//EN"
"http://www.opensymphony.com/xwork/xwork-1.1.1.dtd">

<!-- START SNIPPET: xworkSample -->

<xwork>
<include file="webwork-default.xml"/>

<include file="xwork-Global.xml"/>
<include file="xwork-PersonAction.xml"/> 
</xwork>

 


五、/classes/xwork-Global.xml (配置 WebWork )

<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.1.1//EN"
"http://www.opensymphony.com/xwork/xwork-1.1.1.dtd">
<xwork>
<package name="global" extends="webwork-default">
      <global-results>
       <result name="error" type="redirect">/isnull.jsp</result>
      </global-results>
</package>
</xwork>

 

六、/classes/xwork-PersonAction.xml (配置 WebWork )

 

<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.1.1//EN"
"http://www.opensymphony.com/xwork/xwork-1.1.1.dtd">
<xwork>
      <package name="ppp" extends="global">
       <action name="personaction" class="PersonAction">
        <result name="success" type="dispatcher">/Person.jsp</result>
        <interceptor-ref name="params"/>
       </action>
      </package>
</xwork>

 

七、/WEB-INF/sql-map-config.xml (配置 iBatis)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-config-2.dtd">
<sqlMapConfig>

        <settings
            cacheModelsEnabled="true"
            enhancementEnabled="true"
            lazyLoadingEnabled="true"
            maxRequests="32"
            maxSessions="10"
            maxTransactions="5"
            useStatementNamespaces="false"
        />
        <sqlMap resource="/PersonDataEntity.xml" />
</sqlMapConfig>

 

八、/classes/PersonDataEntity.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"
      "http://www.ibatis.com/dtd/sql-map-2.dtd">
<sqlMap namespace="Person">
<select id="selectPerson" resultClass="fizi.PersonDataEntity">
      SELECT PER_ID as id,
      PER_FIRST_NAME as firstName,
      PER_LAST_NAME as lastName,
      PER_BIRTH_DATE as birthDate,
      PER_WEIGHT_KG as weightInKilograms,
      PER_HEIGHT_M as heightInMeters
      FROM PERSON
      WHERE PER_ID = #value#
</select>
<insert id="insertPerson" parameterClass="fizi.PersonDataEntity">
      <![CDATA[
       INSERT INTO
       PERSON (PER_ID, PER_FIRST_NAME, PER_LAST_NAME,
       PER_BIRTH_DATE, PER_WEIGHT_KG, PER_HEIGHT_M)
       VALUES (#id#, #firstName#, #lastName#,
                 #birthDate#, #weightInKilograms#, #heightInMeters#)
      ]]>
</insert>
<update id="updatePerson" parameterClass="fizi.PersonDataEntity">
      <![CDATA[
       UPDATE PERSON
       SET PER_FIRST_NAME = #firstName#,
       PER_LAST_NAME = #lastName#, PER_BIRTH_DATE = #birthDate#,
       PER_WEIGHT_KG = #weightInKilograms#,
       PER_HEIGHT_M = #heightInMeters#
       WHERE PER_ID = #id#
      ]]>
</update> 
<delete id="deletePerson" parameterClass="fizi.PersonDataEntity">
      <![CDATA[
       DELETE PERSON
       WHERE PER_ID = #id#
      ]]>
</delete>     
</sqlMap>

 

九、/classes/webwork.properties (配置      WebWork )

 

### extension for actions  
webwork.action.extension=action,java,aspx,jhtml  

### Configuration reloading
### This will cause the configuration to reload xwork.xml when it is changed
webwork.i18n.reload=true
webwork.configuration.xml.reload=true

### Load custom default resource bundles
webwork.custom.i18n.resources=default

### character encoding
### webwork.locale=zh_CN
webwork.i18n.encoding=UTF-8

### upload jakarta, temp dir, maxSize = 10M
webwork.multipart.parser=jakarta

### webwork.ui.theme=xhtml
webwork.ui.theme=simple

### WebWork-Spring Integration
webwork.objectFactory = spring
webwork.objectFactory.spring.autoWire = name

 

十、部分代码 PersonDataEntity.java

 

import java.util.Date;

public class PersonDataEntity {
private int id;
private String firstName;
private String lastName;
private Date birthDate;
private double weightInKilograms;
private double heightInMeters;
public int getId () {
return id;
}
public void setId (int id) {
this.id = id;
}
public Date getBirthDate() {
      return birthDate;
}
public void setBirthDate(Date birthDate) {
      this.birthDate = birthDate;
}
public String getFirstName() {
      return firstName;
}
public void setFirstName(String firstName) {
      this.firstName = firstName;
}
public double getHeightInMeters() {
      return heightInMeters;
}
public void setHeightInMeters(double heightInMeters) {
      this.heightInMeters = heightInMeters;
}
public String getLastName() {
      return lastName;
}
public void setLastName(String lastName) {
      this.lastName = lastName;
}
public double getWeightInKilograms() {
      return weightInKilograms;
}
public void setWeightInKilograms(double weightInKilograms) {
      this.weightInKilograms = weightInKilograms;
}
}

 十一、PersonServices.java (要使用iBatis 则需要 继承 类 SqlMapClientDaoSupport )

 

import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;

import com.ibatis.sqlmap.client.SqlMapClient;

public class PersonServices extends SqlMapClientDaoSupport {

public PersonDataEntity GetPerson(Integer pID) {

      return (PersonDataEntity) getSqlMapClientTemplate()
        .queryForObject("selectPerson", pID);
}
}

 

十二、PersonAction.java 在WebWork中方便调用的Action所以需要实现 接口Action

 

import Socket.sclient;

import com.opensymphony.xwork.Action;

public class PersonAction implements Action{
private PersonDataEntity persondataentity = new PersonDataEntity();
private PersonServices personservices;
public String execute() throws Exception {
      // TODO Auto-generated method stub
      Integer pid = new Integer(100001);
      sclient client = new sclient();       //调用Socket,这里你可以不需要(我写的:)
      client.ReadServer();
      persondataentity = personservices.GetPerson(pid);
      if (persondataentity!=null) 
      {
       return SUCCESS;
      }
      else
      {
       return ERROR;
      }
}
public void setPersondataentity(PersonDataEntity persondataentity) {
      this.persondataentity = persondataentity;
}
public void setPersonservices(PersonServices personservices) {
      this.personservices = personservices;
}
public PersonDataEntity getPersondataentity() {
      return persondataentity;
}

}

 

十三、实际调用 PersonAction的 jsp文件 QueryPerson.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//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>Person查询</title>
</head>
<body>
<table border=0 width=97%>
      <tr><td align="left">
       <form name="personaction" action="personaction.action" method="post">
       <form name="personaction" action="personaction.aspx" method="post">
        PersonID:&nbsp;<input type="text" name="persondataentity.id"><br>
        <input type="submit" name="查询"><br>
       </form>
      </td></tr>
</table>
</body>
</html>

 十四、做个简单的查询结果返回页面 person.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"%>
<%@taglib uri="/webwork" prefix="ww" %>
<!DOCTYPE html PUBLIC "-//W3C//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>
</head>
<body>
人员:<label style="color: red;" ><ww:property value='persondataentity.firstName'/></label>查询成功!
</body>
</html>

 
 

标题基于SpringBoot+Vue的学生交流互助平台研究AI更换标题第1章引言介绍学生交流互助平台的研究背景、意义、现状、方法与创新点。1.1研究背景与意义分析学生交流互助平台在当前教育环境下的需求及其重要性。1.2国内外研究现状综述国内外在学生交流互助平台方面的研究进展与实践应用。1.3研究方法与创新点概述本研究采用的方法论、技术路线及预期的创新成果。第2章相关理论阐述SpringBoot与Vue框架的理论基础及在学生交流互助平台中的应用。2.1SpringBoot框架概述介绍SpringBoot框架的核心思想、特点及优势。2.2Vue框架概述阐述Vue框架的基本原理、组件化开发思想及与前端的交互机制。2.3SpringBoot与Vue的整合应用探讨SpringBoot与Vue在学生交流互助平台中的整合方式及优势。第3章平台需求分析深入分析学生交流互助平台的功能需求、非功能需求及用户体验要求。3.1功能需求分析详细阐述平台的各项功能需求,如用户管理、信息交流、互助学习等。3.2非功能需求分析对平台的性能、安全性、可扩展性等非功能需求进行分析。3.3用户体验要求从用户角度出发,提出平台在易用性、美观性等方面的要求。第4章平台设计与实现具体描述学生交流互助平台的架构设计、功能实现及前后端交互细节。4.1平台架构设计给出平台的整体架构设计,包括前后端分离、微服务架构等思想的应用。4.2功能模块实现详细阐述各个功能模块的实现过程,如用户登录注册、信息发布与查看、在线交流等。4.3前后端交互细节介绍前后端数据交互的方式、接口设计及数据传输过程中的安全问题。第5章平台测试与优化对平台进行全面的测试,发现并解决潜在问题,同时进行优化以提高性能。5.1测试环境与方案介绍测试环境的搭建及所采用的测试方案,包括单元测试、集成测试等。5.2测试结果分析对测试结果进行详细分析,找出问题的根源并
内容概要:本文详细介绍了一个基于灰狼优化算法(GWO)优化的卷积双向长短期记忆神经网络(CNN-BiLSTM)融合注意力机制的多变量多步时间序列预测项目。该项目旨在解决传统时序预测方法难以捕捉非线性、复杂时序依赖关系的问题,通过融合CNN的空间特征提取、BiLSTM的时序建模能力及注意力机制的动态权重调节能力,实现对多变量多步时间序列的精准预测。项目不仅涵盖了数据预处理、模型构建与训练、性能评估,还包括了GUI界面的设计与实现。此外,文章还讨论了模型的部署、应用领域及其未来改进方向。 适合人群:具备一定编程基础,特别是对深度学习、时间序列预测及优化算法有一定了解的研发人员和数据科学家。 使用场景及目标:①用于智能电网负荷预测、金融市场多资产价格预测、环境气象多参数预报、智能制造设备状态监测与预测维护、交通流量预测与智慧交通管理、医疗健康多指标预测等领域;②提升多变量多步时间序列预测精度,优化资源调度和风险管控;③实现自动化超参数优化,降低人工调参成本,提高模型训练效率;④增强模型对复杂时序数据特征的学习能力,促进智能决策支持应用。 阅读建议:此资源不仅提供了详细的代码实现和模型架构解析,还深入探讨了模型优化和实际应用中的挑战与解决方案。因此,在学习过程中,建议结合理论与实践,逐步理解各个模块的功能和实现细节,并尝试在自己的项目中应用这些技术和方法。同时,注意数据预处理的重要性,合理设置模型参数与网络结构,控制多步预测误差传播,防范过拟合,规划计算资源与训练时间,关注模型的可解释性和透明度,以及持续更新与迭代模型,以适应数据分布的变化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值