SSM框架搭建

       前言

        本篇文章主要是针对复习之前所学的知识,使用IDEA集成软件下。SSM框架的搭建使用以及内部调用顺序。


一、项目创建

        使用idea创建一个项目,以一个空项目为例。Next>项目名>完成创建之后进入项目。

upload successful

        项目创建好了之后如下图是一个什么都没有的空项目。我们搭建SSM框架需要MyBatis+Spring+SpringMVC所需的各种JAR包。所以我们需要引用JAR包的MAVEN文件(也可以自己导入外部JAR包)

upload successful

upload successfulupload successful
upload successful

        选择Java EE 中的Web Application(WEB项目的需求文件)、Spring(它可以直接帮你下载好需要的Spring相关的JAE包)、Maven(需要导入什么JAR都可以通过Maven)三种。


二、项目配置

        项目创建好之后。还需要配置Tomcat服务器。让他成为一个真正的Web项目。需要配置的地方有两个。

upload successful

        点击Add Configuration,打开窗体点击 +,选择Tomcat Server加载,如果它没有自动扫描到你的Tomcat你需要手动在Application server中进行选择。最后点击Fix关联。保存OK。

upload successful

        第二步,根据第一张图片,说的点击Add Configuration旁边的图标。Project:设置你的JDK、JDK版本、和你需要编译的目录(一般你编译的时候会自动生成)

upload successful

        确定Modules和Facets两个选项中的Web文件设置是否正确,如果不正确或没有需要添加修改

upload successful

        将所有加载或导入的JAR包需要手动添加到Web项目的lib中(SpirngBoot则不需要手动导入)。保存OK

upload successful

运行之后,发现Tomcat已经搭建成功!

upload successful


三、部署SSM

        Tomcat服务器搭建好了之后就可以进行框架的搭建。我们先导入相应的JAR包

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>3.2.13.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>3.2.13.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.29</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.2.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>3.2.13.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.3.0</version>
    </dependency>
    <dependency>
        <groupId>commons-dbcp</groupId>
        <artifactId>commons-dbcp</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>commons-pool</groupId>
        <artifactId>commons-pool</artifactId>
        <version>1.6</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.6.9</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-validator</artifactId>
        <version>4.3.2.Final</version>
    </dependency>
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.4</version>
    </dependency>
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.2.2</version>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.58</version>
    </dependency>
    <dependency>
        <groupId>com.github.pagehelper</groupId>
        <artifactId>pagehelper</artifactId>
        <version>5.1.10</version>
    </dependency>
</dependencies>

        首先我们先配置web.xml。DispatcherServlet是Spring MVC入口,通过Spring配置的url指定的模板(“/“表示所有),所有通过web的文件根据指定的模板都会经过DispatcherServlet。

    <?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" 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_3_0.xsd">
<!--监控器,随着Tomcat启动,访问Spring框架-->
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:springmvc.xml</param-value>
</context-param>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!--前端控制器-->
<servlet>
    <servlet-name>springmvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:springmvc.xml</param-value>
    </init-param>
</servlet>
<servlet-mapping>
    <servlet-name>springmvc</servlet-name>
    <url-pattern>*.do</url-pattern>
</servlet-mapping
</web-app>

        配置springmvc.xml。页面控制器/处理器。根据DispatcherServlet选择页面控制器来进行处理,并把请求委托给它。页面控制器接收请求后,进行业务处理。完毕返回一个ModelAndView。然后根据返回的逻辑视图名,拼接处理器上的前缀后缀选择相应的真正视图。

    <?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-3.2.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.2.xsd">
<!--传输json格式,防止乱码-->
<mvc:annotation-driven>
    <mvc:message-converters>
        <bean class="org.springframework.http.converter.StringHttpMessageConverter">
            <property name="supportedMediaTypes">
                <list>
                    <value>application/json;charset=UTF-8</value>
                </list>
            </property>
        </bean>
        <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">
            <property name="supportedMediaTypes">
                <list>
                    <value>text/html;charset=UTF-8</value>
                    <value>application/json;charset=UTF-8</value>
                </list>
            </property>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>
<!---->
<context:component-scan base-package="com.controller,com.service"/>
<!--过滤静态页面-->
<mvc:resources mapping="/statics/**" location="/statics/"/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/jsp/"/>
    <property name="suffix" value=".jsp"/>
</bean>
</beans>

        创建处理器Controller,@Controller(控制器注解,标注为一个控制器)通过context:component-scan/扫描相应的包、@RequestMapping(负责不同请求映射到对应的控制器方法上)

@Controller
public class LoginController {
@RequestMapping(value = "/index.do")
public String index(){
    System.out.println("首页");
    return "index";
}
}

upload successful

通过之前的配置,文件的位置。现在已经可以通过控制器访问页面了

upload successful

        下面开始连接mybatis访问数据,开始进行完整的SSM的搭建了。添加一个mybatis.xml文件和一个spring-dao.xml文件,springmvc.xml添<import resource="spring-dao.xml"/>导入。所有的配置文件也就配置完了。

<?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>
  <typeAliases>
      <package name="com.pojo"/>
  </typeAliases>
</configuration>

spring-dao.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:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.2.xsd">
    <!--加载配置文件-->
  <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
      <property name="location" value="classpath:data.properties"/>
  </bean>
  <!--数据库连接配置-->
  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
      <property name="driverClassName" value="${driver}"/>
      <property name="url" value="${url}"/>
      <property name="username" value="${username}"/>
      <property name="password" value="${password}"/>
      <property name="maxActive" value="${maxActive}"/>
      <property name="maxIdle" value="${maxIdle}"/>
  </bean>
  <!--装配数据库,扫描*.xml的文件-->
  <bean class="org.mybatis.spring.SqlSessionFactoryBean">
      <property name="dataSource" ref="dataSource"/>
      <property name="configLocation" value="classpath:mybatis.xml"/>
      <property name="mapperLocations">
          <value>classpath:com/dao/**/*.xml</value>
      </property>
  </bean>
  <!--扫描Mapper接口与*.xml关联-->
  <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
      <property name="basePackage" value="com.dao"/>
  </bean>
  </beans>

四、SSM框架访问数据库

        控制器写好代码进行访问数据库,调用Service层,Service直接访问Mapper层接口与Mapper.xml关联进行数据库访问数据库

@Controller
public class LoginController {

@Autowired
private DevUserService devUserService;

@RequestMapping(value = "/index.do")
public String index(){
    System.out.println("首页");
    return "index";
}

@RequestMapping(value = "devlogin.do")
public String devUserLogin(@RequestParam("username")String devName,
                           @RequestParam("password")String password){
    DevUser user= devUserService.devUserLogin(devName);
    if (!EmptyUtils.isEmpty(user)){
        if (user.getDevPassword().equals(password)){
            return "devlogin";
        }
    }
    return "index";
}
}

Service层

  @Service("derUserService")
public class DevUserServiceImpl implements DevUserService {

@Autowired
private DevUserMapper devUserMapper;

public DevUser devUserLogin(String devName) {
    return devUserMapper.devUserLogin(devName);
}
}

dao层

public interface DevUserMapper {
     DevUser devUserLogin(String devName);

}

mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dao.DevUser.DevUserMapper">
    <select id="devUserLogin" resultType="devUser">
        select * from dev_user where devName = #{devName}
    </select>
</mapper>

五、碰见的问题

1)搭建的过程中如果在项目里idea识别不了Tomcat,需要去安装组件——File>Settings。将组件安装进来。

upload successful