spring+springmvc+mybatis 开发JAVA单体应用

myshop 概述

myshop项目是根据视频教程 Java 单体应用 做的一个练习项目,目前完成了登录功能、用户管理、类别管理后续有时间会继续做其它的功能。趁着双11花了99元一年买了台阿里云服务器,演示地址>> myshop

项目地址  https://gitee.com/yehuabin/myshop

项目结构

my-shop-dependencies:管理jar包的版本,所有项目依赖此项目

my-shop-commons:项目通用工具、实体类

my-shop-domain: POJO类,对于数据库一张表

my-shop-web-admin:后台管理功能

my-shop-web-api、my-shop-web-ui:商城前端展示部分,目前还没开发

BaseDao

public interface BaseDao<T> {
 int create(T model);
 int update(T model);
 int delete(int id);
 T getById(int id);
}

BaseDao定义了通用的数据操作接口其它具体的操作接口都继承该dao

public interface TbUserDao extends BaseDao<TbUser> {
 TbUser getByUserNameAndPasswrod(Map<String,String> param);
 List<TbUser> getByPage(PageQuery<TbUserQuery> pageQuery);
 int getCount(PageQuery<TbUserQuery> pageQuery);
}

TbUserDao继承BaseDao并定义了自己特有的一些接口

BaseService

public interface BaseService<T extends BaseEntity> {
 BaseResult create(T model);
 T getById(int id);
 BaseResult update(T model);
 BaseResult delete(int id);
}

BaseService定义通用的服务接口,T 就是某个具体的domain对象

然后给这个通用服务接口定义一个通用的实现 BaseServiceImpl。实现通用的CRUD

public abstract class BaseServiceImpl<T extends BaseEntity,D extends BaseDao<T>> implements BaseService<T> {
 @Autowired
 protected D dao;
 @Override
 public BaseResult create(T model) {
  BaseResult baseResult = EntityValidator.validate(model);
  if (!baseResult.isSuccess()) {
   return baseResult;
  }
  model.setCreated(new Date());
  model.setUpdated(new Date());
  return getBaseResult(dao.create(model),"新增失败");
 }
 public T getById(int id) {
  return dao.getById(id);
 }
 public BaseResult update(T model)
 {
  BaseResult baseResult = EntityValidator.validate(model);
  if (!baseResult.isSuccess()) {
   return baseResult;
  }
  model.setUpdated(new Date());
  return getBaseResult(dao.update(model),"更新失败");
 }
 public BaseResult delete(int id) {
  return getBaseResult(dao.delete(id),"删除失败");
 }
 private BaseResult getBaseResult(int row,String error){
  BaseResult baseResult = BaseResult.success();
  if(row<=0){
   baseResult=BaseResult.fail(error);
  }
  return baseResult;
 }
}

用户服务继承BaseService并扩展了两个方法

public interface UserService extends BaseService<TbUser> {
  PageResult<TbUser> getByPage(PageQuery<TbUserQuery> pageQuery);
  TbUser login(String userName, String password);
}

用户服务的具体实现

@Service
public class UserServiceImpl extends BaseServiceImpl<TbUser,TbUserDao> implements UserService {
 @Override
 public BaseResult create(TbUser tbUser) {
  if (StringUtils.isBlank(tbUser.getPassword())) {
   return BaseResult.fail("密码不能为空");
  }
  tbUser.setPassword(md5DigestAsHex(tbUser.getPassword()));
  return super.create(tbUser);
 }
 @Override
 public PageResult<TbUser> getByPage(PageQuery<TbUserQuery> pageQuery) {
  PageResult<TbUser> result = new PageResult<>();
  List<TbUser> list = dao.getByPage(pageQuery);
  int count=dao.getCount(pageQuery);
  result.setData(list);
  result.setRecordsTotal(count);
  result.setRecordsFiltered(count);
  return result;
 }
 @Override
 public BaseResult update(TbUser tbUser) {
  if (StringUtils.isNotBlank(tbUser.getPassword())) {
   tbUser.setPassword(md5DigestAsHex(tbUser.getPassword()));
  }
  return super.update(tbUser);
 }
 @Override
 public TbUser login(String userName, String password) {
  Map<String, String> param = new HashMap<>();
  param.put("userName", userName);
  param.put("password", md5DigestAsHex(password));
  System.out.println(param.get("password"));
  return dao.getByUserNameAndPasswrod(param);
 }
 private String md5DigestAsHex(String password){
  return DigestUtils.md5DigestAsHex(password.getBytes());
 }
}

BaseController

BaseController定义了通用的列表页、表单页、删除操作的跳转

public abstract class BaseController<T extends BaseEntity,S extends BaseService<T>> {
 @Autowired
 protected S service;
 @ModelAttribute
 public T getModel(Integer id) {
  T model=initFormEntity();
  if (id != null && id > 0) {
   model = service.getById(id);
  }
  return model;
 }
 @RequestMapping("/list")
 public String list(Model model) {
  return getJspPath()+"/list";
 }
 @RequestMapping(value = {"/create", "edit"}, method = RequestMethod.GET)
 public String form() {
  return getJspPath()+"/form";
 }
 @RequestMapping("/detail")
 public String detail() {
  return getJspPath()+"/detail";
 }
 @ResponseBody
 @RequestMapping("/delete")
 public BaseResult delete(int id) {
  return service.delete(id);
 }
 @RequestMapping(value = {"/create", "edit"}, method = RequestMethod.POST)
 public String form(T entity, Model model) {
  BaseResult baseResult;
  if (entity.getId() != null && entity.getId() > 0) {
   baseResult = service.update(entity);
  } else {
   baseResult = service.create(entity);
  }
  //新增或者修改成功返回列表页
  if (baseResult.isSuccess()) {
   return "redirect:list";
  }
  //失败显示错误信息
  model.addAttribute("result", baseResult);
  return getJspPath()+"/form";
 }
 protected abstract T initFormEntity();
 protected String getJspPath(){
  return getClass().getSimpleName().toLowerCase().replace("controller","");
 }
}

任何其它模块只要继承BaseController,就可以自动跳转到列表、表单、删除等页面,可以大大减少代码量

具体的UserController只需要实现特有的业务逻辑就可以

@Controller
@RequestMapping("/user")
public class UserController extends BaseController<TbUser,UserService> {
 @ResponseBody
 @RequestMapping("/page")
 public PageResult<TbUser> page(PageQuery<TbUserQuery> pageQuery, TbUserQuery query) {
  pageQuery.setQuery(query);
  PageResult<TbUser> tbUsers = service.getByPage(pageQuery);
  return tbUsers;
 }
 @Override
 protected TbUser initFormEntity() {
  return new TbUser();
 }
}

总结

以上所述是小编给大家介绍的spring+springmvc+mybatis 开发JAVA单体应用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • springmvc中RequestMappingHandlerAdapter与HttpMessageConverter的装配讲解

    一.DispatcherServlet 默认装配 RequestMappingHandlerAdapter ,而 RequestMappingHandlerAdapter 默认装配如下 HttpMessageConverter HttpMessageConverter: 2)加入jackson jar 包后,RequestMappingHandlerAdapter 装配的HttpMessageConverter 如下: 二. HttpMessageConverter 1)HttpMessageC

  • Spring MVC处理参数中的枚举类型通用实现方法

    前言 在开发的过程中,会涉及到大量的枚举类型数据,我们都知道,Springmvc本身能自动转换很多的数据类型,也支持你自定义转换类型,非常灵活. 本文主要介绍的是关于Spring MVC处理参数的枚举类型通用实现的相关内容,下面话不多说了,来一起看看详细的介绍吧 业务场景: 前端提交了枚举的一个属性value,想由spring来完成参数类型自动转换成对应的枚举. 比方有一个枚举 @AllArgsConstructor(access = AccessLevel.PRIVATE) @Getter @

  • MVC设定默认路由为指定的Area下的某个action

    MVC中,一般的情况下,使用IDE工具帮我们生成的代码,在路由注册的时候: public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute( name: "Default", url: "{controller}/{action}/{id}", defaults

  • Springmvc的运行流程图文详解

    一.常见类及其作用 HandlerExecutionChain : Handler执行链对象, 包含了请求处理器对象 以及所有的拦截器对象. HandlerMapping : 定义了所有的请求与 所有的请求处理器之间的映射. HandlerAdaptor: 请求处理器适配器对象, 负责完成请求处理器对象的调用 . 方法的执行等- 二. 运行流程: 浏览器端发送请求到服务器端: 1.1 当前的请求在DispatcherServlet中不存在对应的映射 ① 是否配置mvc:default-servl

  • Spring整合Springmvc的相关介绍

    1. 是否需要整合 ? 不需要 : 单独使用Springmvc. 需要将原先Spring中的内容通通迁移到Springmvc中. 例如:数据源.事务.AOP.Service .Dao - 需要: 使用Spring + Springmvc. Spring : 数据源.事务.AOP.Service .Dao - Springmvc : 只负责WEB相关的. 2. Spring容器对象如何进行创建? 非WEB环境: 直接在main方法 或者是junit测试方法中 通过new ClassPathXmlA

  • 详解Spring MVC/Boot 统一异常处理最佳实践

    前言 在 Web 开发中, 我们经常会需要处理各种异常, 这是一件棘手的事情, 对于很多人来说, 可能对异常处理有以下几个问题: 什么时候需要捕获(try-catch)异常, 什么时候需要抛出(throws)异常到上层. 在 dao 层捕获还是在 service 捕获, 还是在 controller 层捕获. 抛出异常后要怎么处理. 怎么返回给页面错误信息. 异常处理反例 既然谈到异常, 我们先来说一下异常处理的反例, 也是很多人容易犯的错误, 这里我们同时讲到前端处理和后端处理 : 捕获异常后

  • springmvc处理响应数据的解析

    1. ModelAndView 相关的成员变量和方法 private Object view; 描述视图信息 private ModelMap model 描述模型数据(响应数据) public void setViewName(String viewName) 设置视图信息 public ModelAndView addObject(String attributeName, Object attributeValue) 设置模型数据 protected Map<String, Object>

  • mvc实现图片验证码功能

    mvc中实现图片验证码很简单,只需要创建一个 FileContentResult的方法,返回file就行 /// <summary> /// 创建一个文件方法 /// </summary> /// <returns></returns> public FileContentResult GetCode() { //参数一:产生几个字符的验证码图片 参数二:验证码的形式(数字.字母.数字字母混合都有) ValidateCode validCode = new

  • C#语言MVC框架Aspose.Cells控件导出Excel表数据

    本文实例为大家分享了Aspose.Cells控件导出Excel表数据的具体代码,供大家参考,具体内容如下 控件bin文件下载地址 @{ ViewBag.Title = "xx"; } <script type="text/javascript" language="javascript"> function getparam() { var param = {}; param.sear = $("#sear").t

  • Spring mvc防止数据重复提交的方法

    本文实例为大家分享了Spring mvc如何防止数据重复提交,供大家参考,具体内容如下 方法分析: 这里使用的防止数据重复提交的方法是使用token,给所有的url加一个拦截器,在拦截器里面用java的UUID生成一个随机的UUID并把这个UUID放到session里面,然后在浏览器做数据提交的时候将此UUID提交到服务器.服务器在接收到此UUID后,检查一下该UUID是否已经被提交,如果已经被提交,则不让逻辑继续执行下去. 源码实现: 注解Token代码: @Target(ElementTyp

随机推荐