1、右键new一个Maven Project
2、选择 Create a simple project
3、输入GroupId、Artifact Id、选择Version、选择Packaging为 war 包方式,然后Finish
4、选择刚刚创建好的工程,Alt + Enter,点击Project Facts,取消勾选Dynamic Web Module,点击Apply按钮,然后勾选Dynamic Web Module,会出现Further configuration available…,点击进一步配置,Content directory中输入src/main/webapp,点击OK保存。
5、maven设置:
(1) Preferences --> Maven --> User Settings
其中
① Global Settings 选择为本地 maven 的 settings.xml 文件
② User Settings 选择为本地 maven 仓库的 settings.xm 文件
(2) Preferences --> Maven --> Installations
点击 Add --> Directory… 选择本地 Maven 的根目录
6、settings.xml 文件配置 (非必须)
(1) 配置阿里云镜像
在
节点下新增如下代码:
alimaven
aliyun maven
http://maven.aliyun.com/nexus/content/groups/public/
central
(2) 配置maven工程的属性
在
节点下新增如下代码:
jdk-1.8
true
1.8
1.8
1.8
1.8
推荐在 maven的中央仓库中搜索所需要包的坐标:https://mvnrepository.com/
1、引入 Spring和SpringMVC
① 引入SpringMVC、Spring
搜索 spring webmvc 找到坐标
org.springframework
spring-webmvc
4.3.7.RELEASE
搜索 spring jdbc 找到坐标
org.springframework
spring-jdbc
4.3.7.RELEASE
搜索 spring aspects 找到坐标
org.springframework
spring-aspects
4.3.7.RELEASE
2、引入Mybatis
搜索 mybatis 找到坐标
org.mybatis
mybatis
3.4.2
搜索 Mybatis spring 找到坐标
org.mybatis
mybatis-spring
1.3.1
3、数据库连接池、驱动包
搜索 c3p0 找到坐标
c3p0
c3p0
0.9.1
搜索 mysql-connector 找到坐标
mysql
mysql-connector-java
5.1.41
4、其他
搜索 jstl 找到坐标
jstl
jstl
1.2
搜索 servlet-api 找到坐标
javax.servlet
javax.servlet-api
3.0.1
provided
1、在官网下载Bootstrap:http://www.bootcss.com/
2、在 webapp 目录下新建一个 static 目录用于存放静态资源,将 Bootstrap 目录拷贝到 static 目录下
3、由于Bootstrap依赖于jQuery,所以需要先引入jQuery:
在 static 目录下新建 js 目录,将jQuery拷贝到 js 目录
4、引入jQuery和bootstrap的方式:
1、配置容器启动时加载Spring配置文件的监听器:ContextLoaderListener
contextConfigLocation
classpath:applicationContext.xml
org.springframework.web.context.ContextLoaderListener
2、配置SpringMVC的前端控制器,用于拦截所有请求:DispatcherServlet
不使用
指定配置文件位置时,必须在与 web.xml 同级的目录下新建springmvc的配置文件,
其命名规则为:servlet名称-servlet.xml
如:dispatcherServlet-servlet.xml
dispatcherServlet
org.springframework.web.servlet.DispatcherServlet
1
dispatcherServlet
/
3、配置字符编码过滤器
CharacterEncodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
utf-8
forceRequestEncoding
true
forceResponseEncoding
true
CharacterEncodingFilter
/*
4、配置 HiddenHttpMethodFilter:将页面普通的post请求转为指定的delete或者put请求
HiddenHttpMethodFilter
org.springframework.web.filter.HiddenHttpMethodFilter
HiddenHttpMethodFilter
/*
HttpPutFormContentFilter
org.springframework.web.filter.HttpPutFormContentFilter
HttpPutFormContentFilter
/*
1、配置扫描的组件
2、配置视图解析器
3、配置静态资源访问
4、配置SpringMVC更高级的功能
1、配置扫描的组件
2、配置数据源
① 在classpath下新建一个 db.properties
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/tally_book
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=123456
② spring配置文件中配置数据源
2、配置Spring整合Mybatis
3、将Mybatis接口的实现加入到IOC容器中
4、配置事务控制
1、mybatis全局配置文件
2、逆向工程
① GitHub地址:https://github.com/mybatis/generator/releases
② 引入mybatis-generator包:
搜索 mybatis-generator
org.mybatis.generator
mybatis-generator-core
1.3.5
③ 在工程根目录下创建一个 mbg.xml 文件
④ 生成代码:
@Test
public void testMybatisGenerator() throws Exception
{
List warnings = new ArrayList();
boolean overwrite = true;
File configFile = new File("mbg.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,callback, warnings);
myBatisGenerator.generate(null);
}
1、加入SpringTest模块的依赖
搜索 spring-test 找到坐标
org.springframework
spring-test
4.3.7.RELEASE
2、在测试类上加上@ContextConfiguration
和 @RunWith
注解
@RunWith(value=SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:applicationContext.xml"})
public class TestBillQuery
{
}
3、进行测试
@RunWith(value=SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:applicationContext.xml"})
public class TestBillQuery
{
@Autowired
private AcctBillMapper acctBillMapper;
@Test
public void billQuery()
{
AcctBill acctBill = acctBillMapper.selectByPrimaryKey(1002);
System.out.println(acctBill);
}
}
查询结果:
AcctBill [id=1002, billName=AA, billType=0, recPayMoney=100.0,offerName=早餐, recPayTime=Tue Dec 25 16:33:07 CST 2018,recPayMethod=0, billCategory=02, curStatus=1, createTime=Tue Dec 25 16:33:07 CST 2018, remarks=这是备注, loginName=admin]
1、引入pageHelper分页插件
com.github.pagehelper
pagehelper
5.0.0
2、mybatis全局配置文件中配置分页插件
3、Controller层代码示例
@Controller
public class AcctBillController
{
@Autowired
private AcctBillService acctBillService;
@SuppressWarnings("unchecked")
@RequestMapping("/bills")
public String getBills(@RequestParam(value="pn", defaultValue="1") Integer pn,
Model model)
{
// 1. 在查询之前调用 startPage 开始分页, 传入当前页码和每页大小
PageHelper.startPage(pn, 5);
// 2. startPage 后面紧跟的查询就是分页查询
List acctBills = acctBillService.getAll();
// 3. 使用 PageInfo 包装查询结果, 然后将 PageInfo 传给页面即可
@SuppressWarnings("rawtypes")
// 4. 传入需要连续显示的页数 navigatePages
PageInfo pageInfo = new PageInfo(acctBills, 5);
model.addAttribute("pageInfo", pageInfo);
return "list";
}
}
4、使用SpringTest模拟发送请求获取分页信息
/**
* 使用Spring单元测试测试分页请求
* Spring4测试的时候, 需要Servlet3.0的支持
* @author sqp
*/
@RunWith(value = SpringJUnit4ClassRunner.class)
@WebAppConfiguration
@ContextConfiguration(locations ={ "classpath:applicationContext.xml",
"file:src/main/webapp/WEB-INF/dispatcherServlet-servlet.xml" })
public class TestMvc
{
// 虚拟mvc请求
private MockMvc mockMvc;
// SpringMVC的IOC容器
@Autowired
private WebApplicationContext context;
@Before
public void initMockMvc()
{
mockMvc = MockMvcBuilders.webAppContextSetup(context).build();
}
@Test
public void testPage() throws Exception
{
// 1. 模拟发送请求获取返回值
MvcResult result = mockMvc.perform(MockMvcRequestBuilders
.get("/bills").param("pn", "1")).andReturn();
// 2. 获取请求域
MockHttpServletRequest request = result.getRequest();
// 3. 从请求域中获取 PageInfo
@SuppressWarnings("rawtypes")
PageInfo pageInfo = (PageInfo) request.getAttribute("pageInfo");
System.out.println("当前页码: " + pageInfo.getPageNum());
System.out.println("总页数: " + pageInfo.getPages());
System.out.println("总记录数: " + pageInfo.getTotal());
System.out.print("连续显示的页码: ");
int[] nums = pageInfo.getNavigatepageNums();
for (int i : nums)
{
System.out.println(" " + i);
}
// 4. 获取查询结果
@SuppressWarnings("unchecked")
List acctBills = pageInfo.getList();
for (AcctBill acctBill : acctBills)
{
System.out.println(acctBill);
}
}
}