(笔记整理,仅供参考,可以互相交流学习有问题的话希望大家可以留言指出)
在用SSM框架前先都对这三种框架技术了解。
Spring、Spring-MVC、MyBatis。(具体见其他整理的文章,之后附上链接地址)
MyBatis:
MyBatis 是一个可以自定义SQL、存储过程和高级映射的持久层框架。MyBatis 摒除了大部分的JDBC代码、手工设置参数和结果集重获。MyBatis 只使用简单的XML 和注解来配置和映射基本数据类型、Map 接口和POJO 到数据库记录。MyBatis主要解决数据的持久化问题。
Spring:主要实现控制反转和依赖注入
Spring-MVC:
Spring Web MVC也是服务到工作者模式的实现,但进行可优化。前端控制器是DispatcherServlet;
应用控制器其实拆为处理器映射器(Handler Mapping)进行处理器管理和视图解析器(View Resolver)进行视图管理;页面控制器/动作/处理器为Controller接口(仅包含ModelAndView handleRequest(request, response)
方法)的实现(也可以是任何的POJO类);支持本地化(Locale)解析、主题(Theme)解析及文件上传等;提供了非常灵活的数据验证、格式化和数据绑定机制;提供了强大的约定大于配置(惯例优先原则)的契约式编程支持。
一、首先在创建Maven项目时选择
在创建出来Maven项目之后,配置初始web.xml文件(解决pom.xml中报错问题)
导入(空的)web.XML文件后,解决了项目报错问题,进入pom.xml文件中,不管什么项目,在开始的时候首要任务就是导包(这个环节非常重要,一定要找一个网络畅通的地方下载......不然后面jar包出问题的话真的是让人头疼。推荐去Maven库中下载,注意版本一致的问题),接下来说明一下我这里用到的几个包
1、spring-webmvc
2、spring-orm (spring充当了容器的作用,简单的说就是不需要你自己去new一个新的对象,把这项工作交给spring去管理,咱们只需要在定义成员变量的时候在它的上面加一个注解@Resource即可,就相当于把创建该对象的工作交给了Spring去解决。)
补充:成员变量和属性的区别
3、mybatis(主要作用是简化JDBC也可以说是对JDBC一个很好的封装,精炼代码,作用于数据的持久层)
4、mybatis-spring(Spring和MyBatis是隶属于两个公司的,所以在设计模式方面可能有不同,所以需要导入这个包,起到了连接MyBatis和Spring的作用)
5、mysql-connector-java(当需要操作数据库中的数据时,需要写sql的语句,调用Java环境下的这个包)
6、druid(数据源,起到一个连接池的作用。)
7、lombok(也叫小辣椒,在写pojo的时候可以省去写get和set的方法,在类上方写@Data的注解,但是偶尔会出现写上注解但是属性那里仍然会报该属性未被使用,所以需要更改一些设置如下)
当导入@Data注解无效时,可以从本地的jar包中找到lombok.jar,复制一份到eclipse的安装目录下,然后在安装目录中找到eclipse.ini配置文件,在最后一行加入一行 -javaagent:lombok.jar
这里的lombok.jar必须与你之前黏贴到eclipse安装目录下的jar包名字相同。然后重启eclipse问题就可以解决。(如果还不可以的话考虑jar是否下载成功,或者更换一个版本的小辣椒试试。)
8、jstl(在JSP页面输出数据时用到的。尽量用2.0的版本)
补充:如果发现jar包在下载的过程中出现问题,需要去本地的库中把jar包都删除了再重新下载。仅在eclipse中删除jar包是不会修复jar包的下载失败的问题的。
这里填写配置文件
1、配置监听器
监听器的类的位置:
spring-web >> org.springframework >> web >> context >> ContextLoaderListener
org.springframework.web.context.ContextLoaderListener
2、指定Spring-IoC容器配置文件的位置
contextConfigLocation
classpath*:config/applicationContext.xml
contextConfigLocation //这里面的名字最好写成这个格式,做到见名知意
classpath*: 指的是在类的根目录下
3、配置过滤器
这里为了避免编码格式不统一造成的乱码,所以对所有的请求都进行过滤,对他们的编码格式进行设置
过滤器的类的位置:
spring-web >> org.springframework >> web>> filter >> CharacterEncodingFilter
Encoding
org.springframework.web.filter.CharacterEncodingFilter //这里可以参考他的源码,方便对下面初始化的属性有一个更好的了解
encoding
utf-8
forceRequestEncoding //过滤器中对请求的编码格式的改变默认是false
true
forceResponseEncoding //过滤器中对响应的编码格式的改变默认是false
true
Encoding //这里的名字必须与上面的中的名字保持一致
* //过滤器过滤所有的请求
4、配置Spring-MVC核心拦截器
拦截器的类的位置:
spring-webmvc >> org.springframework.web.servlet >> DispatcherServlet
MVC-Dis
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath*:config/MVC-Dis-servlet.xml
MVC-Dis
*.action
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://192.168.242.128:3306/xxl?characterEncoding=utf-8
username=root
password=123456
192.168.242.128 是我虚拟机中的IP地址,如果没有用虚拟机可以用自己本地的IP地址或者写localhost
调用jdbc.properties文件需要在applicationContext.xml中配置的信息是(这样才可以通过E-L表达式来调取文件中的数据):
下面在applicationContext.xml文件中配置数据源的时候需要调用这里的信息,可以通过E-L表达式来调取
当
//类的具体位置spring-beans >> org.springframework.beans >> factory >> config >> PropertyPlaceholderConfigurer
//类的具体位置:druid >> com.alibaba.druid >> pool >> DruidDataSource
//这里的name不可以随便写,都是类中已经定义过得属性或者成员变量,value值通过EL表达式来提取,相关的配置文件见下面jdbc.properties文件
//类的具体位置: mybaits >> org.mybatis.spring >> SqlSessionFactoryBean
//后面的dataSource是引用上面数据源的
//起别名,具体用途见UserDao.xml中可以看到
//类的具体位置: mybaits >> org.mybatis.spring >> mapper >> MapperScannerConfigurer
四层架构相互调用:dao层调用pojo层,service层调用dao层,web(或者说controller层)调用service层
1、pojo层:定义属性,因为要和数据库中的数据进行交互,所以务必让pojo层中的属性名与数据库中的字段名相同。
2、dao层:数据持久层
定义一个接口,写上业务需要的方法(这里演示查询表中的所有数据,注意返回类型是泛型)
/**
* 使用mybatis框架的话,这里的接口就不需要写实现类,直接在该包下写一个映射文件(xml文件)
* 自动映射的条件:
* 1、必须和该接口的名字一致(UsersDao.xml)
* 2、必须和该接口同处于同一个包下
* @author Administrator
*
*/
public interface UserDao {
public List getAllUser();
}
sql语句执行等都写在相应的XML文件中,这也是MyBatis的一个方便之处(以下为UserDao.xml的内容)
注意:这里执行的sql语句先在Navicat中执行成功之后再放入,尽量不要写*。
//这里可以调用mybatis的模板
//这里的命名空间写接口的完全限定名,这可以避免整个项目中会有文件重名的情况
3、service层
先创建一个UserService接口,在接口中写逻辑业务需要的方法(和dao层一样)。之后写一个UserService的实现类UserServiceImpl。
/**
* Service层需要调用Dao层,需要再Dao层上加@Resource的注解
* @Service 标明这是service层
* @author Administrator
*
*/
@Service
public class UserServiceImpl implements UserService {
//@Resource是把UserDao的对象注入到容器中
@Resource
private UserDao ud;
@Override
public List queryAllUser() {
return ud.getAllUser();
}
}
4、web层(也叫controller层)
@Controller //标明这是controller层,这层引用service层
public class UserAction {
@Resource
private UserServiceImpl usi;
//@RequestMapping() 匹配返回的结果
@RequestMapping("user.action")
public ModelAndView getUsers() {
List user = usi.queryAllUser();
ModelAndView mv = new ModelAndView();
mv.addObject("list",user);
//跳转到指定目录下的页面
mv.setViewName("/WEB-INF/pages/user.jsp");
return mv;
}
}
下面的这行代码是JSTL的jar包中的标签,用该标签调用其中的forEach方法。
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
forEach标签的用法,相当于java中的foreach一样,不过这里需要用标签来写。prefix="c"是一个前缀,相当于在JSP页面中用前缀为c的标签就是调用了core中的东西。
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
Insert title here
用户ID
用户名
密码
${users.id } //这里数据的调取必须用E-L表达式来接收
${users.username }
${users.userpwd }