SSM开发流程详解
SSM执行流程图:
第一步:创建数据库,创建表语句,使用mysql数据库,Navicat for MySQL可视化数据库管理工具。
第二步:创建maven-web项目结构使用IDEA开发工具进行开发。
第三步:创建项目目录结构,
第四步:创建层级结构,即创建包结构,
第五步:书写dao层,entity层,servlce层内容,
第六步:创建查询语句在resources目录下创建目录结构和java目录下的dao层的项目结构相同,创建和dao层中接口名称相同首字母小写的xml文件,即此处是mybatis文件,内容如下:
<?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" >
<!--namespace 填写的是dao层所对应的接口全限定类名-->
<mapper namespace="com.user.dao.UserDao">
</mapper>
第七步:创建jdbc.properties 配置文件这个文件是连接mysql数据库的连接信息内容如下:
#数据库驱动
jdbc.driverClassName=com.mysql.jdbc.Driver
#数据库的url
jdbc.url=jdbc:mysql://localhost:3306/test?useUnicode=true& useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
#连接的数据库用户名
jdbc.username=root
#连接的数据库密码
jdbc.password=123456
第八步: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>
<!--使用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>
第九步:书写spring与mybatis整合的配置文件spring-dao.xml(spring与数据库整合,操作数据库),配置文件内容如下:
<?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">
<!--第一步:加载jdbc.properties数据库连接信息配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--第二步:配置dataSource,连接数据库-->
<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}"/>
</bean>
<!--第三步:配置sqlSessionFactory对象-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--3.1:注入数据源dataSource,数据库连接池-->
<property name="dataSource" ref="dataSource"/>
<!--3.2配置mybatis全局配置文件-->
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
<!--3.3配置别名,扫描entity包下所有的实体类-->
<property name="typeAliasesPackage" value="com.user.entity"/>
<!--3.4扫描sql配置文件-->
<property name="mapperLocations" value="classpath:com/user/dao/*.xml"/>
</bean>
<!--第四步:配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--4.1:注入sqlSessionFactory对象-->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
<!--4.2:给出需要扫描的dao接口的包-->
<property name="basePackage" value="com.user.dao"/>
</bean>
</beans>
spring-service.xml 配置文件详解书写开发步骤:一共分为三步走完成对service层的操作:
<?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.alibaba.com/schema/stat"
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.alibaba.com/schema/stat http://www.alibaba.com/schema/stat.xsd">
<!--第一步:开启扫描,此注解表示支持注解开发,扫描service包下所有内容支持注解-->
<context:component-scan base-package="com.user.service"/>
<!--第二步:配置事务管理器-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!--注入数据库连接池-->
<property name="dataSource" ref="dataSource"/>
</bean>
<!--第三步:配置基于注解的事务-->
<tx:annotation-driven/>
</beans>
spring-mvc.xml 配置文件详解书写开发步骤:一共分为三步走完成对service层的操作:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
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.xsd">
<!--第一步:配 置springMvc-->
<!--开启springMvc注解模式-->
<mvc:annotation-driven/>
<!--第二步: 扫描web相关的bean,扫描controller层所有的类,配置Handler-->
<context:component-scan base-package="com.user.controller"/>
<!-- 第三步: 定义视图解析器,ViewResolver-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"/>
<property name="suffix" value=".jsp"/>
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
</bean>
</beans>
最重要的是把spring-dao.xml和spring-service.xml和spring-mvc.xml配置文件交给Tomcat容器进行管理,在web.xml配置文件中进行配置前端控制器(DispatcherServlet):
<servlet>
<servlet-name>springMvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--指定配置文件路径-->
<init-param>
<param-name>contextConfigLocation</param-name>
<!--加载spring-dao.xml和spring-service.xml和spring-mvc.xml文件-->
<param-value>classpath:spring/spring*.xml</param-value>
</init-param>
<!--表示启动容器时初始化该servlet-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>