JavaWeb——MVC架构模式

devtools/2024/11/14 21:46:55/

一、概述:

MVC(Model View Controller)是软件工程中的一种 软件架构模式 ,它把软件系统分为模型、视图和控制器三个基本部分。用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时不需要重新编写业务逻辑。

M代表Model模型层,具体功能如下:

1.存放和数据库对应的实体类以及一些用于存储非数据库表完整相关的VO对象;

2.存放一些对数据进行逻辑运算操作的一些业务处理代码;

V代表view视图层,具体功能如下:

1.存放一些视图文件相关的代码,例如html、css以及js等;

2.在前后端分离的项目中,后端已经没有视图文件,该层次已经衍化成独立的前端项目;

C代表Controller控制层,具体功能如下:

1.接收客户端请求,获得请求数据;

2.将准备好的数据响应给客户端;

二、MVC模式下项目中的常见包:

M:

1.实体类包(pojo /entity /bean):专门存放和数据库对应的实体类和一些VO对象;

2.数据库访问包(dao/mapper):专门存放对数据库不同表格CURD方法封装的一些类;

3.服务包(service):专门存放对数据进行业务逻辑运算的一些类;

C:

控制层包(controller);

V:

1.web目录下的视图资源html、css、js、img等

2.前端工程化后,在后端项目中已经不存在了;

 三、项目搭建:

项目结构:

1.数据库准备:创建schedule_system数据库并执行如下语句

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 8;
DROP TABLE IF EXISTS `sys_schedule`;
CREATE TABLE `sys_schedule`(
`sid` int NOT NULL AUTO_INCREMENT,
`uid` int NULL DEFAULT NULL,
`title` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0908_ai_Ci NULL DEFAULT NULL,
`completed` int(1) NULL DEFAULT NULL,
PRIMARY KEY(`sid`)USING BTREE
)ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = Utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user`(
`uid` int NOT NULL AUTO_INCREMENT
`username` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
`user_pwd` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
PRIMARY KEY(`uid`)USING BTREE,
UNIQUE INDEX `username`(`username`)USING BTREE
)ENGINE = InnoDB CHARACTER SET =utf8mb4 COLLATE=utf8mb4 0900_ai_ci ROW_FORMAT =Dynamic;
INSERT INTO `sys_user` VALUES(1,'zhangsan','e10adc3949ba59abbe56e057f20f883e');
INSERT INTO `sys_user` VALUES(2,'lisi','e10adc3949ba59abbe56e057f20f883e');
SET FOREIGN_KEY_CHECKS = 1;

2.pojo包处理:使用lombok处理getter、setter、equals、hashcode、构造器

lombok使用步骤:

(1)检查idea是否已经安装lombok插件

(2)检查是否勾选enable,annotation,processing

(3)导入lombok依赖,在实体类上添加注解

package com.atguigu.schedule.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@AllArgsConstructor//添加带有全部参数的构造器
@NoArgsConstructor//添加无参构造器
@Data//添加getter、setter、equals、hashcode
public class SysUser implements Serializable{private Integer uid;private String username;private String userPwd;
}
package com.atguigu.schedule.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@AllArgsConstructor
@NoArgsConstructor
@Data
public class SysSchedule implements Serializable{private Integer sid;private Integer uid;private String title;private Integer completed;
}

3.dao包的处理:dao类用于定义针对表格的CURD的方法

每张数据表都应该对应一个dao类,该dao类专门用于封装对该数据表的操作内容

(1).创建BaseDao对象

package com.atguigu.schedule.dao;
import com.atguigu.schedule.util.JDBCUtil;
import java.lang.reflect.Field;
import java.sql.*;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
public class BaseDao{//公共的查询方法 返回的是单个对象public <T>T baseQueryObject(Class<T> clazz, String sql,Object ... args){T t = null;Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement = null;ResultSet resultSet = null;int rows = 0;try{// 准备语句对象preparedStatement = connection.prepareStatement(sql);//设置语句上的参数for(int i=0;i<args.length;i++){preparedStatement.setObject(i +1,args[i]);}// 执行 查询resultSet = preparedStatement.executeQuery();if(resultSet.next()){t = (T) resultSet.getobject(1);}}catch(Exception e){e.printStackTrace();}finally {if(null != resultSet){try{resultSet.close();}catch(SQLException e){e.printStackTrace();}}if(null != preparedStatement){try{preparedStatement.close();}catch(SQLException e){e.printStackTrace();}}JDBCUtil.releaseConnection();}return t;}//公共的查询方法 返回的是对象的集合public <T> List<T> baseQuery(Class clazz,String sql,Object ... args){List<T> list =new ArrayList<>();Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement = null;ResultSet resultSet = null:int rows = 0;try {// 准备语句对象preparedStatement = connection.prepareStatement(sql);//设置语句上的参数for(int i=0;i<args.length;i++){preparedStatement.setObject(i +1,args[i]);}// 执行 查询resultSet = preparedStatement.executeQuery();ResultSetMetaData metaData = resultSet.getMetaData();int columnCount = metaData.getColumnCount();//将结果集通过反射封装成实体类对象while(resultSet.next()){//使用反射实例化对象Object obj = clazz.getDeclaredConstructor().newInstance();for(int i=1;i<=columnCount;i++){String columnName = metaData.getColumnLabel(i);Object value = resultSet.getObject(columnName);//处理datetime类型字段和java.util.Data转换问题if(value.getClass().equals(LocalDateTime.class)){value = Timestamp.valueOf((LocalDateTime) value);}Field field=clazz.getDeclaredField(columnName);field.setAccessible(true);field.set(obj,value);}list.add((T)obj);}} catch (Exception e){e.printStackTrace();}finally {if(null != resultSet){try{resultSet.close();}catch(SQLException e){e.printStackTrace();}}if(null != preparedStatement){try{preparedStatement.close();}catch(SQLException e){e.printStackTrace();}}JDBCUtil.releaseConnection();}return list;}// 通用的增删改方法public int baseUpdate(String sql,Object ... args){//获取连接Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement = null;int rows =0;try {// 准备语句对象preparedStatement=connection.prepareStatement(sql);//设置语句上的参数for(int i=0;i<args.length;i++){preparedStatement.setObject(i+1,args[i]);}//执行 增删改executeUpdaterows = preparedStatement.executeUpdate();// 释放资源(可选)}catch(SQLException e){e.printStackTrace();}finally{if(null != preparedstatement){try{preparedStatement.close();}catch(SQLException e){throw new RuntimeException(e);}}JDBCUtil.releaseConnection();}return rows;}
}

(2).dao层所有接口:

package com.atguigu.schedule.dao;
public interface SysUserDao {
}
package com.atguigu.schedule.dao;
public interface SysScheduleDao{
}

(3).dao层所有实现类:

package com.atguigu.schedule.dao.impl;
importcom.atguigu.schedule.dao.BaseDao;
import com.atguigu.schedule.dao.SysUserDao;
public class SysUserDaoImpl extends BaseDao implements SysUserDao {
}
package com.atguigu.schedule.dao.impl;
import com.atguigu.schedule.dao.BaseDao;
import com.atguigu.schedule.dao.SysScheduleDao;
public class SysScheduleDaoImpl extends BaseDao implements SysScheduleDao{
}

4.service包处理

(1)接口:

package com.atguigu.schedule.service;
public interface SysUserService{
}
package com.atguigu.schedule.service;
public interface SysScheduleService{
}

(2)实现类:

package com.atguigu.schedule.service.impl;
import com.atguigu.schedule.service.SysUserService;
public class SysUserServiceImpl implements SysUserService{
}
package com.atguigu.schedule.service.impl;
import com.atguigu.schedule.service.SysScheduleService;
public class SysScheduleServiceImpl implements SysScheduleService{
}


http://www.ppmy.cn/devtools/96732.html

相关文章

前端Vue监听路由变化, 点击页面内按钮跳转菜单更改导航菜单选中状态

1.问题描述 当我们进入页面时的菜单导航栏是默认选中的状态如图 点击博客园效果如图 问题1&#xff1a; 但是当我们点击页面上方返回按钮时&#xff0c;导航栏选中状态没有改变 分析问题1&#xff1a; 这个问题是因为页面改变后页面里面存储的菜单导航栏的is-active属性没有改…

触摸感应芯片原厂/抗干扰2路2通道触摸/双通道触摸方案VK3602XS SOP8

产品品牌&#xff1a;永嘉微电/VINKA 产品型号&#xff1a;VK3602XS 封装形式&#xff1a;SOP8 概述 VK3602XS具有2个触摸按键&#xff0c;可用来检测外部触摸按键上人手的触摸动作。该芯片具有 较高的集成度&#xff0c;仅需极少的外部组件便可实现触摸按键的检测。 提供了2…

【Linux】进程程序替换

目录 一、原理 二、程序替换函数 三、模拟实现简易版shell 一、原理 我们可以通过fork方法创建一个子进程&#xff0c;但是我们为什么要创建子进程呢&#xff1f; 在程序中&#xff0c;我们往往需要子进程帮助我们执行另一个程序&#xff0c;但子进程又只能和父进程共享相…

Win10下载安装Mysql服务

Win10下载安装MySQL 一、官网下载MySQL 1.官网地址&#xff1a; https://www.mysql.com/ 2.在官网首页拉到最下方&#xff0c;点击MySQL Community Server&#xff1a; 3.根据个人电脑的操作系统选择&#xff0c;此处以Windows x64为例&#xff0c;选择第2个&#xff0c;点击…

【日常记录-Java】EasyExcel输出设定字体

Author&#xff1a;赵志乾 Date&#xff1a;2024-08-15 Declaration&#xff1a;All Right Reserved&#xff01;&#xff01;&#xff01; 1. 问题描述 使用EasyExcel默认的设定输出时&#xff0c;中文字体显得比较怪异。 2. 解决方案 本质是单元格样式的设置问题&#xff0c…

参与团体标准的意义以及作用

随着经济的快速发展和科技的不断进步&#xff0c;行业的规范与统一变得愈发重要。团体标准应运而生&#xff0c;成为了推动行业前行的强大力量。参与其中&#xff0c;其所带来的作用和意义犹如璀璨星辰&#xff0c;照亮了发展的道路 参与团体标准具有诸多显著的作用&#xff0c…

GIF动图太大怎么压缩?4种方法轻松解决gif动图压缩!

GIF图像的制作方式一般有3种&#xff1a;图片转gif&#xff0c;视频转gif&#xff0c;屏幕录制gif。其中&#xff0c;屏幕录制gif 和视频转gif的形式是我们日常办公制作中最经常使用的方法&#xff0c;但是&#xff0c;这两种方法制作出来的gif动图往往因为高清晰度和时长&…

CSS的:scope伪类:精准定位表格元素的新策略

CSS&#xff08;层叠样式表&#xff09;是控制网页元素样式的强大工具。随着CSS规范的不断更新&#xff0c;新的选择器和伪类被引入&#xff0c;以增强开发者对页面元素的控制能力。:scope伪类是CSS中一个相对较新的特性&#xff0c;它允许开发者在特定的上下文中选择元素&…