多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > htmlcss > Struts2+Spring4+myBatis3整合

Struts2+Spring4+myBatis3整合

來源:程序員人生   發布時間:2016-10-08 15:45:01 閱讀次數:3170次

終究開始整合了,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">
<property name="configLocation" value="classpath:MyBatis.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
,用于創建工廠Bean。
<bean id="userDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
<property name="mapperInterface" value="gyt.frame.first.UserDao" />
</bean>
,創建dao bean(只需提供接口不需提供實現類 )。學習于http://blog.csdn.net/hupanfeng/article/details/21454847。

配置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
超級感謝。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 日本大片免费播放网站 | 成人卡通精品卡通动漫第一页 | 最新国产在线观看福利 | 国产精品福利在线观看 | 亚洲 成人 欧美 自拍 | 国产一级做a爰片久久毛片99 | 国产v欧美v日本v精品 | 日本不卡视频 | 久久久久亚洲国产 | 久久新网址 | 亚洲综合国产一区在线 | 国产精品久久一区一区 | 国产精品久久久久天天影视 | 在线视频精品视频 | 欧美一级淫片漂亮的老师 | 国产精品成人久久久久 | 亚洲第一区在线 | 国产在线视频一区二区三区 | 欧美在线视频不卡 | 欧美精品免费一区欧美久久优播 | 久久久精品成人免费看 | a级淫片| 一二三四视频免费观看在线看1 | 亚洲五月网 | 国产91精品黄网在线观看 | 日韩欧美亚洲在线 | 久久精品国内一区二区三区 | 久久综合欧美成人 | 黄色网址网站 | 一二三四免费手机在线观看视频 | 久久不卡一区二区三区 | 亚洲五月婷婷 | 国产在线精品一区二区三区 | 国产精品久久久久久久久久久久久久 | 国产农村妇女毛片精品久久 | 亚洲一区二区三区高清不卡 | 日本孕妇大胆孕交无码 | 国产亚洲精品久久久久久久久激情 | 国产69精品久久久久99 | 午夜网站在线播放 | 欧美 亚洲 激情 |