SSH 2フレーム構築と配置ファイルの詳細


---------補足説明-----------
記事に記載されているstruts 2の2.2 jarパッケージはすでに最新のものではなく、このバージョンには深刻な脆弱性があります.
今の最新バージョンは2.3.15です.だから.承知してるでしょhttp://struts.apache.org/download.cgi#struts23151
ネット友達の注意に感謝して、今ssh 2の開発をしないで、だからもこの文章を更新することを忘れて、みんなを誤解して導いて、すみません!
SSHフレームワークは、今最も人気のあるプロジェクト開発フレームワークの組み合わせです.彼の第一歩は、どのように環境を配置するかを学ぶことです.Java Webが開発したどのフレームも各種類のxml配置から切り離せません.したがって、このステップが重要です.
SSHはSSH 1とSSH 2に分けられていますが、違いは主にStrutsのバージョン、すなわちStruts 1とStruts 2にあります.Struts 1とStruts 2は配置に違いがあります.
今回は主にStruts 2に基づくSSH 2の枠組みを紹介します.
私たちは枠組みを作る前に、まず各フレームのバージョンに注意しなければなりません.異なるバージョンの集積方式と必要なjarパッケージは違います.
SSH 2フレームのバージョンは、struts-2.23+spring-2.56+hibernate-3.8です.
1.  必要なjar包:猛撃ダウンロード無料jar包資源
struts 2:
struts 2-core-23.2.3.jar
struts 2-spring-plugin-23.2.3.jar
xwork-core-23.2.3.jar
commons-to-2.21.jar
commons-lang-25.jar
commons-fileupload-12.jar
freemarker-23.16.jar
gnl-3.01.jar
javassist-3.12.0.GA.jar(hibernateも同じ必要です.)
スプリング:
spring.jar
commons-loging-11.jar
common-annotations.jar
aspect jrt.jar
aspectjweaver.jar
cglib-nodep-2.1_3.jar
(Baic DataSourceでデータベース接続を設定するなら、次の2つのバッグを追加します.)
commons-dbcp.jar
commons-pool.jar
ヒベルナ:
ヒベルナ3.jar
ヒベルナ-jpa-2.0-api-1.0.1.Final.jar
ANtlr-2.7.6.jar
comons-collection s-31.jar
dom 4 j-1.6.1.jar
javassist-3.12.0.GA.jar
jta-1.11.jar
slaf 4 j-appi-1.6.1.jar
sf 4 j-nop-1.6.44.jar(このjarカバンはsf 4 j公式サイトからsf 4 j-1.6.4パッケージをダウンロードします.)
jdbc:
ojdbc 14.jar(oracle)
2.web.xml設定
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>testSSH</display-name>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  

  <!--      -->
  <context-param>
  	<param-name>contextConfigLocation</param-name>
  	<param-value>classpath:config/applicationContext.xml</param-value>
  </context-param>

  <!--      filter,  spring   -->
  <!-- 
  <filter>
  	<filter-name>myFilter</filter-name>
  	<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
  	<init-param>
  	  <param-name>targetFilterLifecycle</param-name>
  	  <param-value>true</param-value>
  	</init-param>
  	<init-param>
  	  <param-name>encoding</param-name>
  	  <param-value>UTF-8</param-value>
  	</init-param>
  </filter>
  

  <filter-mapping>
  	<filter-name>myFilter</filter-name>
  	<url-pattern>/*</url-pattern>
  </filter-mapping>
   -->
  

  <!--   CharacterEncoding,      -->
  <filter>
  	<filter-name>characterEncodingFilter</filter-name>
  	<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  	<init-param>
  	  <param-name>encoding</param-name>
  	  <param-value>UTF-8</param-value>
  	</init-param>
  	<init-param>
  	  <param-name>forceEncoding</param-name>
  	  <param-value>true</param-value>
  	</init-param>
  </filter>

  <filter-mapping>
  	<filter-name>characterEncodingFilter</filter-name>
  	<url-pattern>/*</url-pattern>
  </filter-mapping>

  <!--  HibernateSession       Filter,        session,  lazy     -->
  <filter>
  	<filter-name>hibernateFilter</filter-name>
  	<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
  	<init-param>
  	  <param-name>singleSession</param-name>
  	  <param-value>true</param-value>
  	</init-param>
  </filter>

  <filter-mapping>
  	<filter-name>hibernateFilter</filter-name>
  	<url-pattern>*.do</url-pattern>
  </filter-mapping>

  
  <!--   struts2 -->
  <filter>
  	<filter-name>struts2</filter-name>
  	<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  	<init-param>
  		<param-name>config</param-name>
  		<param-value>struts-default.xml,struts-plugin.xml,/config/struts.xml</param-value>
  	</init-param>
  </filter>

  <filter-mapping>
  	<filter-name>struts2</filter-name>
  	<url-pattern>/*</url-pattern>
  </filter-mapping>
  

  <!--   spring -->
  <listener>
  	<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  

  <!--   session   -->
  <session-config>
  	<session-timeout>20</session-timeout>
  </session-config>
  

  <!--      -->
  <error-page>
  	<error-code>404</error-code>
  	<location>/error404.html</location>
  </error-page>
</web-app>
 注意:
① カスタムfilterであるDelegating FilterProxyを設定する場合、パラメータtarget FilterLifecycleをtrueにすると、filterをウェブコンテナに入れることが本当の意味でのfilterとなります.それ以外は代理filterだけで、filterのライフサイクルを持たないので、filterのinit、destroy方法を実行できません.統合はspringで管理されているので、springリソース配置ファイル(例えば、appication Contact.xml)に対応していて、myFilterという名前のbeanが必要です.
②OpenSession InView FilterはパラメータsingleSessionをtrueに設定します.そうでないと意味が大きくありません.
③struts 2の設定は、Struts PrepareAndExecute Filterを採用することを推奨します.struts.xmlはデフォルトでsrcルートディレクトリの下に置いて、他のところに置きたいならstruts-default.xmlとstruts-plugin.xmlを一緒に配置してください.他のフレームが結合している時にエラーが発生します.struts 2を配置するfilterラベルはすべてのfilterタグの一番下に置くべきです.そうでないと問題があります.
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>
	<!--  Action     spring    -->
	<constant name="struts.objectFactory" value="spring" />

	<!--   struts2  Action    ,   action。      ,  ","   -->
	<constant name="struts.action.extension" value="do"></constant>

	<package name="struts" namespace="/" extends="struts-default">
		<!--       -->
		<interceptors>
			<interceptor name="myInterceptor" class="myInterceptor"></interceptor>
			<interceptor-stack name="myDefult">
				<interceptor-ref name="myInterceptor"></interceptor-ref>
				<interceptor-ref name="defaultStack"></interceptor-ref>
			</interceptor-stack>
		</interceptors>

		<action name="myLogin" class="loginAction">
			<result name="success">/success.jsp</result>
			<result name="error" type="redirect">/index.jsp</result>
		</action>

		<action name="testSession" class="sessionAction">
			<interceptor-ref name="myDefult"></interceptor-ref>
			<result name="success">/success.jsp</result>
			<result name="error" type="redirect">/login.jsp</result>
		</action>
	</package>
</struts>
注意:
①カスタムブロックを実行した後、struts 2のデフォルトブロックdefault Stockを実行します.そうでないとエラーが発生する可能性があります.
②actionタグのクラス属性は、springと結合してspringのbeanの名称nameとします.
4. appication Contect.xml
<?xml version="1.0" encoding="UTF-8"?>
<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:context="http://www.springframework.org/schema/context"
	xmlns:tx="http://www.springframework.org/schema/tx"
	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-2.5.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
	<!--   spring     -->
	<context:annotation-config/>
	
	<!--        sessionFactory -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="configLocation" value="classpath:config/hibernate.cfg.xml"></property>
	</bean>
	
	<!--        sessionFactory
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
		<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
		<property name="url" value="jdbc:oracle:thin:@localhost:1521:wang"/>
		<property name="username" value="wang"/>
		<property name="password" value="wang"/>
	</bean>
	
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="dataSource" ref="dataSource"/>
		
		<property name="hibernateProperties">
			<props>
				<prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
				<prop key="hibernate.show_sql">true</prop>
			</props>
		</property>
		
		<property name="mappingLocations">
			<list>
				<value>classpath:test/entity/User.hbm.xml</value>
			</list>
		</property>
	</bean>
	 -->
	
	<!--           -->
	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory"/>
	</bean>
	
	<tx:advice id="txadvice" transaction-manager="transactionManager">
		<tx:attributes>
			<tx:method name="add*" propagation="REQUIRED" rollback-for="Exception"/>
			<tx:method name="del*" propagation="REQUIRED" no-rollback-for="MyException"/>
			<tx:method name="update*" propagation="REQUIRED"/>
			<tx:method name="*" propagation="REQUIRED" read-only="true"/>
		</tx:attributes>
	</tx:advice> 
	
	<aop:config>
		<aop:pointcut id="daoMethods" expression="execution(* test.dao.*.*(..))"/>
		<aop:advisor advice-ref="txadvice" pointcut-ref="daoMethods"/>
	</aop:config>
	
	<!--          
	<bean id="transactionProxy" class= "org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">
	   true CGLIB       DAO  
        <property name="proxyTargetClass" value="true" />
        <property name="transactionManager" ref="transactionManager" />
        <property name="transactionAttributes">
            <props>
            	<prop key="add*">PROPAGATION_REQUIRED, -Exception</prop>
            	<prop key="del*">PROPAGATION_REQUIRED, +MyException</prop>
            	<prop key="update">PROPAGATION_REQUIRED</prop>
                <prop key="*">PROPAGATION_REQUIRED, readOnly</prop>
            </props>
        </property>
	</bean>

	<bean id="userService" parent="transactionProxy">
		<property name="target" ref="iUserService"></property>
	</bean>
	
	<bean id="iUserService" class="test.service.UserServiceImpl"></bean>
	 -->
	
	<bean id="userService" class="test.service.UserServiceImpl"></bean>
	
	<bean id="userDao" class="test.dao.UserDaoImpl">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>
	
	<!-- spring      filter -->
	<bean id="myFilter" class="test.service.MyFilter"></bean>
	
	<!-- spring  struts2 Action -->
	<bean id="loginAction" class="test.action.LoginAction" scope="prototype"></bean>
	<bean id="sessionAction" class="test.action.SessionAction" scope="prototype"></bean>
	<bean id="myInterceptor" class="test.service.MyInterceptor" scope="prototype"></bean>
</beans>
注意:
①事務を配置する場合、session Factoryを含むDAO層に事務が関連している場合は、タグのproxy-targt-class属性をtrueとします.(第二の方法はproxyTarget Class属性です.)そうでないとエラーが発生します.
②ResourceまたはAutowiredコメントを採用する場合、beanにはproperty属性ラベルを配置する必要がありません.
③session Factoryを第二の方法で配置する場合は、他に二つのパッケージを導入する必要があります.
5.filterとブロック
●MyFilter.java
package test.service;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

public class MyFilter implements Filter {

	private String encoding;

	@Override
	public void destroy() {

	}

	@Override
	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
		request.setCharacterEncoding(encoding);
		response.setCharacterEncoding(encoding);
		chain.doFilter(request, response);
	}

	@Override
	public void init(FilterConfig config) throws ServletException {
		System.out.println("========" + config.getInitParameter("encoding") + "========");
		encoding = config.getInitParameter("encoding");
	}
}
●MyInterceptor.java
package test.service;

import java.util.Map;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

@SuppressWarnings("serial")
public class MyInterceptor implements Interceptor{

	@Override
	public void destroy() {
		
	}

	@Override
	public void init() {
		
	}

	@Override
	public String intercept(ActionInvocation invocation) throws Exception {
		Map sessionMap = invocation.getInvocationContext().getSession();
		String username = (String)sessionMap.get("username");
		
		if (username != null) {
			return invocation.invoke();
		}
		return "error";
	}

}
filterとブロックの違い:
両者は構造的にも機能的にも非常に似ていますが、両者には違いがあります.
①filterはservlet容器に基づいていますが、interceptorはstruts 2に限られていますので、filterの作用域はinterceptorよりも遥かに大きいです.
②filterのdofilter方法はコールバック関数に基づいていますが、interceptrのintercept方法はjava反射に基づいています.
③filterの機能はinterceptorより大きくなければなりません.filterはフィルタ要求以外に、ワイルドカードでページ、画像、ファイルを保護できます.暗号化、安全フィルタ、権限管理などもできます.Interceptorは基本的にフィルタ要求しかできません.
④filterブロッキング要求の粒径が粗く、interceptorブロッキング要求の粒径が細い.
6.action層
●LoginnAction.java
package test.action;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;

import org.apache.struts2.ServletActionContext;

import test.entity.User;
import test.service.IUserService;

import com.opensymphony.xwork2.ActionSupport;

@SuppressWarnings("serial")
public class LoginAction extends ActionSupport {
	
	@Resource
	private IUserService userService;
	
	private String username;

	private String password;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	@Override
	public String execute() throws Exception {
		User user = new User();
		user.setUsername(username);
		user.setPassword(password);
		try {
			userService.addUser(user);
			HttpServletRequest request = ServletActionContext.getRequest();
			request.getSession().setAttribute("username", username);
			return "success";
		} catch (Exception e) {
			e.printStackTrace();
		}
		return "error";
	}
}
7.サービス層
●UserServiceImpl.java
package test.service;

import java.util.List;

import javax.annotation.Resource;

import test.dao.IUserDao;
import test.entity.User;

public class UserServiceImpl implements IUserService{
	
	@Resource
	private IUserDao userDao;

	@Override
	public void addUser(User user) throws Exception {
		userDao.addUser(user);
		if (!"admin".equals(user.getUsername()) || !"admin".equals(user.getPassword())) {
			throw new Exception();
		}
	}

	@Override
	public boolean updateUser(User user) {
		return false;
	}

	@Override
	public boolean delUser(String username) {
		return false;
	}

	@Override
	public List<User> findAllUser() {
		return null;
	}
}
インターフェースは簡単なので、展示しません.ここでfilterとブロックもservice層に置いています.例だけです.filterまたはinterceptorは単独で一階に置くのがいいです.
8.ダオ層
●UserDaoImpl.java
package test.dao;

import java.util.Date;

import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import test.entity.User;

public class UserDaoImpl extends HibernateDaoSupport implements IUserDao{

	@Override
	public void addUser(User user){
		user.setName("wang");
		user.setCreateTime(new Date());
		user.setModifyTime(new Date());
		this.getHibernateTemplate().save(user);
	}
}
9.entity層
package test.entity;

import java.util.Date;

public class User {

	private String username;
	
	private String password;
	
	private String name;
	
	private String email;
	
	private String tell;
	
	private Date createTime;
	
	private Date modifyTime;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getEmail() {
		return email;
	}

	public void setEmail(String email) {
		this.email = email;
	}

	public String getTell() {
		return tell;
	}

	public void setTell(String tell) {
		this.tell = tell;
	}

	public Date getCreateTime() {
		return createTime;
	}

	public void setCreateTime(Date createTime) {
		this.createTime = createTime;
	}

	public Date getModifyTime() {
		return modifyTime;
	}

	public void setModifyTime(Date modifyTime) {
		this.modifyTime = modifyTime;
	}
}