SSM中各层作用及关系
1.持久层:DAO层(mapper层)(属于mybatis模块)
DAO层:主要负责与数据库进行交互设计,用来处理数据的持久化工作。
DAO层的设计首先是设计DAO的接口,也就是项目中你看到的Dao包。
然后在Spring的xml配置文件中定义此接口的实现类,就可在其他模块中调用此接口来进行数据业务的处理,而不用关心接口的具体实现类是哪个类,这里往往用到的就是反射机制,DAO层的jdbc.properties数据源配置,以及有 关数据库连接的参数都在Spring的配置文件中进行配置。
ps:(有的项目里面Dao层,写成mapper,当成一个意思理解。)
2.业务层:Service层(属于spring模块)
Service层:主要负责业务模块的逻辑应用设计。也就是项目中你看到的Service包。
Service层的设计首先是设计接口,再设计其实现的类。也就是项目中你看到的service+impl包。
接着再在Spring的xml配置文件中配置其实现的关联。这样我们就可以在应用中调用Service接口来进行业务处理。
最后通过调用DAO层已定义的接口,去实现Service具体的实现类。
ps:(Service层的业务实现,具体要调用到已定义的DAO层的接口.)
3.控制层/表现层:Controller层(Handler层) (属于springMVC模块)
Controller层:主要负责具体的业务模块流程控制,也就是你看到的controller包。
Controller层通过要调用Service层的接口来控制业务流程,控制的配置也同样是在Spring的xml配置文件里面,针对具体的业务流程,会有不同的控制器。
4.View层 (属于springMVC模块)
负责前台jsp页面的展示,此层需要与Controller层结合起来开发。
Jsp发送请求,controller接收请求,处理,返回,jsp回显数据。
5.各层之间的联系
DAO层,Service层这两个层次可以单独开发,互相的耦合度很低。
Controller,View层耦合度比较高,因而要结合在一起开发。也可以听当做两层来开发,这样,在层与层之前我们只需要知道接口的定义,调用接口即可完成所需要的逻辑单元应用,项目会显得清晰简单。
值得注意的是,Service逻辑层设计:
Service层是建立在DAO层之上的,在Controller层之下。因而Service层应该既调用DAO层的接口,又提供接口给Controller层的类来进行调用,它处于一个中间层的位置。每个模型都有一个Service接口,每个接口分别封装各自的业务处理方法。
层次结构:
视图层(View):JSP 或 HTML 页面,负责展示数据(如用户界面)。
控制层(Controller):Servlet 或 SpringMVC 控制器,处理请求逻辑,调用业务层并转发视图。业务层(Service):封装业务逻辑,调用持久层接口(如 JavaBean 实现)。
持久层(DAO):MyBatis 实现数据持久化,操作数据库(如 SQL 映射文件)。
联系:控制层接收请求,调用业务层处理,业务层调用持久层操作数据库,最终视图层展示结果,各层通过接口解耦,提高复用性。
使用JDBC技术编写一个简单的Java程序,连接Mysql数据库中的`company_db`的`employee`表,并查询所有员工信息。数据库访问用户为`admin`,密码为`secure@456`。请补充缺失的代码:
public class JdbcDemo {
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
try {
// 加载数据库驱动
Class.forName(___________________________________);
// 建立数据库连接
conn = DriverManager.getConnection(_____________________________);
// 创建Statement对象
stmt = conn.createStatement();
String query =____________________________________;
// 执行查询
rs = stmt.executeQuery(query);
// 遍历结果集
while(________________________) {
System.out.println("员工号:" + rs.getInt("emp_id"));
System.out.println("姓名:" + rs.getString("emp_name"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
// 关闭资源...
}
}
}
使用 HTML 和 CSS 创建一个顶部菜单栏。菜单包含三个选项:"论坛""下载""帮助中心",要求菜单背景为深蓝色(#2c3e50),默认文字颜色为白色,鼠标悬停时文字变为浅黄色(#ffd700)。根据代码补充CSS的❶❷处:
HTML 代码 | CSS 代码(main.css)
------------------------|--------------------------------
<!DOCTYPE html> | .top-menu {
<html> | ❶;
<head> | padding: 15px;
<link rel="stylesheet" | }
href="main.css"> |
</head> | .top-menu a {
<body> | color: white;
<div class="top-menu"> | text-decoration: none;
<a href="#">论坛</a> | margin: 0 20px;
<a href="#">下载</a> | }
<a href="#">帮助中心</a> |
</div> | .top-menu a:hover {
</body> | ❷;
</html> | }
background-color: #2c3e50 (或者blue)
color: #ffd700 (或者yellow)
background-color: #2c3e50 (或者blue)
color: #ffd700 (或者yellow)
@RequestParam
期末考试的内容为整本书。不单独划分重点。题型:选择2分*20,填空2分*5,简答4分*5,编程共30分(每空5分)老师给大家出的题每个同学的题目顺序和选项顺序可能都不一样,所以大家要理解题目,掌握知识为第一任务!