项目已上传码云:小朋友/SSM 联系人工程
知乎视频www.zhihu.com项目用时:6h(全栈,个人独立完成)
使用技术:Tomcat 8.5(运行环境),SSM(JavaWeb 框架),Bootstrap(UI框架),JQuery(JS框架),MySQL(数据库),Eclipse IDE -2020-06(开发工具),Vscode(开发工具),Navicat Pro 15(数据库操作工具)
说明:没有写浏览器兼容样式,开发时使用 Chrome
下面介绍使用 AOP 切面完成数据库事务提交回滚操作:(保证数据库访问一次一个 session,特别是数据库的增删改非常敏感,用事务来完成)
MyBatisUtil.java
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
public class MyBatisUtil {
private static SqlSessionFactory fty = null;
// ThreadLocal线程变量,相当于request作用域,线程内共享数据
private static ThreadLocal<SqlSession> threadMap = new ThreadLocal<SqlSession>();
static {
try {
String resource = "mybatis-cfg.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
fty = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException ex) {
throw new RuntimeException(ex);
}
}
public static SqlSession getSession() {
SqlSession session = threadMap.get();// 先去看看线程作用域中有没有session
if (session == null) {// 没有的话,就创建一个,并且放在线程作用域给自己公用
session = fty.openSession();
threadMap.set(session);
}
return session;
}
public static void closeSession() {
SqlSession session = threadMap.get();
if (session != null) {
session.close();
threadMap.remove();// 关闭的时候,对threadLocal做一些清理动作
}
}
}
下面开始配置
TranAdvice.java
必须使用 org.aopalliance.intercept.MethodInterceptor
接口,并重写接口的 invoke
方法
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
import org.apache.ibatis.session.SqlSession;
import com.sanery.dao.MyBatisUtil;
public class TranAdvice implements MethodInterceptor {
@Override
public Object invoke(MethodInvocation inv) throws Throwable {
SqlSession session = MyBatisUtil.getSession();
try {
Object o = inv.proceed();
session.commit();// 提交事务
return o;
} catch (Exception e) {
session.rollback(); // 有异常说明有问题,回滚
throw new RuntimeException(e);
} finally {
MyBatisUtil.closeSession(); // 关闭
}
}
}
AOP 切面的作用:提高代码的复用率。
配置 spring-mvc.xml
:使得符合pointcut规则的部分会自动的补上om.sanery.service.aop.TranAdvice 的代码。
<!-- 配置aop切片,复用代码,TranAdvice -->
<bean id="txAdvice" class="com.sanery.service.aop.TranAdvice"></bean>
<aop:config>
<aop:advisor advice-ref="txAdvice"
pointcut="execution(public * com.sanery.service.impl..*.*(..))" />
</aop:config>
最后,使用:直接 MyBatisUtil.getSession().getMapper(LinkDao.class)
即可
@Override
public List<Link> getMyLink(Integer id) {
LinkDao dao = MyBatisUtil.getSession().getMapper(LinkDao.class);
List<Link> links = dao.getMyLink(id);
return links;
}
项目结构:
![536ad42b07b142d7086e6f2c2b2cabd9.png](https://img-blog.csdnimg.cn/img_convert/536ad42b07b142d7086e6f2c2b2cabd9.png)
![cb149821114399356ce489c137e7f7d5.png](https://img-blog.csdnimg.cn/img_convert/cb149821114399356ce489c137e7f7d5.png)
CSDN:https://blog.csdn.net/weixin_43148062
简书:https://www.jianshu.com/u/45339cbb7573