前言
SSM就是Spring+SpringMvc+Mybatis,本文搭建一个基本的ssm框架
本文所有源代码包含jar包下载点击:https://download.csdn.net/download/wcc27857285/10667045
正文
Eclipse新建web dynamic project
一.项目结构图:
二.mysql数据库创建好user表:(数据库名为firstdb)
三.引入JAR包:
四.开始正式搭建项目
配置文件
web.xml
我们在web.xml中加载Spring配置,并且将所有的请求都过滤给Spring MVC来处理,同时设置编码过滤器解决编码问题(最后一项可以不配置)。 其中Spring MVC的请求过滤就是一个简单的Servlet配置。
org.springframework.web.context.ContextLoaderListener
contextConfigLocation
classpath*:configxml/applicationContext.xml
Spring
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath*:configxml/applicationContext-Mvc.xml
1
Spring
/
encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
forceEncoding
true
encodingFilter
/*
applicationContext.xml spring 核心配置文件
在这个配置文件中,我们主要配置数据源,Spring的事务管理和Dao接口的扫描,以及对Mybatis的一些列相关配置文件的扫描。
applicationContext-Mvc.xml
这个配置文件中我们主要启用Sping注解驱动,进行静态资源的配置,注解扫描配置和视图解析器配置.
mybatis-config.xml
Mybatis的配置文件就是mybatis-config.xml,主要是配置typeAlias,将实体类匹配成XXXMapper.xml中可以直接使用的类型,相当于一个别名,在XXXMapper.xml中就无需再写完整的实体类全路径,直接用alias的值来代替。
开始测试
User.java实体类
在src下新建com.zht.entity包,然后新建实体类User.java,一般跟表名对应
package com.zht.entity;
public class User {
private Integer id;
private String name;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name == null ? null : name.trim();
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
IUserDao.java数据访问层接口
在src下新建com.zht.dao包,然后新建IUserDao.java 接口类,数据访问层接口
package com.zht.dao;
import com.zht.entity.User;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository("userDao")
public interface IUserDao {
List selectAllUser();
}
UserMapper.xml mybatis映射文件,存放sql语句
src下新建com.zht.mapping包,然后新建UserMapper.xml文件
IUserService.java 业务逻辑层接口
在src下新建com.zht.service包,然后新建IUserService.java 接口类, 业务逻辑层接口
package com.zht.service;
import com.zht.entity.User;
import java.util.List;
public interface IUserService {
public List getUser();
}
UserServiceImpl.java 业务逻辑层实现类
在src下新建com.zht.service.impl包,然后新建UserServiceImpl.java实体类
实现了IUserService接口,主要是处理具体的业务,向下调用dao接口访问数据库,经过业务处理后向上返回给视图
这里写了个很简单的业务判断,若取到的user数据数量大于100或者等于0,则返回空。
package com.zht.service.impl;
import com.zht.dao.IUserDao;
import com.zht.entity.User;
import com.zht.service.IUserService;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
@Service("userService")
public class UserServiceImpl implements IUserService {
@Resource(name = "userDao")
private IUserDao userDao;
@Override
public List getUser() {
List list = userDao.selectAllUser();
if (list.size() > 100 && list.size() <= 0) {
return null;
} else {
return list;
}
}
}
UserController.Java 控制器
控制器,向上接收URL,向下调用server层处理逻辑并返回数据
package com.zht.controller;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import com.zht.entity.User;
import com.zht.service.IUserService;
@Controller
@RequestMapping(value = "/gouser")
public class UserController {
@Resource(name = "userService")
IUserService userService;
@RequestMapping(value = "/list")
public ModelAndView list() {
ModelAndView mv = new ModelAndView();
List userList = userService.getUser();
mv.addObject("userList", userList);
mv.setViewName("result");
return mv;
}
}
index.jsp
程序默认页面,很简单直接跳转到gouser/list
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
Insert title here
result.jsp 返回结果页
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
序号
姓名
年龄
${user.id}
${user.name}
${user.age}
无数据!
部署tomcat,启动,访问url:http://localhost:8080/ssm_proj/
如果出现此页面,那就说明成功了!
遇到的坑:
1.Eclipse的“Bulid Automatically”没开,导致修改的代码没有编译,一直看到的是上一次的结果
2.The origin server did not find a current representation for the target resource or is not willing to disclose that one exists.
这个报错令人很头疼,不知如何解决,我原先以为只要看Console窗口的最下方看即可,以为在Url访问时会给出错误提示,但是发现并没有,后来慢慢发现在Tomcat启动时,Console窗口中就会打印出一些错误信息,只要有“严重”的字样,基本上项目是跑不起来的,根据console信息定位问题,然后解决即可。
3.JAR包的导入,需要复制到WEB-INF/libs下面,是物理复制。我之前引入到Refernced Libraries中还是会提示,class找不到。。。原因暂时不清楚
4.NoSuchBeanDefinitionException: No bean named 'userService' available
这个原因一般有两个,如果是用xml配置的,确定下bean的name(id)是否正确,配置是否完整,如果是用注解@service这种的,确定下你xml配置里面的扫描包是否扫描到了userService这个java类所在的包。
回到本项目就是mvc配置文件中
而我之前写的是base-package="com.zht.dao",所以报错
5.报错:org.mybatis.spring.transaction.SpringManagedTransaction.getTimeout()Ljava/lang/Integer;
主要是jar包版本兼容问题,MyBatis-Spring.jar和MyBatis版本对不上,参考下表:
MyBatis-Spring | MyBatis | Spring |
---|---|---|
1.0.0 and 1.0.1 | 3.0.1 to 3.0.5 | 3.0.0 or higher |
1.0.2 | 3.0.6 | 3.0.0 or higher |
1.1.0 or higher | 3.1.0 or higher | 3.0.0 or higher |
1.3.0 or higher | 3.4.0 or higher | 3.0.0 or higher |
6.返回空结果,如图:
没有任何报错,就是查询数据库返回的list
在用到
需要引入标签库,在开头加上这句 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>即可
同时要引入Jar包jstl-1.2.jar
总结:
就是对Eclipse不熟悉,对Console不熟悉,JSP有黄色警告要注意
ssm框架使用了各种注解,AOP,IOC等技术,你只需要配置文件,然后在业务层里写写业务即可,操作数据库的各种连接代码全封装好了。确实很方便,但是真的是配置很繁琐,而且容易出错。。。
源代码包含jar包csdn下载链接:https://download.csdn.net/download/wcc27857285/10667045