springBoot框架中几个层之间的关系

 

/**

* controller控制器,用于接收和返回数据,

* 并把接收到的参数传给mapper,调用mapper的方法接口

* 响应用户请求:决定使用什么视图,需要准备什么数据来显示

*/

 

1

spring boot 中分为为 controller层、service层、dao层、entity层。

entity层:entity层和model层一样,存放的是实体类,属性值与数据库中的属性值保持一致。 实现set和get方法。

dao层:即mapper层,对数据库进行持久化操作,他的方法是针对数据库操作的,基本用到的就是增删改查。它只是个接口,只有方法名字,具体实现在mapper.xml中。

service层:业务层,存放业务逻辑处理,不直接对数据库进行操作,有接口和接口实现类,提供controller层调用的方法。

controller层:控制器层,导入service层,调用service

方法,controller通过接收前端传过来的参数进行业务操作,在返回一个指定的路径或者数据表。

controller控制器,用于接收和返回数据,

并把接收到的参数传给mapper,调用mapper的方法接口

2

 

可以这样理解:

controller层-----> service层(接口—>接口实现类) -----> dao层的.mapper文件  -----> 和mapper层里的.xml文件对应

 

Model层是数据层:  TableName是对数据表实体的映射;

                               Criteria传输前台数据

                                DTO 传输类间数据

Mapper层 放置SQL查询XML文件

Dao层相当于XML文件的抽象类

3

 

View层->Controller层(响应用户请求)->Service层(接口->接口实现类)->DAO层,即Mapper层(抽象类:xxxMapper.java文件,具体实现在xxxMapper.xml)->Model层(实体类:xxx.java)

数据层,业务层,控制层

2|0

 

1.view层:       :根据接收的数据,显示给用户浏览(使用模板引擎)

2.controller层    :控制器;@RestController响应用户请求:决定使用什么视图,需要准备什么数据来显示

3.service层    :  

        xxxService.java       接口方法声明;

        xxxServiceImpl.java :接口实现;把 Mapper(与数据库直接打交道)和Service(不直接和数据库打交道)进行整合

                      作用:存放业务逻辑处理,不直接和数据库打交道

                             具有接口和接口的实现方法,在实现类中要倒入mapper

                              提供业务处理的方法

4.Mapper层(即 DAO层):     数据库的CRUD接口,封装对数据库进行数据持久化操作。

                                                   具体的CRUD接口实现在xxxMapper.xml中

5.model层(即entity实体层): 实体类与数据表一一对应。

                                                          提供getter/setter方法,接入数据库。

 

 

3|0VO、DTO、DO、PO理解3|1解释

VO:View Object,视图层,其作用是将指定页面的展示数据封装起来。

DTO:Data Transfer Object,数据传输对象

DO:Domain Object,领域对象

PO:Persistent Object,持久化对象

3|2模型

用户发出请求(填写表单),表单的数据被展示层匹配为VO

展示层把VO转换为服务层对应方法所要求的DTO,提交给服务层

服务层先将DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务

服务层再将DO转换为持久层对应的PO,调用持久层的持久化方法,把PO传递持久化方法,完成持久化操作

4|0PO、VO、BO、DTO、DO、POJO、JavaBean、JavaBeans

PO:持久对象 (persistent object),po(persistent object)就是在Object/Relation Mapping框架中的Entity,po的每个属性基本上都对应数据库表里面的某个字段。完全是一个符合Java Bean规范的纯Java对象,没有增加别的属性和方法。持久对象是由insert数据库创建,由数据库delete删除的。基本上持久对象生命周期和数据库密切相关。

VO: 表现层对象(View Object),主要对应展示界面显示的数据对象,用一个VO对象来封装整个界面展示所需要的对象数据,数据脱敏,去掉用户隐私数据。

BO:业务对象层的缩写(Business Object),封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。具体可以看网上的一个例子:

比如一个简历,有教育经历、工作经历、社会关系等等。

我们可以把教育经历对应一个PO,工作经历对应一个PO,社会关系对应一个PO。

建立一个对应简历的BO对象处理简历,每个BO包含这些PO。

这样处理业务逻辑时,我们就可以针对BO去处理。

DTO:数据传输对象(Data Transfer Object),是一种设计模式之间传输数据的软件应用系统。数据传输目标往往是数据访问对象从数据库中检索数据。数据传输对象与数据交互对象或数据访问对象之间的差异是一个以不具有任何行为除了存储和检索的数据(访问和存取器)。简单来说,当我们需要一个对象10个字段的内容,但这个对象总共有20个字段,我们不需要把整个PO对象全部字段传输到客户端,而是可以用DTO重新封装,传递到客户端。此时,如果这个对象用来对应界面的展现,就叫VO。

JavaBean:一种可重用组件,即“一次性编写,任何地方执行,任何地方重用”。满足三个条件①类必须是具体的和公共的②具有无参构造器③提供一致性设计模式的公共方法将内部域暴露成员属性。

主要用途:可以用在 功能、处理、值、数据库访问和JSP中任何可以用Java代码创造的对象。

有两种:一种是有用户界面(UI,User Interface)的JavaBean;还有一种是没有用户界面,主要负责处理事务(如数据运算,操纵数据库)的JavaBean。JSP通常访问的是后一种JavaBean。

分类:通常有Session bean,Entity bean,MessageDrivenBean三大类

——Session bean会话构件,是短暂的对象,运行在服务器上,并执行一些应用逻辑处理,它由客户端应用程序建立,其数据需要自己来管理。分为无状态和有状态两种。

——Entity bean实体构件,是持久对象,可以被其他对象调用。在建立时指定一个唯一标示的标识,并允许客户程序,根据实体bean标识来定位beans实例。多个实体可以并发访问实体bean,事务间的协调由容器来完成。

——MessageDriven Bean消息构件,是专门用来处理JMS(Java Message System)消息的规范(EIB2.0)。JMS是一种与厂商无关的API,用来访问消息收发系统,并提供了与厂商无关的访问方法,以此来访问消息收发服务。JMS客户机可以用来发送消息而不必等待回应。

JavaBeans:JavaBeans 从狭义来说,指的是 JavaBeans 规范也就是位于 java.beans 包中的一组 API。从广义上来说,JavaBeans 指的是 API 集合,比如 Enterprise JavaBeans。

POJO:POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混淆所创造的简称。通指没有使用Entity Beans的普通java对象,可以把POJO作为支持业务逻辑的协助类。

POJO实质上可以理解为简单的实体类,顾名思义POJO类的作用是方便程序员使用数据库中的数据表,对于广大的程序员,可以很方便的将POJO类当做对象来进行使用,当然也是可以方便的调用其get,set方法。POJO类也给我们在struts框架中的配置带来了很大的方便。

一个POJO持久化以后就是PO

直接用它传递、传递过程中就是DTO

直接用来对应表示层就是VO

DAO: 数据访问对象是第一个面向对象的数据库接口,是一个数据访问接口(Data Access Object)。它可以把POJO持久化为PO,用PO组装出来VO、DTO。

DAO模式是标准的J2EE设计模式之一.开发人员使用这个模式把底层的数据访问操作和上层的商务逻辑分开.一个典型的DAO实现有下列几个组件:

1. 一个DAO工厂类;

2. 一个DAO接口;

3. 一个实现DAO接口的具体类;

4. 数据传递对象(有些时候叫做值对象).

具体的DAO类包含了从特定的数据源访问数据的逻辑,一般一个DAO类和一张表对应,每个操作要和事务关联。

@Override 的用法

在java中如果方法上加@Override的注解的话,表示子类重写了父类的方法。当然也可以不写,写的好处是:

  1. 可读性提高
  2. 编译器会校验写的方法在父类中是否存在
  1.  

public class Father {

public void test(){

System.out.println("test");

}

class child extends Father{

@Override

public void test(){

}

}

}

如果将test写成test1的话,编译器在父类中未找到此方法,将会报错

 

 

如果将@override注释去掉的话,那么编译器则会认为创建了新的方法

 

 


### 配置虚拟机连接外部无线网卡并运行 Fern WiFi Cracker 工具 要在虚拟机中通过无线网卡使用 Fern WiFi Cracker 进行无线攻击,需要完成以下几个方面的配置: #### 虚拟机网络适配器设置 在虚拟机软件(如 VMware 或 VirtualBox)中,需将主机上的物理无线网卡传递给虚拟机。此操作通常涉及 USB 设备直通功能或 PCI 直通技术。 对于大多数主流虚拟机平台而言,可以通过以下方式实现: - **VirtualBox**: 将无线网卡作为 USB 设备附加到虚拟机上。进入虚拟机的设置界面,在“USB”选项卡中启用 USB 控制器并将目标无线网卡分配至该虚拟机。 - **VMware**: 同样支持将 USB 无线网卡映射到虚拟机内部。具体方法是在虚拟机启动前,于硬件设置中的 USB 控制器部分绑定对应的设备[^2]。 #### 安装驱动程序和支持库 一旦成功挂载了实际存在的 Wi-Fi 接口,则需要安装适用于 Linux 的相应驱动以及 AirCrack-ng 套件来激活监控模式(monitormode),这是执行任何类型的捕获活动所必需的前提条件之一。例如 Atheros AR9271 卡可能依赖 ath9k_htc 模块加载才能正常工作;而 Realtek RTL88xx 系列芯片组则往往需要用到 rtl8812au/rtl88x2bu 开源项目所提供的补丁版本固件文件才行[^3]。 #### 设置 Fern WiFi Cracker 当确认无线网卡已被识别并且能够切换成监听状态之后,就可以着手准备部署 Fern WiFi Cracker 图形化环境啦! 以下是几个关键步骤概述: 1. 更新包管理索引数据库 `sudo apt update && sudo apt upgrade`; 2. 如果尚未存在的话,请先获取 git 版本控制系统以便克隆远程仓库资源下来:`sudo apt install git`; 3. 下载最新发行版代码副本 `git clone https://github.com/savio-code/fern-wifi-cracker.git` 并跳转目录 cd fern-wifi-cracker/; 4. 执行脚本来初始化必要的依赖关系构建过程 ./install.sh; 5. 最终调用 python 应用入口点开始 GUI session —— python fern-wifi-cracker.py. ```bash # 此处展示命令序列用于引导用户顺利完成上述流程 sudo apt-get update sudo apt-get install -y build-essential autoconf libtool pkg-config \ zlib1g-dev libnl-3-dev libssl-dev iw ethtool usbutils macchanger tcpdump aircrack-ng tshark wireshark cd /opt/ git clone https://github.com/savio-code/fern-wifi-cracker.git chmod +x ./fern-wifi-cracker/install.sh ./fern-wifi-cracker/install.sh python ./fern-wifi-cracker/fern-wifi-cracker.py ``` 以上即为整个过程中涉及到的主要环节说明文档内容总结][^[^23].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Roam-G

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值