记录SSM 框架整合、使用Maven构建,说M实际上是MybatisPlus、是一种对Mybatis封装好的框架、在不影响Mybatis原生的情况下,进行的一种扩展。
框架支持Freemarker 和 JSP 双View展示(优先找Freemarker)。
项目环境:
JDK : 1.7
SpringMVC : 4.2.5
Spring : 4.2.5
Mybatis Plus : 2.0.5
IntelliJ IDEA : 2016.2.5
LomBok : 1.16.8
Veolcity : 1.7 只用来mybatis反向生成代码
freemarker : 2.3.23
LomBok 是一种能自动生成Get & Set 等方法、大大减少开发时代码量、保持代码简洁。
查看LomBok 操作:https://projectlombok.org/
Github 项目地址:
https://github.com/Jandaes/liujilu-ssm
- Mybatis Plus 自动会引入Mybatis 的jar
- 使用Maven Tomcat Plugin部署运行 (Intellij IDEA 中如何部署项目到 Tomcat?)
- 可通过Eclipse 或MyEclipse部署运行、不仅限于IDEA
pom.xml :
<build>
<finalName>liujilufinalName>
<plugins>
<plugin>
<groupId>org.apache.tomcat.mavengroupId>
<artifactId>tomcat7-maven-pluginartifactId>
<version>2.2version>
<configuration>
<uriEncoding>UTF-8uriEncoding>
configuration>
plugin>
plugins>
build>
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<spring.version>4.2.5.RELEASEspring.version>
<junit.version>4.12junit.version>
<druid.version>1.0.18druid.version>
<fastjson.version>1.2.8fastjson.version>
<mybaitsplus.version>2.0.5mybaitsplus.version>
<mysql.version>5.1.38mysql.version>
<log4j.version>1.2.17log4j.version>
<slf4j.version>1.7.19slf4j.version>
<aspectjweaver.version>1.8.8aspectjweaver.version>
<shiro.version>1.3.1shiro.version>
properties>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webartifactId>
<version>${spring.version}version>
<type>jartype>
<scope>compilescope>
dependency>
web.xml
<servlet>
<servlet-name>spring-mvcservlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
<init-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring/spring-mvc.xmlparam-value>
init-param>
<load-on-startup>1load-on-startup>
servlet>
<servlet-mapping>
<servlet-name>spring-mvcservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
<context-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring/spring.xml,classpath:spring/spring-*.xmlparam-value>
context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
listener>
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListenerlistener-class>
listener>
从项目根目录/
开始拦截所有的请求、全部交给Springmvc管理,包括静态资源(css,js,image
),如果项目有引入静态资源也被拦截的话、需要在springmvc.xml
加入:
classpath:spring/spring-*.xml : 加载所有spring目录下spring- 开头的xml文件
Spring.xml
<context:component-scan base-package="com.liujilu.service.*"/>
<context:annotation-config/>
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location" value="classpath:jdbc.properties" />
bean>
SpringMVC.xml
<context:component-scan base-package="com.liujilu.controller">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>
context:component-scan>
<mvc:annotation-driven />
<mvc:default-servlet-handler/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"/>
<property name="suffix" value=".jsp"/>
bean>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"/>
<property name="suffix" value=".jsp"/>
bean>
<bean id="freemarkerConfig"
class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="templateLoaderPath" value="/WEB-INF/views/" />
<property name="defaultEncoding" value="utf-8" />
<property name="freemarkerSettings">
<props>
<prop key="template_update_delay">10prop>
<prop key="locale">zh_CNprop>
<prop key="datetime_format">yyyy-MM-ddprop>
<prop key="date_format">yyyy-MM-ddprop>
<prop key="number_format">#.##prop>
props>
property>
bean>
<bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView">property>
<property name="suffix" value=".ftl" />
<property name="contentType" value="text/html;charset=utf-8" />
<property name="exposeRequestAttributes" value="true" />
<property name="exposeSessionAttributes" value="true" />
<property name="exposeSpringMacroHelpers" value="true" />
<property name="requestContextAttribute" value="request" />
<property name="order" value="1" />
bean>
/WEB-INF/pages/
: SpringMVC 的返回页面、只返回.jsp
结尾的文件
/WEB-INF/views/
:Freemarker 的模版页面、只返回.ftl
结尾的文件
Freemarker文件后缀可自己编写、比如:
*.html
spring-mybatis.xml
<bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="mapperLocations" value="classpath:mybatis/xml/*.xml"/>
<property name="typeAliasesPackage" value="com.liujilu.model"/>
<property name="plugins">
<array>
<bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor">
<property name="dialectType" value="mysql"/>
bean>
array>
property>
<property name="globalConfig" ref="globalConfig" />
bean>
<bean id="globalConfig" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
<property name="idType" value="2" />
<property name="dbType" value="mysql"/>
<property name="dbColumnUnderline" value="true" />
bean>
整合Mybatis plus 配置
SysUser.java
/**
*
* 用户信息表
*
*
* @since 2017-07-31
*/
@TableName("sys_user")
@Data
@AllArgsConstructor
@NoArgsConstructor
public class SysUser extends Model<SysUser> {
private static final long serialVersionUID = 1L;
/**
* 编号
*/
@TableId(value="id", type= IdType.ID_WORKER)
private String id;
/**
* 姓名
*/
private String name;
/**
* 昵称
*/
private String nickname;
/**
* 邮箱
*/
private String email;
/**
* Q号码
*/
private String number;
/**
* 密码
*/
private String password;
/**
* 创建时间
*/
@TableField("create_time")
private Date createTime;
/**
* 最后登录时间
*/
@TableField("last_login_time")
private Date lastLoginTime;
/**
* 状态:0 锁定、 1 正常
*/
private Integer status;
@Override
protected Serializable pkVal() {
return this.id;
}
}
@Data
: 会自动生成Set & Get方法
@AllArgsConstructor
: 会自动生成构造方法
@NoArgsConstructor
: 会自动生成无参构造方法
@TableId(type= IdType.ID_WORKER)
:主键生成策略、查看spring-mybatis.xml
PS : 如果有构造方法的话、必须要写无参构造方法
SysUserController.java
@Controller
@RequestMapping("/")
public class SysUserController {
private Logger logger = Logger.getLogger(SysUserController.class);
@Autowired
private SysUserService userService;
/**
* 返回到JSP
* @return
*/
@RequestMapping("index")
public ModelAndView index(){
ModelAndView mv = new ModelAndView("index");
logger.info("进来了");
List userList = userService.selectList(new EntityWrapper());
for (SysUser user:userList) {
System.out.println(user.toString());
}
mv.addObject("userList",userList);
return mv;
}
/**
* 返回到FreeMarker
* @param model
* @return
*/
@RequestMapping("/freemarker/index")
public String index(Model model){
logger.info("进来了Freemarker 处理器");
List userList = userService.selectList(new EntityWrapper());
for (SysUser user:userList) {
System.out.println(user.toString());
}
model.addAttribute("userList",userList);
return "indexs";
}
}
MpGenerator.java
/**
*
* 代码生成器请勿轻易操作
* 操作时请取消 pom.xml 中的 velocity 注释
*
*/
public class MpGenerator {
/**
* @param args
*/
public static void main(String[] args) {
AutoGenerator mpg = new AutoGenerator();
// 全局配置
GlobalConfig gc = new GlobalConfig();
gc.setOutputDir("D://cache");//生成存放地址
gc.setFileOverride(true);
gc.setActiveRecord(true);
gc.setEnableCache(false);// XML 二级缓存
gc.setBaseResultMap(true);// XML ResultMap
gc.setBaseColumnList(false);// XML columList
gc.setAuthor("D.Yang");
// 自定义文件命名,注意 %s 会自动填充表实体属性!
gc.setMapperName("%sMapper");
gc.setXmlName("%sMapper");
gc.setServiceName("%sService");
gc.setServiceImplName("%sServiceImpl");
gc.setControllerName("%sController");
mpg.setGlobalConfig(gc);
// 数据源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setDbType(DbType.MYSQL);
dsc.setTypeConvert(new MySqlTypeConvert(){
// 自定义数据库表字段类型转换【可选】
@Override
public DbColumnType processTypeConvert(String fieldType) {
System.out.println("转换类型:" + fieldType);
return super.processTypeConvert(fieldType);
}
});
dsc.setDriverName("com.mysql.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("");
dsc.setUrl("jdbc:mysql://127.0.0.1:3306/liujilu?characterEncoding=utf8");
mpg.setDataSource(dsc);
// 策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setTablePrefix(new String[] {""});// 此处可以修改为您的表前缀
strategy.setNaming(NamingStrategy.underline_to_camel);// 表名生成策略
//strategy.setInclude(new String[]{"sys_order"});//生成指定表
mpg.setStrategy(strategy);
// 包配置
PackageConfig pc = new PackageConfig();
pc.setParent("com");
pc.setModuleName("liujilu");
pc.setEntity("model");
mpg.setPackageInfo(pc);
// 执行生成
mpg.execute();
}
}
该工具类、自动通过连接数据库生成对应的java文件、包括:
Controller、model、Service、ServiceImpl、Mappler、Mapperxml
只要修改配置里面的数据库连接地址、以及修改生成代码的存放地址就可以使用。
具体更多的MybatisPlus方法操作、查看:http://git.oschina.net/baomidou/mybatis-plus
以上代码为主要代码、更多代码查看Github 源码
后续提交添加、修改、删除
等操作
参考网站:http://liujilu.com/