二、SSM框架制作CRM系统案例

一、搭建框架

        1、首先创建下面的目录结构
        

        2、添加相关依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.ssm.crm</groupId>
    <artifactId>crm</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>war</packaging>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.7</maven.compiler.source>
        <maven.compiler.target>1.7</maven.compiler.target>
    </properties>

    <dependencies>

        <!-- MySQL数据库连接驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.21</version>
        </dependency>

        <!-- JDBC数据源连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.1</version>
        </dependency>

        <!-- MyBatis框架依赖 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.1</version>
        </dependency>

        <!-- Spring框架依赖的JAR配置 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aop</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-oxm</artifactId>
            <version>4.3.9.RELEASE</version>
        </dependency>

        <!-- Spring AOP支持-->
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.9</version>
        </dependency>

        <!-- MyBatis与Spring整合依赖 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.0</version>
        </dependency>

        <!-- servlet及jstl标签库依赖的JAR配置 -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp.jstl</groupId>
            <artifactId>jstl-api</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.taglibs</groupId>
            <artifactId>taglibs-standard-spec</artifactId>
            <version>1.2.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.taglibs</groupId>
            <artifactId>taglibs-standard-impl</artifactId>
            <version>1.2.1</version>
        </dependency>

        <!-- 加载jackson插件依赖 -->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.7.3</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.7.3</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.7.3</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.module</groupId>
            <artifactId>jackson-module-jaxb-annotations</artifactId>
            <version>2.2.3</version>
        </dependency>

        <!--poi依赖-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.15</version>
        </dependency>

        <!-- 文件上传 -->
        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.3.1</version>
        </dependency>

        <!-- Log4j2依赖的JAR配置 -->
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-jcl</artifactId>
            <version>2.3</version>
        </dependency>



        <!-- google java lib -->
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>17.0</version>
        </dependency>
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>17.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.3.2</version>
        </dependency>

        <!-- xstream xml -->
        <dependency>
            <groupId>com.thoughtworks.xstream</groupId>
            <artifactId>xstream</artifactId>
            <version>1.4.7</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <!-- tomcat7插件 -->
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.1</version>
                <configuration>
                    <port>8080</port>
                    <path>/</path>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>7</source>
                    <target>7</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

       

        3、springmvc.xml   springmvc配置文件:

<?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"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
		http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd">

    <!-- 启用注解驱动 -->
    <!-- 用于启用注解驱动。它支持 @RequestMapping、@Controller 等注解的使用,让 Spring MVC 自动识别注解的控制器并处理映射关系 -->
    <mvc:annotation-driven/>


    <!-- 配置组件扫描 -->
    <!-- 扫描controller包下面的所有的类,注入到springmvc中
         也可以使用 <context:include-filter /> 选择过滤只包含@controller注解的类 -->
    <context:component-scan base-package="com.ssm.crm.controller"/>


    <!-- 配置视图解析器 -->
    <!-- InternalResourceViewResolver 是 Spring MVC 内置的视图解析器之一。
         配置 prefix 和 suffix 后,Spring MVC 会将控制器返回的视图名称拼接成文件路径。
         例如,如果控制器返回 home,则解析器会将其映射到 /WEB-INF/views/home.jsp。-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"/>
        <property name="suffix" value=".jsp"/>
    </bean>



    <!-- 配置静态资源处理 -->
    <!-- mvc:resources 用于指定静态资源的访问路径和物理路径。这里的配置表示将 /static/** 路径下的请求映射到项目中的 /static/ 目录。
        mapping="/static/**":指定了静态资源的 URL 映射路径。当客户端访问以 /static/ 开头的 URL 时,
        Spring MVC 会将这些请求映射到实际的静态资源路径中去。这意味着所有匹配 /static/** 的请求将直接从指定的资源目录中获取静态文件,而不是通过 Spring MVC 控制器。

        location="/static/":定义了静态资源在项目中的存储位置。这里的 /static/ 表示资源目录在项目的根目录下,所有静态文件都应该放在 static 文件夹中。
        例如,/static/images/logo.png 可以通过 URL http://yourdomain/static/images/logo.png 来访问。

        cache-period="31536000":设置了缓存的有效期,以秒为单位。31536000 秒相当于一年(365 天),这意味着客户端将缓存这些静态资源一年,从而减少服务器的负载和带宽使用。
        配置了缓存有效期后,浏览器会根据缓存过期时间来判断是否需要重新加载资源文件,适合那些不经常更改的静态文件,如图片、CSS、JS 文件等。-->
    <mvc:resources mapping="/static/**" location="/static/"  cache-period="31536000"/>



    <!-- 配置文件上传解析器 -->
    <!-- CommonsMultipartResolver 支持文件上传操作,它将文件上传的请求解析为 MultipartFile,方便控制器处理上传文件。-->
    <!-- maxUploadSize   说明:设置允许上传的最大文件大小,以字节为单位。
            ${web.maxUploadSize}:从配置文件中获取 web.maxUploadSize 的值。
            作用:如果上传文件的大小超过此限制,将抛出 MaxUploadSizeExceededException 异常。

         maxInMemorySize 说明:定义文件上传时允许写入内存的最大值,以字节为单位。
            默认值 10240(10KB):不设置时,默认值为 10KB,表示上传文件小于此值时直接存储在内存中,而不生成临时文件。
        value="0":设置为 0 意味着所有文件上传内容将直接写入临时文件,而不保存在内存中。适用于希望减少内存消耗的大文件上传情况。-->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="maxUploadSize" value="${web.maxUploadSize}" />
        <!-- 设置文件上传是允许写到内存中的最大值 ,以字节为单位默认:10240=10K-->
        <!-- 经测试,上传文件小于此值时则不会生成临时文件 -->
        <property name="maxInMemorySize" value="0" />
    </bean>


    <!-- 配置消息转换器 -->
    <!-- 通过 <mvc:message-converters> 配置消息转换器,Spring 会自动将返回的 Java 对象转换为客户端需要的格式(如 JSON 或 XML)。-->
    <!-- StringHttpMessageConverter 用于处理字符串类型的消息。它可以将 Java 字符串转换为 HTTP 响应的字符串内容。
         在此配置中,通过 <constructor-arg value="UTF-8" /> 设置了字符串转换时的字符编码为 UTF-8。这是常见的做法,用来确保字符编码的一致性。-->

    <!-- MappingJackson2HttpMessageConverter 是用于处理 JSON 格式的消息转换器,它基于 Jackson 库将 Java 对象转换为 JSON 字符串,反之亦然。
         配置中的 supportedMediaTypes 将媒体类型设置为 application/json;charset=UTF-8,这表示此转换器只会处理 application/json 类型的响应,并且会使用 UTF-8 编码。
         prettyPrint 设置为 false,表示输出的 JSON 格式不会被格式化(即不会有额外的缩进或换行)。如果你希望返回的 JSON 格式更易读,可以设置为 true。
         通过 objectMapper 属性自定义了 Jackson 的 ObjectMapper,这里引用了 com.ssm.common.json.JsonMapper,这个类应该是你自定义的 ObjectMapper,
         可以用来做一些自定义的 JSON 处理(如日期格式、字段过滤等)。-->
    <mvc:annotation-driven>
        <mvc:message-converters register-defaults="true">
            <!-- 将StringHttpMessageConverter的默认编码设为UTF-8 -->
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                <constructor-arg value="UTF-8" />
            </bean>
            <!-- 将Jackson2HttpMessageConverter的默认格式化输出为false -->
            <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
                <property name="supportedMediaTypes">
                    <list><value>application/json;charset=UTF-8</value></list>
                </property>
                <property name="prettyPrint" value="false"/>
                <property name="objectMapper">
                    <bean class="com.ssm.common.json.JsonMapper"/>
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>





    <!-- 配置拦截器 -->
<!--    暂时没用到-->
<!--    <mvc:interceptors>-->
<!--        <mvc:interceptor>-->
<!--            <mvc:mapping path="/**"/>-->
<!--            <bean class="com.example.interceptor.LoginInterceptor"/>-->
<!--        </mvc:interceptor>-->
<!--    </mvc:interceptors>-->



    <!-- 开发环境配置  dev环境指定dev配置文件 ,-->
    <beans profile="dev">
        <context:property-placeholder location="classpath:configs-dev.properties"/>
    </beans>
    <!-- 测试环境配置 -->
    <beans profile="prod">
        <context:property-placeholder location="classpath:configs-prod.properties"/>
    </beans>

</beans>

        4、添加 mybatis-config.xml 配置文件

        MyBatis 的mybatis-config.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>
    <!-- 全局配置 -->
    <settings>
        <!-- 配置选项 -->
    </settings>

    <!-- 类型别名 -->
    <typeAliases>
        <!-- 定义别名 -->
    </typeAliases>

    <!-- 插件配置 -->
    <plugins>
        <!-- 配置插件 -->
    </plugins>

    <!-- 类型处理器 -->
    <typeHandlers>
        <!-- 定义自定义类型处理器 -->
    </typeHandlers>

    <!-- 环境配置(数据源和事务管理) -->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/your_db"/>
                <property name="username" value="root"/>
                <property name="password" value="password"/>
            </dataSource>
        </environment>
    </environments>

    <!-- 映射文件 -->
    <mappers>
        <!-- 配置Mapper文件路径 -->
    </mappers>
</configuration>

        虽然上述配置都可以在springconfig中进行配置,但其实 datasource 数据源的配置和 mappers 映射文件的配置,通常会配置在 spring 的配置文件中。所以我们简单配置的案例如下:

<?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>
        <setting name="logImpl" value="STDOUT_LOGGING"/> <!-- 将sql日志打印到控制台 -->
        <setting name="cacheEnabled" value="true"/> <!-- 开启二级缓存 -->
        <setting name="lazyLoadingEnabled" value="true"/> <!-- 懒加载 -->
        <setting name="mapUnderscoreToCamelCase" value="true"/> <!-- 自动映射数据库的下划线命名字段到Java驼峰命名属性 -->
    </settings>

    <!-- 类型别名 -->
    <!-- 该配置指定了 com.ssm.crm.model 包路径。
         MyBatis 会扫描这个包下的所有类,并为它们创建别名。
         自动别名规则:MyBatis 会自动使用类名(首字母小写)作为别名。
         例如,com.bjpowernode.crm.model.User 类会被自动映射为 user,
         而 com.bjpowernode.crm.model.CustomerInfo 类会被映射为 customerInfo。
         在 XML 文件中,使用别名替代全限定类名会使映射文件更简洁。例如:
                <resultMap id="userResultMap" type="user">
                    <id column="id" property="id"/>
                    <result column="name" property="name"/>
                    <result column="age" property="age"/>
                </resultMap>
        在这里,我们用 user 替代了全限定类名 com.bjpowernode.crm.model.User,使 XML 文件更易读。-->
    <typeAliases>
        <package name="com.ssm.crm.model"/>
    </typeAliases>
    
</configuration>

        <typeHandlers> 暂时没用到先不进行配置。
        <dataSource> 数据源配置 跟 <mappers> 映射文件配置,我们放到spring的配置文件中去。

         

        5、spring.xml  spring配置文件:

        Bean 配置:
        Spring 的核心功能之一是通过 IoC(控制反转)容器来管理对象。spring.xml 中定义 Bean 是最常见的操作。

<bean id="myBean" class="com.example.MyClass">
    <property name="propertyName" value="propertyValue"/> 
</bean>
  • id: Bean 的标识符,其他组件可以通过这个 ID 获取该 Bean。
  • class: Bean 的实现类。
  • property: 通过属性注入(setter 注入)将数据提供给 Bean 的成员变量。
<?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:jdbc="http://www.springframework.org/schema/jdbc"
       xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:util="http://www.springframework.org/schema/util" xmlns:task="http://www.springframework.org/schema/task" xsi:schemaLocation="
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
		http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.1.xsd
		http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-4.1.xsd
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
		http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.1.xsd
		http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.1.xsd"
       default-lazy-init="true">

        <!-- base-package="com.ssm.crm":指示 Spring 扫描 com.ssm.crm 包及其子包中的类,自动将符合条件的类注册为 Spring Bean。
             type="annotation":表示排除的条件是基于注解的。
             expression="org.springframework.stereotype.Controller":表示排除所有标注了 @Controller 注解的类。
             如果有任何类是通过 @Controller 注解标记的,它们将不会被 Spring 自动注册为 Bean。-->
        <context:component-scan base-package="com.ssm.crm"><!-- base-package 如果多个,用“,”分隔 -->
            <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
        </context:component-scan>



    <!-- DecryptDruidSource:这是自定义的 Druid 数据源类,对 DruidDataSource 进行了一些定制化,加密解密数据库连接配置。为了解决配置文件中的敏感信息(如数据库密码)进行解密。 -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<!--    <bean id="dataSource" class="com.ssm.common.untils.DecryptDruidSource">-->
        <!-- 数据源驱动类可不写,Druid默认会自动根据URL识别DriverClass -->
        <property name="driverClassName" value="${jdbc.driver}" />
        <!-- 基本属性 url、user、password -->
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />

        <!-- 配置初始化大小、最小、最大 -->
        <!-- initialSize:连接池的初始大小(在启动时创建的连接数)。例如,如果配置为 5,则连接池初始化时会创建 5 个数据库连接。
             minIdle:连接池中保持的最小空闲连接数。低于该数值时,连接池会创建新的连接以保证有足够的空闲连接。
             maxActive:连接池中最大连接数。超过这个数量时,新的请求将被阻塞,直到有空闲连接可用。-->
        <property name="initialSize" value="${jdbc.pool.init}" />
        <property name="minIdle" value="${jdbc.pool.minIdle}" />
        <property name="maxActive" value="${jdbc.pool.maxActive}" />

        <!-- 配置获取连接等待超时的时间 如果数据库连接池中没有空闲连接,它会在 60 秒内一直尝试获取连接。 -->
        <property name="maxWait" value="60000" />

        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 例如,每 60 秒检查一次池中的连接,关闭那些空闲时间过长的连接。 -->
        <property name="timeBetweenEvictionRunsMillis" value="60000" />

        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒  例如,连接如果空闲 5 分钟,就会被关闭。-->
        <property name="minEvictableIdleTimeMillis" value="300000" />

        <!-- 用来验证数据库连接是否有效的 SQL 查询。例如,SELECT 1 或 SELECT 1 FROM DUAL(对于 Oracle)。-->
        <property name="validationQuery" value="${jdbc.testSql}" />
        <!-- 是否在空闲连接时进行有效性检查。设置为 true 时,空闲连接会定期执行 validationQuery 进行检查。 -->
        <property name="testWhileIdle" value="true" />
        <!-- 在每次获取连接时是否检查连接的有效性。设置为 false 表示不进行检查。-->
        <property name="testOnBorrow" value="false" />
        <!-- 在每次归还连接时是否检查连接的有效性。设置为 false 表示不进行检查。-->
        <property name="testOnReturn" value="false" />

        <!-- 配置监控统计拦截的filters -->
        <!-- Druid 提供了监控功能,stat 是用于监控统计信息的一个拦截器,能够生成数据库连接池的运行时统计数据。通过它,可以查看连接池的状态、SQL 执行情况等。-->
        <property name="filters" value="stat" />
    </bean>

    <!-- 事务管理器,负责在执行事务时提交和回滚事务 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <!-- MyBatis begin -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <!-- 指定 MyBatis 配置文件 -->
<!--        <property name="mapperLocations" value="classpath:/mappings/**/*.xml"/>-->
        <!-- 指定 MyBatis 映射文件 -->
        <property name="configLocation" value="classpath:/mybatis-config.xml"/>
        <!-- 配置 MyBatis 类型别名 -->
        <property name="typeAliasesPackage" value="com.ssm.crm.model"/>
        <!-- 这个属性用于指定 MyBatis 别名的父类类型,MyBatis 会扫描所有继承自该父类的类并注册为别名。
        在这个例子中,CommonModel 是所有实体类的父类,这样所有继承自 CommonModel 的类都将被自动注册为 MyBatis 的别名。-->
        <property name="typeAliasesSuperType" value="com.ssm.common.base.CommonModel"/>
    </bean>

    <!-- mapper注解扫描器配置,扫描@MapperScan注解,自动生成代码对象 -->
    <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.ssm.crm.mapper"/>
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    </bean>

    <!-- 配置 SqlSessionTemplate -->
    <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg ref="sqlSessionFactory"/>
    </bean>



    <!-- 开发环境配置  dev环境指定dev配置文件 ,-->
    <beans profile="dev">
        <context:property-placeholder location="classpath:configs-dev.properties"/>
    </beans>
    <!-- 测试环境配置 -->
    <beans profile="prod">
        <context:property-placeholder location="classpath:configs-prod.properties"/>
    </beans>



</beans>

        6、web.xml 配置文件:

<?xml version="1.0" encoding="UTF-8"?>
<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_4_0.xsd"
         version="4.0">

    <!-- MVC Servlet -->
    <!-- <servlet> 元素定义了 Servlet 类以及相关的初始化参数,而 <servlet-mapping> 元素则定义了该 Servlet 被映射到哪些 URL 上。
         Servlet 是 Java Web 应用的处理请求的核心组件。-->
    <servlet>
        <servlet-name>springServlet</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>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>springServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

    <!-- Context ConfigLocation -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <!-- classpath*:/spring-context*.xml 表示匹配 classpath 中所有以 spring 开头并以 .xml 结尾的文件。
        这个模式常用来加载多个 Spring 配置文件(比如 spring-context-dev.xml、spring-context-prod.xml 等)。-->
        <param-value>classpath:spring.xml</param-value>
    </context-param>
    <!-- 在上下文context-param中设置spring.profile.default的默认值 -->
    <context-param>
        <param-name>spring.profiles.default</param-name>
        <param-value>dev</param-value>
    </context-param>

    <!-- 指定 ContextLoaderListener 的作用是启动 Spring 应用上下文,让 Spring 加载配置文件中的 bean 定义并管理它们的生命周期。
         配置 ContextLoaderListener 的主要目的是初始化 Spring 的 IoC 容器,从而支持应用程序中的依赖注入和注解扫描等功能。 -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <filter>
        <filter-name>encodingFilter</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>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <servlet>
        <servlet-name>DruidStatView</servlet-name>
        <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
        <init-param>
            <param-name>allow</param-name>
            <param-value>127.0.0.1</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>DruidStatView</servlet-name>
        <url-pattern>/druid/*</url-pattern>
    </servlet-mapping>

</web-app>

        7、另外一些根据环境来单独配置,例如:
                         

                

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值