计算机毕业设计 基于HTML5+CSS3的在线英语阅读分级平台的设计与实现 Java实战项目 附源码+文档+视频讲解
博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌
🍅文末获取源码联系🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟
————————————————
计算机毕业设计《1000套》✌
目录
1、项目介绍及开发技术
1.1 项目介绍
1.2 开发技术
2、系统功能设计结构图
3、功能截图
3.1 前台功能
3.2 后台功能
4、数据库表结构设计
5、关键代码
5.1 我的书架Controller模块
5.2 我的书架Service模块
5.3 我的书架ServiceImpl模块
5.4 我的书架Dao模块
6、论文目录结构
7、源码获取
1、项目介绍及开发技术
1.1 项目介绍
随着电脑和笔记本的广泛运用,以及各种计算机硬件的完善和升级,市面上的电脑和笔记本的性能都得到提升,可以支持的软件也逐渐增多,因此,在计算机上安装软件来发挥其高效地信息处理的作用,则很受人们的青睐。传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装在线英语阅读分级平台软件来发挥其高效地信息处理的作用,可以规范信息管理流程,让管理工作可以系统化和程序化,同时,在线英语阅读分级平台的有效运用可以帮助管理人员准确快速地处理信息。在线英语阅读分级平台在对开发工具的选择上也很慎重,为了便于开发实现,选择的开发工具为Eclipse,选择的数据库工具为Mysql。以此搭建开发环境实现在线英语阅读分级平台的功能。在线英语阅读分级平台是一款运用软件开发技术设计实现的应用系统,在信息处理上可以达到快速的目的,不管是针对数据添加,数据维护和统计,以及数据查询等处理要求,在线英语阅读分级平台都可以轻松应对。
1.2 开发技术
Java开发语言、SpringBoot、MyBatisPlus、MySQL数据库、Maven、IDEA开发工具、JDK1.8+、Vue、HTML、CSS、JS。
2、系统功能设计结构图

3、功能截图
3.1 前台功能
登录

首页

公告

书籍

个人中心

3.2 后台功能
登录

用户信息管理:是对用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息,还能进行对用户名称的模糊查询的条件。

书籍信息管理: 查看已发布的书籍信息数据,修改书籍信息,书籍信息作废,即可删除,还进行了对书籍信息名称的模糊查询、书籍信息的类型查询等一些条件。

章节信息管理: 根据章节信息进行条件查询,还可以对章节信息进行新增、修改、查询操作等等。

公告信息管理: 管理员根据公告信息进行新增、修改、查询操作等等。

4、数据库表结构设计
/*
SQLyog Ultimate v11.3 (64 bit)
MySQL - 5.7.32-log : Database - zaixianyingyuyuedupingtai
*********************************************************************
*//*!40101 SET NAMES utf8 */;/*!40101 SET SQL_MODE=''*/;/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
CREATE DATABASE /*!32312 IF NOT EXISTS*/`zaixianyingyuyuedupingtai` /*!40100 DEFAULT CHARACTER SET utf8 */;USE `zaixianyingyuyuedupingtai`;/*Table structure for table `config` */DROP TABLE IF EXISTS `config`;CREATE TABLE `config` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`name` varchar(100) DEFAULT NULL COMMENT '配置参数名称',`value` varchar(100) DEFAULT NULL COMMENT '配置参数值',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT='配置文件';/*Data for the table `config` */insert into `config`(`id`,`name`,`value`) values (1,'轮播图1','upload/config1.jpg'),(2,'轮播图2','upload/config2.jpg'),(3,'轮播图3','upload/config3.jpg');/*Table structure for table `dictionary` */DROP TABLE IF EXISTS `dictionary`;CREATE TABLE `dictionary` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`dic_code` varchar(200) DEFAULT NULL COMMENT '字段',`dic_name` varchar(200) DEFAULT NULL COMMENT '字段名',`code_index` int(11) DEFAULT NULL COMMENT '编码',`index_name` varchar(200) DEFAULT NULL COMMENT '编码名字 Search111 ',`super_id` int(11) DEFAULT NULL COMMENT '父字段id',`beizhu` varchar(200) DEFAULT NULL COMMENT '备注',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='字典';/*Data for the table `dictionary` */insert into `dictionary`(`id`,`dic_code`,`dic_name`,`code_index`,`index_name`,`super_id`,`beizhu`,`create_time`) values (1,'sex_types','性别类型',1,'男',NULL,NULL,'2023-04-22 11:23:42'),(2,'sex_types','性别类型',2,'女',NULL,NULL,'2023-04-22 11:23:42'),(3,'shangxia_types','上下架',1,'上架',NULL,NULL,'2023-04-22 11:23:42'),(4,'shangxia_types','上下架',2,'下架',NULL,NULL,'2023-04-22 11:23:42'),(5,'shuji_types','书籍类型',1,'书籍类型1',NULL,NULL,'2023-04-22 11:23:42'),(6,'shuji_types','书籍类型',2,'书籍类型2',NULL,NULL,'2023-04-22 11:23:42'),(7,'shuji_erji_types','二级类型',1,'书籍类型1.1',1,NULL,'2023-04-22 11:23:42'),(8,'shuji_erji_types','二级类型',2,'二级类型1.2',1,NULL,'2023-04-22 11:23:42'),(9,'shuji_erji_types','二级类型',3,'书籍类型2.1',2,NULL,'2023-04-22 11:23:42'),(10,'shuji_erji_types','二级类型',4,'书籍类型2.2',2,NULL,'2023-04-22 11:23:42'),(11,'shuji_collection_types','收藏表类型',1,'收藏',NULL,NULL,'2023-04-22 11:23:42'),(12,'zhangjie_collection_types','收藏表类型',1,'收藏',NULL,NULL,'2023-04-22 11:23:42'),(13,'gonggao_types','公告类型',1,'公告类型1',NULL,NULL,'2023-04-22 11:23:42'),(14,'gonggao_types','公告类型',2,'公告类型2',NULL,NULL,'2023-04-22 11:23:42');/*Table structure for table `gonggao` */DROP TABLE IF EXISTS `gonggao`;CREATE TABLE `gonggao` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键 ',`gonggao_name` varchar(200) DEFAULT NULL COMMENT '公告名称 Search111 ',`gonggao_photo` varchar(200) DEFAULT NULL COMMENT '公告图片 ',`gonggao_types` int(11) NOT NULL COMMENT '公告类型 Search111 ',`insert_time` timestamp NULL DEFAULT NULL COMMENT '公告发布时间 ',`gonggao_content` text COMMENT '公告详情 ',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间 show1 show2 nameShow',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='公告';/*Data for the table `gonggao` */insert into `gonggao`(`id`,`gonggao_name`,`gonggao_photo`,`gonggao_types`,`insert_time`,`gonggao_content`,`create_time`) values (1,'公告名称1','upload/gonggao1.jpg',1,'2023-04-22 11:23:56','公告详情1','2023-04-22 11:23:56'),(2,'公告名称2','upload/gonggao2.jpg',1,'2023-04-22 11:23:56','公告详情2','2023-04-22 11:23:56'),(3,'公告名称3','upload/gonggao3.jpg',1,'2023-04-22 11:23:56','公告详情3','2023-04-22 11:23:56'),(4,'公告名称4','upload/gonggao4.jpg',1,'2023-04-22 11:23:56','公告详情4','2023-04-22 11:23:56'),(5,'公告名称5','upload/gonggao5.jpg',1,'2023-04-22 11:23:56','公告详情5','2023-04-22 11:23:56'),(6,'公告名称6','upload/gonggao6.jpg',2,'2023-04-22 11:23:56','公告详情6','2023-04-22 11:23:56'),(7,'公告名称7','upload/gonggao7.jpg',1,'2023-04-22 11:23:56','公告详情7','2023-04-22 11:23:56'),(8,'公告名称8','upload/gonggao8.jpg',2,'2023-04-22 11:23:56','公告详情8','2023-04-22 11:23:56'),(9,'公告名称9','upload/gonggao9.jpg',2,'2023-04-22 11:23:56','公告详情9','2023-04-22 11:23:56'),(10,'公告名称10','upload/gonggao10.jpg',2,'2023-04-22 11:23:56','公告详情10','2023-04-22 11:23:56'),(11,'公告名称11','upload/gonggao11.jpg',2,'2023-04-22 11:23:56','公告详情11','2023-04-22 11:23:56'),(12,'公告名称12','upload/gonggao12.jpg',1,'2023-04-22 11:23:56','公告详情12','2023-04-22 11:23:56'),(13,'公告名称13','upload/gonggao13.jpg',2,'2023-04-22 11:23:56','公告详情13','2023-04-22 11:23:56'),(14,'公告名称14','upload/gonggao14.jpg',2,'2023-04-22 11:23:56','公告详情14','2023-04-22 11:23:56');/*Table structure for table `shuji` */DROP TABLE IF EXISTS `shuji`;CREATE TABLE `shuji` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键 ',`shuji_name` varchar(200) DEFAULT NULL COMMENT '书籍名称 Search111 ',`shuji_uuid_number` varchar(200) DEFAULT NULL COMMENT '书籍编号',`shuji_photo` varchar(200) DEFAULT NULL COMMENT '书籍封面',`shuji_types` int(11) DEFAULT NULL COMMENT '书籍类型 Search111',`shuji_erji_types` int(11) DEFAULT NULL COMMENT '二级类型 Search111',`shuji_clicknum` int(11) DEFAULT NULL COMMENT '书籍热度',`shuji_content` text COMMENT '书籍简介 ',`shangxia_types` int(11) DEFAULT NULL COMMENT '是否上架 ',`shuji_delete` int(11) DEFAULT NULL COMMENT '逻辑删除',`insert_time` timestamp NULL DEFAULT NULL COMMENT '录入时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间 show1 show2 photoShow',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='书籍';/*Data for the table `shuji` */insert into `shuji`(`id`,`shuji_name`,`shuji_uuid_number`,`shuji_photo`,`shuji_types`,`shuji_erji_types`,`shuji_clicknum`,`shuji_content`,`shangxia_types`,`shuji_delete`,`insert_time`,`create_time`) values (1,'书籍名称1','1682133836967','upload/shuji1.jpg',2,2,344,'书籍简介1',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,'书籍名称2','1682133837001','upload/shuji2.jpg',2,2,486,'书籍简介2',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,'书籍名称3','1682133837045','upload/shuji3.jpg',1,3,178,'书籍简介3',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,'书籍名称4','1682133837034','upload/shuji4.jpg',1,1,125,'书籍简介4',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,'书籍名称5','1682133837049','upload/shuji5.jpg',1,4,40,'书籍简介5',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(6,'书籍名称6','1682133836964','upload/shuji6.jpg',1,1,422,'书籍简介6',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,'书籍名称7','1682133836987','upload/shuji7.jpg',2,3,109,'书籍简介7',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,'书籍名称8','1682133837001','upload/shuji8.jpg',2,3,197,'书籍简介8',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(9,'书籍名称9','1682133837003','upload/shuji9.jpg',1,2,348,'书籍简介9',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,'书籍名称10','1682133837018','upload/shuji10.jpg',2,3,150,'书籍简介10',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,'书籍名称11','1682133837013','upload/shuji11.jpg',2,4,53,'书籍简介11',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(12,'书籍名称12','1682133836980','upload/shuji12.jpg',1,2,87,'书籍简介12',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,'书籍名称13','1682133837031','upload/shuji13.jpg',2,3,259,'书籍简介13',1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,'书籍名称14','1682133837010','upload/shuji14.jpg',1,4,340,'书籍简介14',2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56');/*Table structure for table `shuji_collection` */DROP TABLE IF EXISTS `shuji_collection`;CREATE TABLE `shuji_collection` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`shuji_id` int(11) DEFAULT NULL COMMENT '书籍',`yonghu_id` int(11) DEFAULT NULL COMMENT '用户',`shuji_collection_types` int(11) DEFAULT NULL COMMENT '类型',`insert_time` timestamp NULL DEFAULT NULL COMMENT '收藏时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间 show3 photoShow',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='我的书架';/*Data for the table `shuji_collection` */insert into `shuji_collection`(`id`,`shuji_id`,`yonghu_id`,`shuji_collection_types`,`insert_time`,`create_time`) values (1,1,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,2,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,3,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,4,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,5,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(6,6,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,7,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,8,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,10,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,11,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(12,12,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,13,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,14,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56');/*Table structure for table `shuji_liuyan` */DROP TABLE IF EXISTS `shuji_liuyan`;CREATE TABLE `shuji_liuyan` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`shuji_id` int(11) DEFAULT NULL COMMENT '书籍',`yonghu_id` int(11) DEFAULT NULL COMMENT '用户',`shuji_liuyan_text` text COMMENT '评论内容',`insert_time` timestamp NULL DEFAULT NULL COMMENT '评论时间',`reply_text` text COMMENT '回复内容',`update_time` timestamp NULL DEFAULT NULL COMMENT '回复时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='书籍评论';/*Data for the table `shuji_liuyan` */insert into `shuji_liuyan`(`id`,`shuji_id`,`yonghu_id`,`shuji_liuyan_text`,`insert_time`,`reply_text`,`update_time`,`create_time`) values (1,1,2,'评论内容1','2023-04-22 11:23:56','回复信息1','2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,2,3,'评论内容2','2023-04-22 11:23:56','回复信息2','2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,3,3,'评论内容3','2023-04-22 11:23:56','回复信息3','2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,4,1,'评论内容4','2023-04-22 11:23:56','回复信息4','2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,5,1,'评论内容5','2023-04-22 11:23:56','回复信息5','2023-04-22 11:23:56','2023-04-22 11:23:56'),(6,6,3,'评论内容6','2023-04-22 11:23:56','回复信息6','2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,7,1,'评论内容7','2023-04-22 11:23:56','回复信息7','2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,8,1,'评论内容8','2023-04-22 11:23:56','回复信息8','2023-04-22 11:23:56','2023-04-22 11:23:56'),(9,9,2,'评论内容9','2023-04-22 11:23:56','回复信息9','2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,10,2,'评论内容10','2023-04-22 11:23:56','回复信息10','2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,11,2,'评论内容11','2023-04-22 11:23:56','回复信息11','2023-04-22 11:23:56','2023-04-22 11:23:56'),(12,12,3,'评论内容12','2023-04-22 11:23:56','回复信息12','2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,13,2,'评论内容13','2023-04-22 11:23:56','回复信息13','2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,14,1,'评论内容14','2023-04-22 11:23:56','回复信息14','2023-04-22 11:23:56','2023-04-22 11:23:56');/*Table structure for table `token` */DROP TABLE IF EXISTS `token`;CREATE TABLE `token` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`userid` bigint(20) NOT NULL COMMENT '学生id',`username` varchar(100) NOT NULL COMMENT '学生名',`tablename` varchar(100) DEFAULT NULL COMMENT '表名',`role` varchar(100) DEFAULT NULL COMMENT '角色',`token` varchar(200) NOT NULL COMMENT '密码',`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '新增时间',`expiratedtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '过期时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COMMENT='token表';/*Data for the table `token` */insert into `token`(`id`,`userid`,`username`,`tablename`,`role`,`token`,`addtime`,`expiratedtime`) values (1,1,'admin','users','管理员','vy1s3i71bbdasen38iyq4rmu11493jyq','2023-04-22 11:34:29','2023-04-22 14:26:44'),(2,1,'a1','yonghu','用户','qwf3uq14chy89d9ij86jw7vfvq9mzbes','2023-04-22 12:00:22','2023-04-22 14:25:20');/*Table structure for table `users` */DROP TABLE IF EXISTS `users`;CREATE TABLE `users` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`username` varchar(100) NOT NULL COMMENT '学生名',`password` varchar(100) NOT NULL COMMENT '密码',`role` varchar(100) DEFAULT '管理员' COMMENT '角色',`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '新增时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='管理员';/*Data for the table `users` */insert into `users`(`id`,`username`,`password`,`role`,`addtime`) values (1,'admin','admin','管理员','2023-04-22 11:23:42');/*Table structure for table `yonghu` */DROP TABLE IF EXISTS `yonghu`;CREATE TABLE `yonghu` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`username` varchar(200) DEFAULT NULL COMMENT '账户',`password` varchar(200) DEFAULT NULL COMMENT '密码',`yonghu_name` varchar(200) DEFAULT NULL COMMENT '用户姓名 Search111 ',`yonghu_phone` varchar(200) DEFAULT NULL COMMENT '用户手机号',`yonghu_id_number` varchar(200) DEFAULT NULL COMMENT '用户身份证号',`yonghu_photo` varchar(200) DEFAULT NULL COMMENT '用户头像',`sex_types` int(11) DEFAULT NULL COMMENT '性别',`yonghu_email` varchar(200) DEFAULT NULL COMMENT '用户邮箱',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT='用户';/*Data for the table `yonghu` */insert into `yonghu`(`id`,`username`,`password`,`yonghu_name`,`yonghu_phone`,`yonghu_id_number`,`yonghu_photo`,`sex_types`,`yonghu_email`,`create_time`) values (1,'a1','123456','用户姓名1','17703786901','410224199010102001','upload/yonghu1.jpg',2,'1@qq.com','2023-04-22 11:23:56'),(2,'a2','123456','用户姓名2','17703786902','410224199010102002','upload/yonghu2.jpg',1,'2@qq.com','2023-04-22 11:23:56'),(3,'a3','123456','用户姓名3','17703786903','410224199010102003','upload/yonghu3.jpg',1,'3@qq.com','2023-04-22 11:23:56');/*Table structure for table `youlanjilu` */DROP TABLE IF EXISTS `youlanjilu`;CREATE TABLE `youlanjilu` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键 ',`yonghu_id` int(11) DEFAULT NULL COMMENT '用户',`youlan_tableid` int(11) DEFAULT NULL COMMENT '游览表id',`youlan_tablename` varchar(200) DEFAULT NULL COMMENT '游览表名称 Search111 ',`youlan_name` varchar(200) DEFAULT NULL COMMENT '名称 Search111 ',`youlan_photo` varchar(200) DEFAULT NULL COMMENT '图片',`insert_time` timestamp NULL DEFAULT NULL COMMENT '游览时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4401 DEFAULT CHARSET=utf8 COMMENT='游览记录';/*Data for the table `youlanjilu` */insert into `youlanjilu`(`id`,`yonghu_id`,`youlan_tableid`,`youlan_tablename`,`youlan_name`,`youlan_photo`,`insert_time`,`create_time`) values (4396,1,4,'shuji','书籍名称4','upload/shuji4.jpg','2023-04-22 13:24:08','2023-04-22 13:24:08'),(4397,1,14,'shuji','书籍名称14','upload/shuji14.jpg','2023-04-22 13:24:13','2023-04-22 13:24:13'),(4398,1,14,'shuji','书籍名称14','upload/shuji14.jpg','2023-04-22 13:24:23','2023-04-22 13:24:23'),(4399,1,14,'shuji','书籍名称14','upload/shuji14.jpg','2023-04-22 13:24:36','2023-04-22 13:24:36'),(4400,1,14,'shuji','书籍名称14','upload/shuji14.jpg','2023-04-22 13:24:57','2023-04-22 13:24:57');/*Table structure for table `zhangjie` */DROP TABLE IF EXISTS `zhangjie`;CREATE TABLE `zhangjie` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键 ',`shuji_id` int(11) DEFAULT NULL COMMENT '书籍',`zhangjie_name` varchar(200) DEFAULT NULL COMMENT '章节标题 Search111 ',`zhangjie_clicknum` int(11) DEFAULT NULL COMMENT '章节热度',`zhangjie_xuhao` int(11) DEFAULT NULL COMMENT '序号',`zhangjie_content` text COMMENT '章节内容 ',`insert_time` timestamp NULL DEFAULT NULL COMMENT '发布时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间 show2 photoShow',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='章节';/*Data for the table `zhangjie` */insert into `zhangjie`(`id`,`shuji_id`,`zhangjie_name`,`zhangjie_clicknum`,`zhangjie_xuhao`,`zhangjie_content`,`insert_time`,`create_time`) values (1,14,'章节标题1',56,14,'章节内容1','2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,14,'章节标题2',443,14,'章节内容2','2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,14,'章节标题3',332,14,'章节内容3','2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,14,'章节标题4',452,14,'章节内容4','2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,14,'章节标题5',139,14,'章节内容5','2023-04-22 11:23:56','2023-04-22 11:23:56'),(6,14,'章节标题6',252,14,'章节内容6','2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,14,'章节标题7',355,14,'章节内容7','2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,14,'章节标题8',334,14,'章节内容8','2023-04-22 11:23:56','2023-04-22 11:23:56'),(9,14,'章节标题9',51,14,'章节内容9','2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,14,'章节标题10',347,14,'章节内容10','2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,14,'章节标题11',492,14,'章节内容11','2023-04-22 11:23:56','2023-04-22 11:23:56'),(12,14,'章节标题12',419,14,'章节内容12','2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,14,'章节标题13',335,14,'章节内容13','2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,14,'章节标题14',171,14,'章节内容14','2023-04-22 11:23:56','2023-04-22 11:23:56');/*Table structure for table `zhangjie_collection` */DROP TABLE IF EXISTS `zhangjie_collection`;CREATE TABLE `zhangjie_collection` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`zhangjie_id` int(11) DEFAULT NULL COMMENT '章节',`yonghu_id` int(11) DEFAULT NULL COMMENT '用户',`zhangjie_collection_types` int(11) DEFAULT NULL COMMENT '类型',`insert_time` timestamp NULL DEFAULT NULL COMMENT '收藏时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间 show3 photoShow',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='章节收藏';/*Data for the table `zhangjie_collection` */insert into `zhangjie_collection`(`id`,`zhangjie_id`,`yonghu_id`,`zhangjie_collection_types`,`insert_time`,`create_time`) values (1,1,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,2,2,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,3,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,4,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,5,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,7,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,8,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(9,9,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,10,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,11,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,13,1,1,'2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,14,3,1,'2023-04-22 11:23:56','2023-04-22 11:23:56');/*Table structure for table `zhangjie_liuyan` */DROP TABLE IF EXISTS `zhangjie_liuyan`;CREATE TABLE `zhangjie_liuyan` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`zhangjie_id` int(11) DEFAULT NULL COMMENT '章节',`yonghu_id` int(11) DEFAULT NULL COMMENT '用户',`zhangjie_liuyan_text` text COMMENT '评论内容',`insert_time` timestamp NULL DEFAULT NULL COMMENT '评论时间',`reply_text` text COMMENT '回复内容',`update_time` timestamp NULL DEFAULT NULL COMMENT '回复时间',`create_time` timestamp NULL DEFAULT NULL COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8 COMMENT='章节评论';/*Data for the table `zhangjie_liuyan` */insert into `zhangjie_liuyan`(`id`,`zhangjie_id`,`yonghu_id`,`zhangjie_liuyan_text`,`insert_time`,`reply_text`,`update_time`,`create_time`) values (1,1,2,'评论内容1','2023-04-22 11:23:56','回复信息1','2023-04-22 11:23:56','2023-04-22 11:23:56'),(2,2,2,'评论内容2','2023-04-22 11:23:56','回复信息2','2023-04-22 11:23:56','2023-04-22 11:23:56'),(3,3,3,'评论内容3','2023-04-22 11:23:56','回复信息3','2023-04-22 11:23:56','2023-04-22 11:23:56'),(4,4,2,'评论内容4','2023-04-22 11:23:56','回复信息4','2023-04-22 11:23:56','2023-04-22 11:23:56'),(5,5,3,'评论内容5','2023-04-22 11:23:56','回复信息5','2023-04-22 11:23:56','2023-04-22 11:23:56'),(6,6,1,'评论内容6','2023-04-22 11:23:56','回复信息6','2023-04-22 11:23:56','2023-04-22 11:23:56'),(7,7,2,'评论内容7','2023-04-22 11:23:56','回复信息7','2023-04-22 11:23:56','2023-04-22 11:23:56'),(8,8,1,'评论内容8','2023-04-22 11:23:56','回复信息8','2023-04-22 11:23:56','2023-04-22 11:23:56'),(9,9,1,'评论内容9','2023-04-22 11:23:56','回复信息9','2023-04-22 11:23:56','2023-04-22 11:23:56'),(10,10,1,'评论内容10','2023-04-22 11:23:56','回复信息10','2023-04-22 11:23:56','2023-04-22 11:23:56'),(11,11,1,'评论内容11','2023-04-22 11:23:56','回复信息11','2023-04-22 11:23:56','2023-04-22 11:23:56'),(12,12,2,'评论内容12','2023-04-22 11:23:56','回复信息12','2023-04-22 11:23:56','2023-04-22 11:23:56'),(13,13,2,'评论内容13','2023-04-22 11:23:56','回复信息13','2023-04-22 11:23:56','2023-04-22 11:23:56'),(14,14,1,'评论内容14','2023-04-22 11:23:56','回复信息14','2023-04-22 11:23:56','2023-04-22 11:23:56'),(15,1,1,'1111111','2023-04-22 13:24:31','2222','2023-04-22 13:25:35','2023-04-22 13:24:31');/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
5、关键代码
5.1 我的书架Controller模块
/*** 我的书架* 后端接口* @author 学长编程* @email* WeChat jsjbysj88
*/
@RestController
@Controller
@RequestMapping("/shujiCollection")
public class ShujiCollectionController {private static final Logger logger = LoggerFactory.getLogger(ShujiCollectionController.class);private static final String TABLE_NAME = "shujiCollection";@Autowiredprivate ShujiCollectionService shujiCollectionService;@Autowiredprivate TokenService tokenService;@Autowiredprivate DictionaryService dictionaryService;//字典@Autowiredprivate GonggaoService gonggaoService;//公告@Autowiredprivate ShujiService shujiService;//书籍@Autowiredprivate ShujiLiuyanService shujiLiuyanService;//书籍评论@Autowiredprivate YonghuService yonghuService;//用户@Autowiredprivate YoulanjiluService youlanjiluService;//游览记录@Autowiredprivate ZhangjieService zhangjieService;//章节@Autowiredprivate ZhangjieCollectionService zhangjieCollectionService;//章节收藏@Autowiredprivate ZhangjieLiuyanService zhangjieLiuyanService;//章节评论@Autowiredprivate UsersService usersService;//管理员/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));String role = String.valueOf(request.getSession().getAttribute("role"));if(false)return R.error(511,"永不会进入");else if("用户".equals(role))params.put("yonghuId",request.getSession().getAttribute("userId"));CommonUtil.checkMap(params);PageUtils page = shujiCollectionService.queryPage(params);//字典表数据转换List<ShujiCollectionView> list =(List<ShujiCollectionView>)page.getList();for(ShujiCollectionView c:list){//修改对应字典表字段dictionaryService.dictionaryConvert(c, request);}return R.ok().put("data", page);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id, HttpServletRequest request){logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);ShujiCollectionEntity shujiCollection = shujiCollectionService.selectById(id);if(shujiCollection !=null){//entity转viewShujiCollectionView view = new ShujiCollectionView();BeanUtils.copyProperties( shujiCollection , view );//把实体数据重构到view中//级联表 书籍//级联表ShujiEntity shuji = shujiService.selectById(shujiCollection.getShujiId());if(shuji != null){BeanUtils.copyProperties( shuji , view ,new String[]{ "id", "createTime", "insertTime", "updateTime", "yonghuId"});//把级联的数据添加到view中,并排除id和创建时间字段,当前表的级联注册表view.setShujiId(shuji.getId());}//级联表 用户//级联表YonghuEntity yonghu = yonghuService.selectById(shujiCollection.getYonghuId());if(yonghu != null){BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createTime", "insertTime", "updateTime", "yonghuId"});//把级联的数据添加到view中,并排除id和创建时间字段,当前表的级联注册表view.setYonghuId(yonghu.getId());}//修改对应字典表字段dictionaryService.dictionaryConvert(view, request);return R.ok().put("data", view);}else {return R.error(511,"查不到数据");}}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody ShujiCollectionEntity shujiCollection, HttpServletRequest request){logger.debug("save方法:,,Controller:{},,shujiCollection:{}",this.getClass().getName(),shujiCollection.toString());String role = String.valueOf(request.getSession().getAttribute("role"));if(false)return R.error(511,"永远不会进入");else if("用户".equals(role))shujiCollection.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));Wrapper<ShujiCollectionEntity> queryWrapper = new EntityWrapper<ShujiCollectionEntity>().eq("shuji_id", shujiCollection.getShujiId()).eq("yonghu_id", shujiCollection.getYonghuId()).eq("shuji_collection_types", shujiCollection.getShujiCollectionTypes());logger.info("sql语句:"+queryWrapper.getSqlSegment());ShujiCollectionEntity shujiCollectionEntity = shujiCollectionService.selectOne(queryWrapper);if(shujiCollectionEntity==null){shujiCollection.setInsertTime(new Date());shujiCollection.setCreateTime(new Date());shujiCollectionService.insert(shujiCollection);return R.ok();}else {return R.error(511,"表中有相同数据");}}/*** 后端修改*/@RequestMapping("/update")public R update(@RequestBody ShujiCollectionEntity shujiCollection, HttpServletRequest request) throws NoSuchFieldException, ClassNotFoundException, IllegalAccessException, InstantiationException {logger.debug("update方法:,,Controller:{},,shujiCollection:{}",this.getClass().getName(),shujiCollection.toString());ShujiCollectionEntity oldShujiCollectionEntity = shujiCollectionService.selectById(shujiCollection.getId());//查询原先数据String role = String.valueOf(request.getSession().getAttribute("role"));
// if(false)
// return R.error(511,"永远不会进入");
// else if("用户".equals(role))
// shujiCollection.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));shujiCollectionService.updateById(shujiCollection);//根据id更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Integer[] ids, HttpServletRequest request){logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());List<ShujiCollectionEntity> oldShujiCollectionList =shujiCollectionService.selectBatchIds(Arrays.asList(ids));//要删除的数据shujiCollectionService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 批量上传*/@RequestMapping("/batchInsert")public R save( String fileName, HttpServletRequest request){logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);Integer yonghuId = Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId")));SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//.eq("time", new SimpleDateFormat("yyyy-MM-dd").format(new Date()))try {List<ShujiCollectionEntity> shujiCollectionList = new ArrayList<>();//上传的东西Map<String, List<String>> seachFields= new HashMap<>();//要查询的字段Date date = new Date();int lastIndexOf = fileName.lastIndexOf(".");if(lastIndexOf == -1){return R.error(511,"该文件没有后缀");}else{String suffix = fileName.substring(lastIndexOf);if(!".xls".equals(suffix)){return R.error(511,"只支持后缀为xls的excel文件");}else{URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);//获取文件路径File file = new File(resource.getFile());if(!file.exists()){return R.error(511,"找不到上传文件,请联系管理员");}else{List<List<String>> dataList = PoiUtil.poiImport(file.getPath());//读取xls文件dataList.remove(0);//删除第一行,因为第一行是提示for(List<String> data:dataList){//循环ShujiCollectionEntity shujiCollectionEntity = new ShujiCollectionEntity();
// shujiCollectionEntity.setShujiId(Integer.valueOf(data.get(0))); //书籍 要改的
// shujiCollectionEntity.setYonghuId(Integer.valueOf(data.get(0))); //用户 要改的
// shujiCollectionEntity.setShujiCollectionTypes(Integer.valueOf(data.get(0))); //类型 要改的
// shujiCollectionEntity.setInsertTime(date);//时间
// shujiCollectionEntity.setCreateTime(date);//时间shujiCollectionList.add(shujiCollectionEntity);//把要查询是否重复的字段放入map中}//查询是否重复shujiCollectionService.insertBatch(shujiCollectionList);return R.ok();}}}}catch (Exception e){e.printStackTrace();return R.error(511,"批量插入数据异常,请联系管理员");}}/*** 前端列表*/@IgnoreAuth@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params, HttpServletRequest request){logger.debug("list方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));CommonUtil.checkMap(params);PageUtils page = shujiCollectionService.queryPage(params);//字典表数据转换List<ShujiCollectionView> list =(List<ShujiCollectionView>)page.getList();for(ShujiCollectionView c:list)dictionaryService.dictionaryConvert(c, request); //修改对应字典表字段return R.ok().put("data", page);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Integer id, HttpServletRequest request){logger.debug("detail方法:,,Controller:{},,id:{}",this.getClass().getName(),id);ShujiCollectionEntity shujiCollection = shujiCollectionService.selectById(id);if(shujiCollection !=null){//entity转viewShujiCollectionView view = new ShujiCollectionView();BeanUtils.copyProperties( shujiCollection , view );//把实体数据重构到view中//级联表ShujiEntity shuji = shujiService.selectById(shujiCollection.getShujiId());if(shuji != null){BeanUtils.copyProperties( shuji , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段view.setShujiId(shuji.getId());}//级联表YonghuEntity yonghu = yonghuService.selectById(shujiCollection.getYonghuId());if(yonghu != null){BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段view.setYonghuId(yonghu.getId());}//修改对应字典表字段dictionaryService.dictionaryConvert(view, request);if(String.valueOf(request.getSession().getAttribute("role")).equals("用户"))//只有 用户 才能添加游览记录youlanjiluService.insertYoulanjilu((Integer) request.getSession().getAttribute("userId"),TABLE_NAME,shuji.getId(),shuji.getShujiName(),shuji.getShujiPhoto());return R.ok().put("data", view);}else {return R.error(511,"查不到数据");}}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody ShujiCollectionEntity shujiCollection, HttpServletRequest request){logger.debug("add方法:,,Controller:{},,shujiCollection:{}",this.getClass().getName(),shujiCollection.toString());Wrapper<ShujiCollectionEntity> queryWrapper = new EntityWrapper<ShujiCollectionEntity>().eq("shuji_id", shujiCollection.getShujiId()).eq("yonghu_id", shujiCollection.getYonghuId()).eq("shuji_collection_types", shujiCollection.getShujiCollectionTypes())
// .notIn("shuji_collection_types", new Integer[]{102});logger.info("sql语句:"+queryWrapper.getSqlSegment());ShujiCollectionEntity shujiCollectionEntity = shujiCollectionService.selectOne(queryWrapper);if(shujiCollectionEntity==null){shujiCollection.setInsertTime(new Date());shujiCollection.setCreateTime(new Date());shujiCollectionService.insert(shujiCollection);return R.ok();}else {return R.error(511,"您已经收藏过了");}}}
5.2 我的书架Service模块
package com.service;import com.baomidou.mybatisplus.service.IService;
import com.utils.PageUtils;
import com.entity.ShujiCollectionEntity;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.lang.Nullable;
import java.util.List;/*** 我的书架 服务类*/
public interface ShujiCollectionService extends IService<ShujiCollectionEntity> {/*** @param params 查询参数* @return 带分页的查询出来的数据*/PageUtils queryPage(Map<String, Object> params);}
5.3 我的书架ServiceImpl模块
package com.service.impl;import com.utils.StringUtil;
import com.service.DictionaryService;
import com.utils.ClazzDiff;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.lang.reflect.Field;
import java.util.*;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import org.springframework.transaction.annotation.Transactional;
import com.utils.PageUtils;
import com.utils.Query;
import org.springframework.web.context.ContextLoader;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import org.springframework.lang.Nullable;
import org.springframework.util.Assert;
import com.dao.ShujiCollectionDao;
import com.entity.ShujiCollectionEntity;
import com.service.ShujiCollectionService;
import com.entity.view.ShujiCollectionView;/*** 我的书架 服务实现类*/
@Service("shujiCollectionService")
@Transactional
public class ShujiCollectionServiceImpl extends ServiceImpl<ShujiCollectionDao, ShujiCollectionEntity> implements ShujiCollectionService {@Overridepublic PageUtils queryPage(Map<String,Object> params) {Page<ShujiCollectionView> page =new Query<ShujiCollectionView>(params).getPage();page.setRecords(baseMapper.selectListView(page,params));return new PageUtils(page);}}
5.4 我的书架Dao模块
package com.dao;import com.entity.ShujiCollectionEntity;
import com.baomidou.mybatisplus.mapper.BaseMapper;
import java.util.List;
import java.util.Map;
import com.baomidou.mybatisplus.plugins.pagination.Pagination;import org.apache.ibatis.annotations.Param;
import com.entity.view.ShujiCollectionView;/*** 我的书架 Dao 接口** @author 学长编程* WeChat jsjbysj88
*/
public interface ShujiCollectionDao extends BaseMapper<ShujiCollectionEntity> {List<ShujiCollectionView> selectListView(Pagination page,@Param("params")Map<String,Object> params);}
6、论文目录结构

7、源码获取
感谢大家的阅读,如有不懂的问题可以评论区交流或私聊!
喜欢文章可以点赞、收藏、关注、评论啦
→获取源码请私信←
相关文章:
计算机毕业设计 基于HTML5+CSS3的在线英语阅读分级平台的设计与实现 Java实战项目 附源码+文档+视频讲解
博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…...
云原生|kubernetes|kubernetes资源备份和集群迁移神器velero的部署和使用
前言: kubernetes集群需要灾备吗?kubernetes需要迁移吗? 答案肯定是需要的 那么,如何做kubernetes灾备和迁移呢?当然了,有很多的方法,例如,自己编写shell脚本,或者使用…...
【26.4K⭐】ShareX:一款开源免费、功能强大且丰富的截屏录屏软件
【26.4K⭐】ShareX:一款开源免费、功能强大且丰富的截屏录屏软件 在日常工作、学习和娱乐过程中,我们经常需要截取屏幕或者录制屏幕上特定区域中的内容并进行标记、编辑等操作。无论是为了记录重要的信息、分享有趣的内容,还是为了制作教程和…...
什么是ajax,为什么使用ajax?
概念:ajax是一种现有的技术集合,技术内容包括:HTML或XHTML,CSS,JavaScript,DOM,XML,XSLT,以及最重要的XMLHttpRequest。用于浏览器与服务器之间使用异步传输,做到局部请求以实现局部刷新。 作用…...
AI面板识别 - 华为OD统一考试
OD统一考试 (B卷) 分值: 100分 题解: Java / Python / C++ 题目描述 AI识别到面板上有N(1 ≤ N ≤ 100)个指示灯,灯大小一样,任意两个之间无重叠。 由于AI识别误差,每次别到的指示灯位置可能有差异,以4个坐标值描述AI识别的指示灯的大小和位置(左上角x1,y1,右下角x2…...
Linux之磁盘分区,挂载
Linux分区 分区介绍 对linux来说无论有几个分区,分给哪个目录使用,归根结底只有一个根目录,linux中每个分区都是用来组成整个文件系统的一部分。linux采用“载入"的处理方法,他的整个文件系统中包含一整套的文件和目录&…...
2核2G3M服务器上传速度多少?以阿里云和腾讯云为例
2核2G3M服务器上传速度多少?上传是按10M带宽算,上传速度是1280KB/秒,即1.25M/秒;下载速度按3M带宽计算,下载速度是384KB/秒。本文是以阿里云为例的,阿里云服务器当公网带宽小于10M及10M以下时,上…...
Cisco模拟器-OSPF路由协议
设计要求用两台双口路由器连接不同IP网段的计算机,并使用OSFP协议发现路由表使不同IP网段的计算机可以相互通信。 通过设计,可以连通IP地址网段不同的局域网,可应用在园区网的互连和互通的实现上。 主要配置步骤 路由器0: Router…...
SpEL 的使用
SpEL 的使用 SpEL的全称为 Spring Expression Language,具有再运行时构建复杂表达式、存取对象图属性、对象方法调用等功能 下面是一个简单样例 public class SpelTest { Test public void test1() { ExpressionParser parser new SpelExpressionParser(); …...
数据采集实战:电商详情页数据埋点
本文我们以电商产品的商品详情页为例,介绍如何做用户浏览以及点击行为的数据埋点。 案例中包含一个页面(商品详情页)以及该页面上的关键按钮(加购、收藏按钮),具体页面如下图所示。 (1…...
计算机网络——计算大题(七)
前言: 最近也是在准备计算机考试,我们的考试形式是上机考试,所以可能有些计算题是会给提供思路的,前面已经对本学期的计算机网络知识有了一个简单的认识与了解,现在我们就来对计算大题进行一个学习吧,这里的…...
子网掩码与IP段计算
一.什么叫子网掩码: 子网掩码(subnet mask)又叫网络掩码、地址掩码、子网络遮罩,它用来指明一个IP地址的哪些位标识的是主机所在的子网,以及哪些位标识的是主机的位掩码。子网掩码不能单独存在,它必须结合IP地址一起使用。 子网掩…...
【译文】IEEE白皮书 6G 太赫兹技术的基本原理 2023版
第一章 简介 太赫兹波是介于微波和光波之间的光谱区域,频率从 0.1THz ~ 10THz 之间,波长在 3mm ~ 30μm 之间。提供大块连续的频带范围以满足对 Tbit/s 内极高数据传输速率的需求,使该区域成为下一代无线通信(6G)的重…...
AUTOSAR从入门到精通-网络通信(UDPNm)(三)
目录 前言 原理 网络状态 初始化 执行 处理器架构 时间参数...
ubuntu 使用openssl制作一个自签名证书
我们需要为浏览器创建自己的根CA证书来信任自签名证书。因此,让我们首先创建根CA证书 创建根CA证书 创建文件夹 mkdir openssl && cd openssl执行以下openssl命令,生成 rootCA.key 以及 rootCA.crt. 用你的域名或者ip地址替换demo.mlopshub.c…...
WPF+Halcon 培训项目实战(1-5):Halcon安装,图像处理,Halcon简单模板匹配
文章目录 前言相关链接项目专栏我个人对就业市场的评价Halcon安装实战1-4:Halcon基础实战5:模板匹配[形状匹配]实战代码 结尾 前言 为了更好地去学习WPFHalcon,我决定去报个班学一下。原因无非是想换个工作。相关的教学视频来源于下方的Up主…...
虚函数的讲解
文章目录 虚函数的声明与定义代码演示基类Person派生类Man派生类Woman 测试代码动态绑定静态绑定访问私有虚函数总结一下通过成员函数指针调用函数的方式 虚函数的声明与定义 虚函数存在于C的类、结构体等中,不能存在于全局函数中,只能作为成员函数存在…...
Java强软弱虚引用
面试: 1.强引用,软引用,弱引用,虚引用分别是什么? 2.软引用和弱引用适用的场景? 3.你知道弱引用的话,能谈谈WeakHashMap吗? 目录 一、Java引用 1、强引用(默认支持模式…...
QCharView使用
QCharView概念:title、系列、图标Chart、视图 说明: 需要添加Qt组件charts 在使用QChart或者QChartView之前需要添加宏定义QT_CHARTS_USE_NAMESPACE (其实是使用了命名空间),不然不能识别QChart或者QChartView 3.在添加宏定义QT_CHARTS_USE_N…...
华为hcia之ipv6实验手册
R3: dhcp enable ipv6 dhcpv6 pool test address prefix 2000:23::/64 excluded-address 2000:23::2 dns-server 2000:23::2 interface GigabitEthernet0/0/0 ipv6 enable ipv6 address 2000:12::2/64 ipv6 address auto link-local undo ipv6 nd ra halt //无状态配置 inter…...
黑马Mybatis
Mybatis 表现层:页面展示 业务层:逻辑处理 持久层:持久数据化保存 在这里插入图片描述 Mybatis快速入门 ,你需要做出一个**决定性判断**:恶性还是良性?这种“非黑即白”的抉择,正是**逻辑回归(Logistic Regression)** 的战场&a…...
Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...
OkHttp 中实现断点续传 demo
在 OkHttp 中实现断点续传主要通过以下步骤完成,核心是利用 HTTP 协议的 Range 请求头指定下载范围: 实现原理 Range 请求头:向服务器请求文件的特定字节范围(如 Range: bytes1024-) 本地文件记录:保存已…...
全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...
CRMEB 中 PHP 短信扩展开发:涵盖一号通、阿里云、腾讯云、创蓝
目前已有一号通短信、阿里云短信、腾讯云短信扩展 扩展入口文件 文件目录 crmeb\services\sms\Sms.php 默认驱动类型为:一号通 namespace crmeb\services\sms;use crmeb\basic\BaseManager; use crmeb\services\AccessTokenServeService; use crmeb\services\sms\…...
【Post-process】【VBA】ETABS VBA FrameObj.GetNameList and write to EXCEL
ETABS API实战:导出框架元素数据到Excel 在结构工程师的日常工作中,经常需要从ETABS模型中提取框架元素信息进行后续分析。手动复制粘贴不仅耗时,还容易出错。今天我们来用简单的VBA代码实现自动化导出。 🎯 我们要实现什么? 一键点击,就能将ETABS中所有框架元素的基…...
【Linux】Linux安装并配置RabbitMQ
目录 1. 安装 Erlang 2. 安装 RabbitMQ 2.1.添加 RabbitMQ 仓库 2.2.安装 RabbitMQ 3.配置 3.1.启动和管理服务 4. 访问管理界面 5.安装问题 6.修改密码 7.修改端口 7.1.找到文件 7.2.修改文件 1. 安装 Erlang 由于 RabbitMQ 是用 Erlang 编写的,需要先安…...
02.运算符
目录 什么是运算符 算术运算符 1.基本四则运算符 2.增量运算符 3.自增/自减运算符 关系运算符 逻辑运算符 &&:逻辑与 ||:逻辑或 !:逻辑非 短路求值 位运算符 按位与&: 按位或 | 按位取反~ …...
解析“道作为序位生成器”的核心原理
解析“道作为序位生成器”的核心原理 以下完整展开道函数的零点调控机制,重点解析"道作为序位生成器"的核心原理与实现框架: 一、道函数的零点调控机制 1. 道作为序位生成器 道在认知坐标系$(x_{\text{物}}, y_{\text{意}}, z_{\text{文}}…...
