本文写于实训期间,致敬我的实训老师-东哥
目录
创建我的SSM脚手架(模板)项目--单模块
一 创建 Maven 项目
1.1选择模板:web-app
1.2 设置项目
1.3 设置maven的路径以及setting.xml配置
二 添加相关依赖
Spring核心maven包:
- spring-core
- spring-context
- spring-beans
- spring-test
- spring-aop
- spring-expression
- spring-tx
- spring-jdbc
SpringMVC核心maven包:
- spring-web
- spring-webmvc
JavaEE:
- javax.servlet-api
数据库连接驱动(阿里)
- druid com.alibaba.druid.pool.DruidDataSource
- mysql-connector-java com.mysql.jdbc.Driver
mybatis核心maven包
- mybatis
- mybatis-spring (mybatis关联spring的一个驱动包)
- mybatis-generator-core (逆向工程,目的是把数据库的表结构自动生成为类对象、mapper)
jackson核心maven包
(把java对象自动转换成json对象 Spring默认集成的json转换器)
- jackson-core
- jackson-databind
- jackson-annotations
org.json包
- json
swagger(提供api接口文档展示到页面中)
- springfox-swagger2
- springfox-swagger-ui
上传组件
- commons-io
- commons-fileupload
三 配置部署描述符 web.xml
下面根据SSM启动执行的加载流程添加配置
3.1添加listener
中间初始化数据库连接、sqlSessionFactory、Mapper接口和Service类
<!--Spring核心监听器 -->
<!--在服务器启动时加载Spring容器,且只会加载一次 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/spring-ioc.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
3.2添加filter
用于编码过滤的过滤器
<!--配置由Spring 提供的针对中文乱码的编码过滤器 -->
<!-- 编码过滤器 -->
<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>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
3.3添加servlet
MVC的DispatcherServlet
因为在SSM启动的时候,servlet并不会进行初始化,只有设置<load-on-startup>1</load-on-startup>才会在ssm开始运作的时候便启动MVC Servlet
<!--配置springmvc -->
<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:spring/spring-mvc.xml</param-value>
</init-param>
<!--设置启动时加载-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
四 创建文件夹以及添加相关的文件
项目目录结构图
五 配置文件
5.1 配置dataSource.properties
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/blog_one?useUnicode=true&characterEncoding=utf-8
jdbc.username=root
jdbc.password=dcpnet
jdbc.initialSize=5
上面的数据库名、用户名、密码记得改为自己的
5.2 配置spring-ioc.xml
有关Mapper的配置
<!--找到resource下的资源:dataSource.properties-->
<context:property-placeholder location="classpath*:dataSource.properties"/>
<!--1. 配置数据源:阿里数据源 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="initialSize" value="${jdbc.initialSize}"/>
</bean>
<!--2. 配置mybatis的SqlSession的工厂: SqlSessionFactoryBean dataSource:引用数据源 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--dataSource属性指定要用到的连接池-->
<property name="dataSource" ref="dataSource" />
<!--configLocation属性指定mybatis的核心配置文件-->
<property name="configLocation" value="classpath:mybatis-config.xml" />
<!-- 自动扫描mapping.xml文件 -->
<property name="mapperLocations" value="classpath*:mapper/*.xml"/>
<property name="typeAliasesPackage" value="com.dcpnet.template.pojo"/>
</bean>
<!--接口扫描-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
<property name="basePackage" value="com.dcpnet.template.mapper"/>
</bean>
有关Service的配置
<!--Service-->
<!--4. 扫描service注解 -->
<context:component-scan base-package="com.dcpnet.template.service"/>
<!--5. 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<!--6. 开启注解进行事务管理 transaction-manager:引用上面定义的事务管理器-->
<tx:annotation-driven transaction-manager="transactionManager" />
<!--Service-->
5.3配置spring-mvc.xml
<!--添加注解驱动-->
<mvc:annotation-driven/>
<!--扫描 Controller 相关的Bean-->
<context:component-scan base-package="com.dcpnet.controller"/>
<!-现在的企业已经放弃了模板View技术,基本使用的是html-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<!--property name="suffix" value=".jsp"/-->
<property name="suffix" value=".html"/>
</bean>
<!-- 2.静态资源默认servlet配置 (1)加入对静态资源的处理:js,gif,png (2)允许使用"/"做整体映射 -->
<mvc:resources mapping="/resources/**" location="/WEB-INF/resources/"/>
<mvc:default-servlet-handler/>
5.4配置mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTO 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"/>
<!--如果value为true的时候,当返回内容为空时,那么返回的是一个空的对象,而不是null
如果这里的value为false(默认值),mybatis在没有查询到内容的时候返回null-->
<setting name="returnInstanceForEmptyRow" value="true"/>
<!--显示sql语句,此行配置如果删除,则不在后台显示SQL语句-->
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
</configuration>
6安装Idea插件EsayCode
7 逆向工程
对选中表点击右键,在EsayCode插件下的子菜单选择Generate Code,然后吧要用的勾选上,package选择src/main/java下的自己的包,点击确定。再几个创建目录的弹窗确定后
可以看见已经自动生成了相应的文件,这个插件是沿袭了部分的Hubberite的习惯,我这里是将插件设置了,具体的设置还是看个人
8运行
此时已经可以运行啦,tomcat配置就不讲了
内有集成Layui、Editor.md
异常记录
Error:(5, 1) java: 程序包org.springframework.web.bind.annotation不存在
解决方案:把工作委托给Maven,其实本该如此