關於SSM框架下各層的解釋說明(Controller等)

SSM框架

SSM框架是spring MVC ,Spring和Mybatis框架的整合,是標準的MVC模式,將整個系統劃分為表現層(web),controller層,service層,dao層四層,使用spring MVC負責請求的轉發和視圖管理。

Spring實現業務對象管理,Mybatis作為數據對象的持久化引擎。

  • 表現層(web):通俗講就是展現給用戶的界面,即用戶在使用一個系統的時候他的所見所得。
  • 業務邏輯層(service):針對具體問題的操作,也可以說是對數據層的操作,對數據業務邏輯處理。
  • 數據訪問層(dao):該層所做事務直接操作數據庫,針對數據的增添、刪除、修改、更新、查找等。

DataBase ===> Entity ===> Mapper.xml ===> Dao.Java ===> Service.java ===> Controller.java ===> html css js(thymeleaf)

各層解釋說明

用IDEA創建一個maven項目結構如左圖所示,在該項目中,有五個包,分別是controller、dao、entity、service和serviceimpl:

描述
實體層 數據庫在項目中的類,主要用於定義與數據庫對象應的屬性,提供get/set方法,tostring方法,有參無參構造函數。
持久層 與數據庫交互,dao層首先會創建dao接口,接著就可以在配置文件中定義該接口的實現類;接著就可以在模塊中調用dao的接口進行數據業務的處理,而不用關註此接口的具體實現類是哪一個類,dao層的數據源和數據庫連接的參數都是在配置文件中進行配置的。
業務層 控制業務,業務模塊的邏輯應用設計,和dao層一樣都是先設計接口,再創建要實現的類,然後在配置文件中進行配置其實現的關聯。接下來就可以在service層調用接口進行業務邏輯應用的處理。
實現層 實現service接口的所有方法,整合service和dao
控制層 controller層主要調用Service層裡面的接口控制具體的業務流程,控制的配置也要在配置文件中進行。Controller和Service的區別是:Controller負責具體的業務模塊流程的控制;Service層負責業務模塊的邏輯應用設計

entity層(model層)

實體層用於存放我們的實體類,與數據庫中的屬性值基本保持一致,實現set和get的方法。

1.導入lombok小辣椒驅動依賴,用來生成get/set方法依賴:

package com.dvms.entity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
import lombok.experimental.Accessors;
import java.util.Date;
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
@Accessors(chain = true) //鏈式調用
public class Emp {
    private String id;
    private String name;
    private Double salary;
    private Integer age;
    private Date bir;
}

2.傳統方式

package com.umf.entity;
import java.io.Serializable;
public class UpdataSettingEntity implements Serializable {
	private static final long serialVersionUID = 1L;
	//
	private Integer id = 1;
	//
	private int updataflag;
	/**
	 * 設置:
	 */
	public void setId(Integer id) {
		this.id = id;
	}
	/**
	 * 獲取:
	 */
	public Integer getId() {
		return id;
	}
	/**
	 * 設置:
	 */
	public void setUpdataflag(int updataflag) {
		this.updataflag = updataflag;
	}
	/**
	 * 獲取:
	 */
	public int getUpdataflag() {
		return updataflag;
	}
}

dao層(mapper層)

dao層(接口類)對數據庫進行數據持久化操作,他的方法語句是直接針對數據庫操作的,主要實現一些增刪改查操作,在Mybatis中方法主要與與xxxDao(Mapper).xml內相互一一映射。

Mybatis可以用.xml進行數據操作,也可以在dao層用註解的方式,也可以采取xml和dao層接口組合使用的方法(常用)。

package com.dvms.dao;
import com.dvms.entity.User;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public interface UserDao {
    //登錄
    User login(@Param("username") String username, @Param("password") String password);// 在mybatis中傳遞多個參數要做參數的綁定
    //新增用戶(註冊)
    void save(User user);
    //查詢所有用戶
    List<User> findAlluser();
    //刪除用戶
    void delete(String id);
    //修改用戶信息(先查再改)
    User update(String id);
    void add(User user);
}

xxxDao(Mapper).xml:

關鍵: < mapper namespace=“com.dvms.dao.UserDao”>

前提:基本數據庫語法

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dvms.dao.UserDao">
<!--註冊/新增用戶-->
    <insert id="save" parameterType="User">
        insert into user (id,username,password,sex,phone,email,role) values (#{id},#{username},#{password},#{sex},#{phone},#{email},#{role})
    </insert>
<!--登錄驗證-->
    <select id="login" resultType="User">
        select id,username,password,sex,phone,email,role from user
        where username =#{username} and password =#{password}
    </select>
<!--查詢所有用戶-->
    <select id="findAlluser" resultType="User">
        select id,username,password,sex,phone,email,role from user
    </select>
<!--刪除用戶-->
    <delete id="delete" parameterType="String">
        delete from user where id=#{id}
    </delete>
<!--修改用戶信息-->
    <!--查到要修改的用戶信息-->
    <select id="update" parameterType="String" resultType="User">
        select id,username,password,sex,phone,email,role from user where id=#{id}
    </select>
    <!--修改用戶信息-->
    <update id="add" parameterType="User">
        update user set username=#{username},password=#{password},sex=#{sex},phone=#{phone},email=#{email},role=#{role} where id=#{id}
    </update>
</mapper>

在dao層用註解的方式:

public interface StudentDao {
    
    @Select("select * from student where stu_id=#{stuId}")
    public Student queryById(int stuId);
}

service層

service層(接口類)為controller層的類提供接口進行調用,一般就是自己寫的方法封裝起來,具體實現在serviceImpl中。

service層是建立在dao層之上的,建立瞭dao層後才可以建立service層,而service層又是在controller層之下的,因而service層應該既調用dao層的接口,又要提供接口給Controller層的類來進行調用,它剛好處於一個中間層的位置。每個模型都有一個service接口,每個接口分別封裝各自的業務處理方法。

package com.dvms.service;
import com.dvms.entity.User;
import java.util.List;
public interface UserService {
    //新增用戶
    void save(User user);
    //登錄
    User login(String username, String password);
    //查詢所有用戶
    List<User> findAlluser();
    //刪除用戶
    void delete(String id);
    //修改用戶信息
    User update(String id);
    void add(User user);
}

servicedmpl(實現service層,整合service和dao)(導入dao層)(接口實現類)

package com.dvms.service.Impl;
import com.dvms.dao.UserDao;
import com.dvms.entity.User;
import com.dvms.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.UUID;
@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private UserDao userDao;
    @Override
    public void save(User user) {
        user.setId(UUID.randomUUID().toString());
        userDao.save(user);
    }
    @Override
    public User login(String username, String password) {
        return userDao.login(username,password);
    }
    @Override
    public List<User> findAlluser() {
        return userDao.findAlluser();
    }
    @Override
    public void delete(String id) {
        userDao.delete(id);
    }
    @Override
    public User update(String id) {
        return userDao.update(id);
    }
    @Override
    public void add(User user) {
        userDao.add(user);
    }
}

Controller層(web 層)

負責具體模塊的業務流程控制(獲取參數(前端傳過來)返回響應(前端或數據庫或一個指定路徑)),需要調用service邏輯設計層的接口來控制業務流程(導入service層)。

package com.dvms.controller;
import com.dvms.entity.Emp;
.....
@Controller
public class EmpController {
    @Autowired
    private EmpService empService;
    @GetMapping("emp/findAll")
    public String findAll(@RequestParam(defaultValue = "1") int pageNum,
                          @RequestParam(defaultValue = "5") int pageSize,
                          Model model){
        PageHelper.startPage(pageNum,pageSize);//
        PageInfo<Emp> pageInfo = new PageInfo<>(empService.findAll());
        model.addAttribute("pageInfo",pageInfo);
//        List<Emp> emps = empService.findAll();
//        model.addAttribute("emps",emps);
        return "ems/tables";
    }
    @RequestMapping("/emp/save")
    public String save(Emp emp){
        empService.save(emp);
        return "redirect:/emp/findAll";
    }
}

Controller層調用瞭Service層的接口方法,Service層調用Dao層的方法,其中調用的參數是使用Entity層進行傳遞的。View層與Controller層協同工作,主要負責界面展示。

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: