>  기사  >  Java  >  [자바 튜토리얼] SSM: 환경 설정

[자바 튜토리얼] SSM: 환경 설정

php是最好的语言
php是最好的语言원래의
2018-08-09 17:13:512256검색

SSM 환경 구축

  1. 디렉토리 생성

  2. pom. Struts

  3. service의 작업과 동일: 비즈니스 로직 레이어-> 내부 다른 패키지 .impl 생성(예: com.imooc.Project name.service.impl)

dao: 주로 데이터베이스 처리, 파일 읽기 쓰기 작업, Redis 캐시 작업 및 기타 데이터 관련 작업. mybatis를 사용하면 구성 파일의 인터페이스를 구현하는 방법이 resources.mapper에 있으므로 impl 패키지에서 빌드할 필요가 없습니다.

    dto: 주로 레이어를 캡슐화하여 엔터티의 단점을 보완합니다.
  • enums: 열거형을 저장합니다. 예를 들어
  • interceptor: 인터셉터
  • util: 일반 도구 클래스 저장소
  • 1.2 src/main/resources
  • mapper: 각각에 해당하는 SQL을 저장합니다. DAO의 메서드, DAO 구현 클래스를 작성할 필요 없음
  • spring: spring 구성 파일 저장
  • 1.3 src/test 테스트 저장
  • java

    resources
  • 2. xml 구성
  • jar 패키지를 쿼리할 수 있습니다. :http://mvnrepository.com/

  • 2.1 테스트 jar 패키지

junit: 범위06db57cb000bdd2564c5b32a302b10e2test03b1008234ba0cf6ad3c873aea327e8a

    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>
    2.2 로그 jar 패키지
  • logback

        <dependency>
          <groupId>ch.qos.logback</groupId>
          <artifactId>logback-classic</artifactId>
          <version>1.2.3</version>
        </dependency>
  • 2.3 Spring 관련 jar 패키지
  • 2.3.1 spring-core

  • Spring 프레임워크의 기본 핵심 도구 클래스입니다. 다른 Spring 컴포넌트는 이 패키지의 클래스를 사용해야 합니다. 다른 컴포넌트의 기본 핵심

2.3.2 spring-beans

은 구성 파일 액세스, Bean 생성 및 관리, IOS/DI 작업 수행을 포함하여 모든 애플리케이션에서 사용해야 합니다. .모든 관련 수업. Java와 유사한 반사 메커니즘

애플리케이션에 기본 IOC/DI 지원만 필요한 경우 spring-core.jar 및 spring-beans.jar 파일을 도입하면 됩니다.

2.3.3 spring-context

Spring을 위한 다양한 확장 제공 , Spring ApplicationContext 기능을 사용하는 데 필요한 모든 클래스, 계측 구성 요소 및 검증 관련 클래스를 찾을 수 있습니다

2.3.4 spring-jdbc

Spring이 JDBC 데이터 액세스를 캡슐화하는 모든 클래스

2.3.5 spring-tx

제공 JDBC, Hibernate, JDO, JPA 등에 대한 일관된 선언적 및 프로그래밍 방식 트랜잭션 관리

2.3.6 spring-web

WebApplicationContext 자동 로드

2.3을 포함하여 웹 애플리케이션을 개발할 때 Spring 프레임워크를 사용할 때 필요한 핵심 클래스가 포함되어 있습니다. 7 spring-webmvc

SpringMVC 프레임워크와 관련된 모든 클래스가 포함되어 있으며, 더 중요한 클래스는 Dispatcher-servlet입니다

2.3.8 spring-test

JUNIT와 같은 테스트 프레임워크의 간단한 캡슐화

범위 지정:

2.4 데이터베이스 관련 jar 패키지 소개

2.4.1 mybatis

mybatis의 기본 클래스 라이브러리 포함

2.4.2 mybatis-spring

Spring 프레임워크 연결

2.4.3 mysql -connector-java

JDBC와 MySQL 간의 상호 작용을 지원합니다.

2.4.4 c3p0

연결 풀

2.5 기타 jar 패키지

2.5.1 javax.servlet-api

서블릿 제공

2.5.2 jackson -databind

서비스는 JSON을 구문 분석하는 데 사용됩니다. SpringMVC의 컨트롤러는 프런트 엔드와 상호 작용할 때 JSON 구문 분석

2.5.6 commons-collections

Map 도구 클래스가 많은 경우에 사용됩니다. JAVA 컬렉션

spring-core.jar에는 기본 클래스 지원을 제공하기 위해 commons-collections.jar이 필요합니다

2.6 수정이 필요한 pom.xml의 전체 부분

maven 프로젝트의 pom.xml 파일을 생성합니다

① 채우기 방금 지침에서 필수 jar 패키지 종속성


    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>
    
    <dependency>
      <groupId>ch.qos.logback</groupId>
      <artifactId>logback-classic</artifactId>
      <version>1.2.3</version>
    </dependency>
    
    
    
      org.springframework
      spring-core
      ${spring.version}
    
    
    
      org.springframework
      spring-beans
      ${spring.version}
    
    
    
      org.springframework
      spring-context
      ${spring.version}
    
    
    
      org.springframework
      spring-jdbc
      ${spring.version}
    
    
    
      org.springframework
      spring-tx
      ${spring.version}
    
    
    
      org.springframework
      spring-web
      ${spring.version}
    
    
    
      org.springframework
      spring-webmvc
      ${spring.version}
    
    
    
      org.springframework
      spring-test
      ${spring.version}
      test
    
    
    
      javax.servlet
      javax.servlet-api
      3.1.0
    
    
    
      com.fasterxml.jackson.core
      jackson-databind
      2.8.7
    
    
    
      commons-collections
      commons-collections
      3.2
    
    
    
      org.mybatis
      mybatis
      3.4.2
    
    
      org.mybatis
      mybatis-spring
      1.3.1
    
    
    
      mysql
      mysql-connector-java
      5.1.37
    
    
      c3p0
      c3p0
      0.9.1.2
    
    
    
    
      net.coobird
      thumbnailator
      0.4.8
    
    
    
      com.github.penggle
      kaptcha
      2.3.2
    
    
      commons-fileupload
      commons-fileupload
      1.3.2
    
    
    
      redis.clients
      jedis
      2.9.0
    
  

② 6ca16768ab454cb0c0b46f79456f85f6 앞에 spring.version 문

  <properties>
    <spring.version>4.3.7.RELEASE</spring.version>
  </properties>

을 입력하세요.

3. SSM 레이어별 구성

jdbc.properties

mybatis-config.xml

spring-dao.xml, spring-service.xml, spring-web.xml


web.xml

3.1 jdbc.properties

    데이터베이스 구성 파일은 다음 위치에 생성됩니다. src/main/resources 디렉토리에 있는 파일 내용은 다음과 같습니다.
  1. jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/{填写项目名}?useUnicode=true&characterEncoding=utf8
    jdbc.username={databases的username}
    jdbc.password={databases的password}

    계좌번호와 비밀번호를 임시로 평문으로 작성합니다.

  2. jdbc는 mysql.jdbc.Driver 드라이버를 사용하여 jdbc.url 주소의 데이터베이스에 액세스하고 사용자 이름과 비밀번호를 사용하여 MySQL에 연결합니다.
  3. 3.2 mybatis-config.xml

  4. mybatis 구성 파일은 src/main/resources 디렉터리에 생성됩니다. 파일 내용은 다음과 같습니다.
  5. <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE configuration
      PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
        <!-- 配置全局属性 -->
        <settings>
            <!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
            <setting name="useGeneratedKeys" value="true" />
    
            <!-- 使用列标签替换列别名 默认:true -->
            <setting name="useColumnLabel" value="true" />
    
            <!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
            <setting name="mapUnderscoreToCamelCase" value="true" />
        </settings>
    </configuration>

    3.3 Spring 관련 구성

  6. 은 src/main/resources에 저장됩니다. /spring 디렉토리
  7. 3.3.1 spring-dao.xml 만들기

jdbd 구성 파일 읽기

데이터베이스 연결 풀 구성

데이터베이스 연결 풀 개체 만들기 [내부 패키지 이름 수정 참고]

어떤 구성이 필요한가요? 패키지는 DAO 레이어를 스캔하고 자동으로 생성된 연결 풀 개체를 해당 레이어에 전달합니다. [내부 패키지 이름 수정에 유의하세요]

注意包名的填写:我用中文写了的位置,IDE会标红
<?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: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/context
    http://www.springframework.org/schema/context/spring-context.xsd">
    <!-- 配置整合mybatis过程 -->
    <!-- 1.配置数据库相关参数properties的属性:${url} -->
    <context:property-placeholder location="classpath:jdbc.properties"/>
    <!-- 2.数据库连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 配置连接池属性 -->
        <property name="driverClass" value="${jdbc.driver}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <!-- c3p0连接池的私有属性 -->
        <property name="maxPoolSize" value="30" />
        <property name="minPoolSize" value="10" />
        <!-- 关闭连接后不自动commit -->
        <property name="autoCommitOnClose" value="false" />
        <!-- 获取连接超时时间 -->
        <property name="checkoutTimeout" value="10000" />
        <!-- 当获取连接失败重试次数 -->
        <property name="acquireRetryAttempts" value="2" />
    </bean>

    <!-- 3.配置SqlSessionFactory对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
        <!-- 配置MyBaties全局配置文件:mybatis-config.xml -->
        <property name="configLocation" value="classpath:mybatis-config.xml" />
        <!-- 扫描entity包 使用别名 -->
        <property name="typeAliasesPackage" value="{实体类包所在的位置}" />
        <!-- 扫描sql配置文件:mapper需要的xml文件 -->
        <property name="mapperLocations" value="classpath:mapper/*.xml" />
    </bean>

    <!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
        <!-- 给出需要扫描Dao接口包 -->
        <property name="basePackage" value="{找到需要填写的dao包}" />
    </bean>
</beans>

3.3.2 spring-service.xml

  1. 扫描Service包下所有使用注释的类型 [注意填写包名]

  2. 配置事务管理器:多个DAO的协同操作,保证操作的原子性

  3. 配置基于注解的声明式事务

<?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: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/context
    http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="{service包所在的目录,如com.cat.o2o.service}" />

    <!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
    </bean>

    <!-- 配置基于注解的声明式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" />
</beans>

3.3.3 spring-web.xml

  • 开启Spring注解模式,自动实现Controller,不用做bean的配置

  • 静态资源默认servlet配置,需要在webapp下创建resource目录,图片等静态资源存放位置

  • 视图解析器配置

  • 扫描controller所在的包[需要填写你的controller所在的包]

文件内容如下:

<?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:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/mvc
    http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd">
    <!-- 配置SpringMVC -->
    <!-- 1.开启SpringMVC注解模式 -->
    <mvc:annotation-driven />

    <!-- 2.静态资源默认servlet配置 (1)加入对静态资源的处理:js,gif,png (2)允许使用"/"做整体映射 告知SpringMVC的核心类dispatcher-servlet不要对此拦截,交由默认的servlet-handler处理-->
    <mvc:resources mapping="/resources/**" location="/resources/" />
    <mvc:default-servlet-handler />

    <!-- 3.定义视图解析器 -->
    <bean id="viewResolver"
          class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/html/"></property>
        <property name="suffix" value=".html"></property>
    </bean>

    <!-- 4.扫描web(放置controller的包)相关的bean -->
    <context:component-scan base-package="需要修改的地方" />

</beans>

3.4 配置web.xml

  • 配置index文件,暂时默认即可

  • 配置SpringMVC的Servlet,注意填写初始参数(指定目录)

  • 配置Servlet-mapping,默认匹配所有的请求(url-pattern填写/即可)

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
                      http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1" metadata-complete="true">
  <display-name>Archetype Created Web Application</display-name>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>spring-dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring/spring-*.xml</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>spring-dispatcher</servlet-name>
    <!-- 默认匹配所有的请求 -->
    <url-pattern>/</url-pattern>
  </servlet-mapping>
</web-app>

相关推荐:

JavaWeb环境搭建

PHP环境搭建要点

위 내용은 [자바 튜토리얼] SSM: 환경 설정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.