終究開始整合了,3大工具各司其職。Struts負責與jsp交互,Spring針對javaBean的生命周期進行管理,myBatis負責數據庫部份。
個人認為整合最重要的是找對相應的包,不然包之間便可能出現沖突,然后1直報錯。以下是千辛萬苦測試成功的包:
配置web.xml
<?xml version="1.0" encoding="UTF⑻"?>
<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">
<display-name></display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!-- spring 加載文件配置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- spring監聽器配置 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 設置spring字符編碼過濾器 -->
<filter>
<filter-name>characterEncoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF⑻</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- 配置Struts2 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
配置applicationContext.xml
<?xml version="1.0" encoding="UTF⑻"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 采取注解的方式配置bean -->
<context:annotation-config />
<!-- 配置要掃描的包 -->
<context:component-scan base-package="gyt.frame.first"></context:component-scan>
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:MyBatis.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="url" value="jdbc:mysql://localhost:3306/SSM" />
<property name="username" value="root" />
<property name="password" value="123456" />
<property name="maxActive" value="100" />
<property name="maxIdle" value="5" />
<property name="minEvictableIdleTimeMillis" value="300000" />
<property name="timeBetweenEvictionRunsMillis" value="120000" />
<property name="validationQuery" value="SELECT 1" />
<property name="testWhileIdle" value="true" />
<property name="testOnReturn" value="true" />
<property name="testOnBorrow" value="true" />
</bean>
<bean id="userDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
<property name="mapperInterface" value="gyt.frame.first.UserDao" />
</bean>
<!-- 配置mybatis數據處理的方式,共4種方式,這里采取MapperScannerConfigurer方式 -->
<!-- SqlSessionTemplate 這個需要寫配置文件,在實現類中注入sqlsession,再使用sqlsession,是細顆粒控制
SqlSessionDaoSupport 這個只需要在實現類中繼承特殊類就能夠使用sqlsession MapperFactoryBean 這個要寫配置文件,把對應的所有接口在配置文件中援用便可,無需寫實現類
MapperScannerConfigurer 這個要寫配置文件,只要給出接口所在的包便可,會自動把包中的接口引入,無需寫實現類 -->
<!-- jdbc初始化數據庫 -->
<!-- <jdbc:initialize-database data-source="dataSource" ignore-failures="NONE"
enabled="true"> <jdbc:script encoding="utf⑻" location="/WEB-INF/db-init.sql"/>
</jdbc:initialize-database> -->
<!-- 配置哪些方法用甚么樣的事務,配置事務的傳播特性 -->
<!-- <tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes> <tx:method name="add" propagation="REQUIRED"/> </tx:attributes>
</tx:advice> <aop:config> <aop:pointcut id="pointcut" expression="execution(*
D1.serviceimpl.UserServiceImpl.*(..))" /> <aop:advisor advice-ref="log" pointcut-ref="pointcut"/>
</aop:config> -->
<!-- 配置結束 -->
</beans>
applicationContext.xml里的重點:
⑴<context:annotation-config />
,寫了這句話才能使用注解的方式配置Bean。
⑵<context:component-scan base-package="gyt.frame.first"></context:component-scan>
,配置需要掃描的包。如果某個類的頭上帶有特定的注解@Component,@Repository,@Service,@Controller,就會將這個對象作為Bean注冊進Spring容器。掃描多個包用逗號隔開。
⑶<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
,用于創建工廠Bean。
<property name="configLocation" value="classpath:MyBatis.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
⑷<bean id="userDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
,創建dao bean(只需提供接口不需提供實現類 )。學習于http://blog.csdn.net/hupanfeng/article/details/21454847。
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
<property name="mapperInterface" value="gyt.frame.first.UserDao" />
</bean>
配置struts.xml
<?xml version="1.0" encoding="UTF⑻" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
"http://struts.apache.org/dtds/struts⑵.1.dtd">
<struts>
<!-- 指定默許編碼集 ,作用于HttpServletRequest的setCharacterEncoding()和freemarker,vilocity的輸出 -->
<constant name="struts.i18n.encoding" value="UTF⑻"/>
<!-- 當struts配置文件修改時是不是自動加載 -->
<constant name="struts.configuration.xmlreload" value="true"/>
<!-- 開發模式下打印詳細的毛病信息,默許為false -->
<constant name="struts.devMode" value="true"/>
<!-- 標準的UI主題,默許的UI主題為xhtml,可以為simple,xhtml或ajax -->
<constant name="struts.ui.theme" value="xhtml"/>
<package name="test" namespace="/test" extends="struts-default">
<action name="hello" class="gyt.frame.first.HelloAction">
<result name="success">/jsps/HelloAction.jsp</result>
</action>
</package>
<package name="user" namespace="/user" extends="struts-default">
<action name="UserAction" class="gyt.frame.first.UserAction">
<result name="success">index.jsp</result>
</action>
</package>
</struts>
配置myBatis.xml
<?xml version="1.0" encoding="UTF⑻"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis⑶-config.dtd">
<configuration>
<!-- 映照文件,寄存sql語句的配置文件 -->
<mappers>
<mapper resource="gyt/frame/first/UserMappers.xml" />
</mappers>
</configuration>
配置log4j.properties
log4j.rootLogger=info,A1
log4j.logger.com.mchange=warn,A1
log4j.additivity.com.mchange=false
log4j.logger.org.hibernate=warn,A1
log4j.additivity.org.hibernate=false
log4j.logger.com.ibatis=warn,A1
log4j.additivity.com.ibatis=false
# ConsoleAppender
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss,SSS} [%c]-[%p] %m%n
# \u6253\u5370sql
log4j.logger.org.apache.ibatis=debug
log4j.logger.java.sql.Connection=debug
log4j.logger.java.sql.Statement=debug
log4j.logger.java.sql.PreparedStatement=debug
log4j.logger.java.sql.ResultSet=debug
#com.frame
log4j.logger.com.frame=debug
創建表
CREATE TABLE `user` (
`UserNo` varchar(10) NOT NULL,
`DepartmentNo` varchar(10) DEFAULT NULL,
`UserName` varchar(10) DEFAULT NULL,
`Password` char(16) DEFAULT NULL,
`Email` varchar(40) DEFAULT NULL,
PRIMARY KEY (`UserNo`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
新建1個action類UserAction.java
/*
Action注解單例問題
交有spring管理后,action默許是單例模式。但是項目不能全部都采取單例,使用我們需要加入相干注解切換為非單例:
在action上面配置,@Scope("prototype") ,每一個要求都會new1個新的實例
*/
@Controller
@Scope("prototype")
public class UserAction extends ActionSupport {
/**
*
*/
private static final long serialVersionUID = 1L;
@Autowired
//@Resource(name="userservice")
private UserService userservice;// 使用@Autowired,要寫setter方法。
private User user=new User();//不寫New,將報空指針
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public UserService getUserservice() {
return userservice;
}
public void setUserservice(UserService userservice) {
this.userservice = userservice;
}
public static long getSerialversionuid() {
return serialVersionUID;
}
public String insert(){
user.setUserNo(user.getUserNo());
user.setDepartmentNo(user.getDepartmentNo());
user.setUserName(user.getUserName());
user.setPassword(user.getPassword());
user.setEmail(user.getEmail());
System.out.println(user.getUserName()+" insert");
this.userservice.insert(user);
return SUCCESS;
}
}
dao接口
UserDao.java
@Repository
@Transactional
public interface UserDao {
public void insert(User user);
}
UserMappers.xml
<?xml version="1.0" encoding="UTF⑻"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis⑶-mapper.dtd">
<mapper namespace="gyt.frame.first.UserDao">
<insert id="insert">
insert into User (UserNo,DepartmentNo,UserName,Password,Email) values(
#{UserNo,jdbcType=VARCHAR},
#{DepartmentNo,jdbcType=VARCHAR},
#{UserName,jdbcType=NUMERIC},
#{Password,jdbcType=VARCHAR},
#{Email,jdbcType=VARCHAR})
</insert>
</mapper>
這里注意namespace不要寫錯,id為類里面的某個方法。不然會報錯。
service接口UserService.java
public interface UserService {
public void insert(User user);
}
service實現類
/*
Bean注解管理
Spring自動掃描管理Bean注解有4種配置模式,以下
@Service 用于業務層(service) 示例:@Service("baseService")
@Controller 用于控制層(action) 示例:@Controller("baseAction")
@Repository 用于數據訪問層(dao) 示例:@Repository("baseDao")
@Component 泛型配置(當組件不肯定時用),以上3種配置是基于此擴大
*/
/*
@Service自動裝配到Spring的容器,為其他組件提供服務;
通過@Transactional進行事務的管理;
通過@Resource注入UserDao對象。
*/
@Service
@Transactional
public class UserServiceImpl implements UserService{
@Autowired
private UserDao userdao;
public void insert(User user) {
this.userdao.insert(user);
}
}
user.jsp
<body>
<!-- <form action="user/UserAction!insert.action">
編號:<input name="UserNo"><br>
部門編號:<input name="DepartmentNo"><br>
姓名:<input name="UserName"><br>
密碼:<input name="Password"><br>
郵箱:<input name="Email"><br>
<input type="submit" value="肯定">
</form>-->
<form action="user/UserAction!insert.action">
編號:<input name="user.UserNo"><br>
部門編號:<input name="user.DepartmentNo"><br>
姓名:<input name="user.UserName"><br>
密碼:<input name="user.Password"><br>
郵箱:<input name="user.Email"><br>
<input type="submit" value="肯定">
</form>
</body>
此進程學習于 http://blog.csdn.net/yunsyz/article/details/17187659
超級感謝。
上一篇 單向散列加密
下一篇 [置頂] ELK(ElasticSearch, Logstash, Kibana)+ SuperVisor + Springboot + Logback 搭建實時日志分析平臺