前后端分离(前后端交互步骤)

1.设计数据库

/*Navicat Premium Data Transfer
​Source Server         : localhost_3306Source Server Type    : MySQLSource Server Version : 80037 (8.0.37)Source Host           : localhost:3306Source Schema         : studymysql
​Target Server Type    : MySQLTarget Server Version : 80037 (8.0.37)File Encoding         : 65001
​Date: 24/12/2024 11:32:08
*/
​
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
​
-- ----------------------------
-- Table structure for emp
-- ----------------------------
DROP TABLE IF EXISTS `emp`;
CREATE TABLE `emp`  (`empno` int NOT NULL AUTO_INCREMENT COMMENT '雇员编号',`ename` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '雇员姓名',`job` varchar(9) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '表示工作职位',`mgr` int NULL DEFAULT NULL COMMENT '表示一个雇员的领导编号',`hiredate` datetime NULL DEFAULT NULL COMMENT '表示雇佣日期',`sal` double NULL DEFAULT NULL COMMENT '表示月薪,工资',`comm` double NULL DEFAULT NULL COMMENT '表示奖金或佣金',`deptno` int NULL DEFAULT NULL,PRIMARY KEY (`empno`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;
​
-- ----------------------------
-- Records of emp
-- ----------------------------
​
SET FOREIGN_KEY_CHECKS = 1;
​

2.编写实体类和数据库形成映射

package com.pyb.pojo;
​
/*** @version 1.0* @Author 彭彦彬* @Date 2024/12/24 15:07* @注释*/
public class Emp {private int empNo;private String eName;private String job;private int mgr;private String hireDate;private double sal;private double comm;private int deptNo;
​public Emp(int empNo, String eName, String job, int mgr, String hireDate, double sal, double comm, int deptNo) {this.empNo = empNo;this.eName = eName;this.job = job;this.mgr = mgr;this.hireDate = hireDate;this.sal = sal;this.comm = comm;this.deptNo = deptNo;}
​public Emp(String eName, String job) {this.eName = eName;this.job = job;}
​public Emp(String eName, String job, int mgr, String hireDate, double sal, int deptNo, double comm) {this.eName = eName;this.job = job;this.mgr = mgr;this.hireDate = hireDate;this.sal = sal;this.deptNo = deptNo;this.comm = comm;}
​@Overridepublic String toString() {return "Emp{" +"empNo=" + empNo +", eName='" + eName + '\'' +", job='" + job + '\'' +", mgr=" + mgr +", hireDate='" + hireDate + '\'' +", sal=" + sal +", comm=" + comm +", deptNo=" + deptNo +'}';}
​public Emp() {}
​public int getEmpNo() {return empNo;}
​public void setEmpNo(int empNo) {this.empNo = empNo;}
​public String geteName() {return eName;}
​public void seteName(String eName) {this.eName = eName;}
​public String getJob() {return job;}
​public void setJob(String job) {this.job = job;}
​public int getMgr() {return mgr;}
​public void setMgr(int mgr) {this.mgr = mgr;}
​public String getHireDate() {return hireDate;}
​public void setHireDate(String hireDate) {this.hireDate = hireDate;}
​public double getSal() {return sal;}
​public void setSal(double sal) {this.sal = sal;}
​public double getComm() {return comm;}
​public void setComm(double comm) {this.comm = comm;}
​public int getDeptNo() {return deptNo;}
​public void setDeptNo(int deptNo) {this.deptNo = deptNo;}
}
​

3.编写数据和Java代码交互逻辑

  • 定义业务接口

package com.pyb.dao;
​
import com.pyb.pojo.Emp;
import java.sql.SQLException;
import java.util.List;
/*** @version 1.0* @Author 彭彦彬* @Date 2024/12/25 10:17* @注释*/
public interface EmpDao {/*** 获取所有用户数据* @return*/List<Emp> list() throws SQLException;
​/*** 查询员工信息通过姓名* @param name* @return*/Emp selectEmpByName(String name) throws SQLException;/*** 添加員工信息* @param emp*/int addEmp(Emp emp);int deleteEmp(Emp emp);List<Emp> selectEmpByLike(Emp emp,int page,int limit);long countEmpByLike(Emp emp);
}
​
  • 实现业务接口

package com.pyb.dao.daoImpl;
import com.pyb.dao.EmpDao;
import com.pyb.pojo.Emp;
import com.pyb.utils.JdbcUtils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
/*** @version 1.0* @Author 彭彦彬* @Date 2024/12/25 10:19*/
public class EmpDaoImpl implements EmpDao {@Overridepublic List<Emp> list() throws SQLException {String sql = "SELECT * FROM emp";List<Emp> list = new ArrayList<>();
​// 使用 try-with-resources 确保资源自动关闭try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql);ResultSet rs = ps.executeQuery()) {
​while (rs.next()) {int empno = rs.getInt("empno");String ename = rs.getString("ename");String job = rs.getString("job");int mgr = rs.getInt("mgr");String hiredate = rs.getString("hiredate"); // 如果 hiredate 是日期类型double sal = rs.getDouble("sal");double comm = rs.getDouble("comm");int deptno = rs.getInt("deptno");
​list.add(new Emp(empno, ename, job, mgr, hiredate, sal, comm, deptno));}} catch (SQLException e) {// 记录详细的错误信息,以便于调试e.printStackTrace(); // 在实际应用中应使用日志框架如 SLF4J 等记录错误信息throw e; // 或者抛出自定义异常}return list;}@Overridepublic Emp selectEmpByName(String name) throws SQLException {String sql = "SELECT * FROM emp WHERE ename = ?";
​// 使用 try-with-resources 确保资源自动关闭try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql)) {
​ps.setString(1, name);
​try (ResultSet rs = ps.executeQuery()) {if (rs.next()) {int empno = rs.getInt("empno");String ename = rs.getString("ename");String job = rs.getString("job");int mgr = rs.getInt("mgr");String hiredate = rs.getString("hiredate"); // 如果 hiredate 是日期类型double sal = rs.getDouble("sal");double comm = rs.getDouble("comm");int deptno = rs.getInt("deptno");
​return new Emp(empno, ename, job, mgr, hiredate, sal, comm, deptno);}}
​// 如果没有找到员工,则返回 nullreturn null;} catch (SQLException e) {// 记录详细的错误信息,以便于调试e.printStackTrace(); // 在实际应用中应使用日志框架如 SLF4J 等记录错误信息throw e; // 或者抛出自定义异常}}@Overridepublic int addEmp(Emp emp) {String sql="insert into emp(ename,job,mgr,hiredate,sal,comm,deptno)values(?,?,?,?,?,?,?)";int effect=0;// 使用 try-with-resources 确保资源自动关闭try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql)) {
​ps.setString(1,emp.geteName());ps.setString(2,emp.getJob());ps.setInt(3,emp.getMgr());ps.setString(4,emp.getHireDate());ps.setDouble(5, emp.getSal());ps.setDouble(6,emp.getComm());ps.setInt(7,emp.getDeptNo());effect=ps.executeUpdate();} catch (SQLException e) {// 记录详细的错误信息,以便于调试e.printStackTrace(); // 在实际应用中应使用日志框架如 SLF4J 等记录错误信息}return effect;}@Overridepublic int deleteEmp(Emp emp) {String sql = "DELETE FROM emp WHERE empno = ?";int affectedRows = 0;
​// 使用 try-with-resources 确保资源自动关闭try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql)) {
​ps.setInt(1, emp.getEmpNo());
​affectedRows = ps.executeUpdate();
​if (affectedRows == 0) {System.out.println("Warning: No rows were deleted for empno=" + emp.getEmpNo());// 可选择抛出自定义异常或返回特定值以表示未找到要删除的记录} else {System.out.println("Employee with empno=" + emp.getEmpNo() + " deleted successfully.");}
​} catch (SQLException e) {// 记录详细的错误信息,以便于调试e.printStackTrace(); // 在实际应用中应使用日志框架如 SLF4J 等记录错误信息// 抛出自定义异常或进行其他适当的错误处理throw new RuntimeException("Database error occurred while deleting employee.", e);}return affectedRows;}
​@Overridepublic List<Emp> selectEmpByLike(Emp emp, int page, int limit) {// Adjust the SQL query to support pagination using LIMIT and OFFSETString sql = "SELECT * FROM emp WHERE ename LIKE ? OR job LIKE ? LIMIT ? OFFSET ?";List<Emp> list = new ArrayList<>();try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql)) {// Set parameters with wildcards for the LIKE clauseps.setString(1, "%" + emp.geteName() + "%");ps.setString(2, "%" + emp.getJob() + "%");
​// Calculate offset based on page number and limitint offset = (page - 1) * limit;ps.setInt(3, limit);ps.setInt(4, offset);
​try (ResultSet rs = ps.executeQuery()) {while (rs.next()) {int empno = rs.getInt("empno");String ename = rs.getString("ename");String job = rs.getString("job");int mgr = rs.getInt("mgr");String hiredate = rs.getString("hiredate"); // Assuming hiredate is a DATE type in databasedouble sal = rs.getDouble("sal");Double comm = rs.getDouble("comm"); // Use Double to handle NULL valuesint deptno = rs.getInt("deptno");
​// Handle possible null values for commif (rs.wasNull()) {comm = null;}list.add(new Emp(empno, ename, job, mgr, hiredate, sal, comm, deptno));}}} catch (SQLException e) {// Log the exception using a logging framework in production codee.printStackTrace();// You may want to throw or handle the exception here}return list; // Return the populated list}
​@Overridepublic long countEmpByLike(Emp emp) {String sql = "SELECT COUNT(*) FROM emp WHERE ename LIKE ? OR job LIKE ?";try (Connection con = JdbcUtils.getConnection();PreparedStatement ps = con.prepareStatement(sql)) {
​// Set parameters with wildcards for the LIKE clauseps.setString(1, "%" + emp.geteName() + "%");ps.setString(2, "%" + emp.getJob() + "%");
​try (ResultSet rs = ps.executeQuery()) {if (rs.next()) {return rs.getLong(1);}}} catch (SQLException e) {// Log the exception using a logging framework in production codee.printStackTrace();}return 0L;}
}
​
​
​
​
​
​
​
  • 编写服务层接口

package com.pyb.service;
​
/*** @version 1.0* @Author 彭彦彬* @Date 2024/12/25 14:22* @注释*/
import com.pyb.pojo.Emp;
import java.sql.SQLException;
import java.util.List;
public interface EmpService {List<Emp> selectEmpByLike(Emp emp, int page, int limit) throws SQLException;long countEmpByLike(Emp emp) throws SQLException;
}
​
  • 编写服务层实现类

package com.pyb.service.serviceImpl;
​
import com.pyb.dao.EmpDao;
import com.pyb.dao.daoImpl.EmpDaoImpl;
import com.pyb.pojo.Emp;
import com.pyb.service.EmpService;
import java.sql.SQLException;
import java.util.List;
public class EmpServiceImpl implements EmpService {private final EmpDao empDao = new EmpDaoImpl();@Overridepublic List<Emp> selectEmpByLike(Emp emp, int page, int limit) throws SQLException {return empDao.selectEmpByLike(emp, page, limit);}@Overridepublic long countEmpByLike(Emp emp) throws SQLException {return empDao.countEmpByLike(emp);}
}
  • 编写控制层实现页面控制

package com.pyb.controller;
​
import com.fasterxml.jackson.databind.ObjectMapper;
import com.pyb.service.EmpService;
​
import com.pyb.pojo.Emp;
import com.pyb.service.serviceImpl.EmpServiceImpl;
​
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@WebServlet("/api/likeEmp")
public class EmpLikeServlet extends HttpServlet {private final EmpService empService = new EmpServiceImpl();@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {handleRequest(req, resp);}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {handleRequest(req, resp);}
​private void handleRequest(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {try {// 处理请求编码req.setCharacterEncoding("utf-8");resp.setContentType("application/json;charset=UTF-8");resp.setHeader("Access-Control-Allow-Origin", "*"); // 生产环境中应限制到具体域名resp.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");resp.setHeader("Access-Control-Max-Age", "3600");resp.setHeader("Access-Control-Allow-Headers", "Content-Type");
​// 解析分页参数int page = Integer.parseInt(req.getParameter("page") != null ? req.getParameter("page") : "1");int limit = Integer.parseInt(req.getParameter("limit") != null ? req.getParameter("limit") : "2");
​// 解析检索参数String ename = req.getParameter("ename");String job = req.getParameter("job");
​// 调用Service层List<Emp> list = empService.selectEmpByLike(new Emp(ename, job), page, limit);long totalUsers = empService.countEmpByLike(new Emp(ename, job));
​// 构建响应对象Map<String, Object> responseData = new HashMap<>();responseData.put("users", list);responseData.put("total", totalUsers);responseData.put("page", page);responseData.put("limit", limit);if (ename != null) responseData.put("ename", ename);if (job != null) responseData.put("job", job);
​ObjectMapper mapper = new ObjectMapper();mapper.writeValue(resp.getWriter(), responseData);} catch (SQLException e) {throw new RuntimeException(e);}}
}

启动服务部署到tomcat,用postman测试接口

http://localhost:8080/api/likeEmp?ename=a
  • 测试结果

4.编写前端页面,实现前后端数据交互

  • html页面

<template><div class="employee-manager"><!-- 现有的表格和分页组件 --><el-card class="box-card"><template #header><div class="card-header"><span>员工列表</span><!-- 检索框 --><el-input v-model="searchEname" placeholder="请输入姓名" style="width: 200px; margin-right: 10px;"></el-input><el-input v-model="searchJob" placeholder="请输入岗位" style="width: 200px; margin-right: 10px;"></el-input><el-button type="primary" @click="fetchData">搜索</el-button><el-button type="info" @click="resetSearch">重置</el-button><el-button type="primary" @click="openAddEmployeeDialog">添加员工</el-button></div></template><el-table :data="paginatedData" style="width: 100%; margin-top: 20px;" stripe><el-table-column prop="empNo" label="ID" width="100" /><el-table-column prop="eName" label="姓名" width="100" /><el-table-column prop="job" label="岗位" width="100" /><el-table-column prop="mgr" label="上级编号" /><el-table-column prop="hireDate" label="入职日期" width="200"/><el-table-column prop="sal" label="月薪" width="100"/><el-table-column prop="comm" label="奖金" /><el-table-column prop="deptNo" label="部门编号" />​<el-table-column fixed="right" label="操作" width="180"><template #default="scope"><el-button size="small" type="danger" @click="deleteEmployee(scope.row.empNo)">删除</el-button></template></el-table-column></el-table>
​<el-paginationlayout="total, sizes, prev, pager, next, jumper":total="totalItems":page-size="pageSize":current-page="currentPage"@size-change="handleSizeChange"@current-change="handleCurrentChange":page-sizes="[3, 6, 9, 12]"style="margin-top: 20px;"></el-pagination></el-card>
​<!-- 添加员工对话框 --><el-dialog v-model="dialogVisible" title="添加员工" width="30%"><el-form :model="employeeForm" label-width="100px" class="add-employee-form"><el-form-item label="ID"><el-input v-model="employeeForm.id" placeholder="请输入ID"></el-input></el-form-item><el-form-item label="姓名"><el-input v-model="employeeForm.name" placeholder="请输入姓名"></el-input></el-form-item><el-form-item label="职位"><el-input v-model="employeeForm.position" placeholder="请输入职位"></el-input></el-form-item></el-form><template #footer><span class="dialog-footer"><el-button @click="closeDialog">取消</el-button><el-button type="primary" @click="addEmployee">确认添加</el-button></span></template></el-dialog></div>
</template>
  • css样式页面

<style scoped>
.employee-manager {padding: 20px;
}
​
.box-card {width: 100%;
}
​
.card-header {display: flex;justify-content: space-between;align-items: center;
}
​
.add-employee-form {max-width: 400px;margin: auto;
}
​
.el-table {border-radius: 8px;overflow: hidden;
}
​
.el-pagination {text-align: center;
}
​
.dialog-footer {text-align: right;
}
</style>
  • 和后台交互的script代码

<script lang="js" setup>
import { ref, onMounted, computed } from 'vue';
import axios from 'axios';
import { ElMessage } from 'element-plus'; // 局部引入 ElMessage
​
const tableData = ref([]); // 使用 ref 创建响应式数据源
const totalItems = ref(0);
const currentPage = ref(1);
const pageSize = ref(3);
​
// 表单数据模型
const employeeForm = ref({id: '',name: '',position: ''
});
​
// 对话框可见性
const dialogVisible = ref(false);
​
// 检索条件
const searchEname = ref('');
const searchJob = ref('');
​
// 计算属性,用于根据当前页码和每页大小获取分页后的数据
const paginatedData = computed(() => {const start = (currentPage.value - 1) * pageSize.value;const end = start + pageSize.value;return tableData.value;
});
​
const fetchData = async () => {try {const response = await axios.get('http://localhost:8080/api/likeEmp', {params: {page: currentPage.value,limit: pageSize.value,ename: searchEname.value,job: searchJob.value}});const { users, total } = response.data;tableData.value = users.map(user => ({ ...user, id: user.id, name: user.name, position: user.position }));totalItems.value = total; // 更新总条目数} catch (error) {console.error('Error fetching data:', error);}
};
​
onMounted(() => {fetchData(); // 组件挂载时自动加载数据
});
​
const handleSizeChange = (newSize) => {pageSize.value = newSize;fetchData();
};
​
const handleCurrentChange = (newPage) => {currentPage.value = newPage;fetchData();
};
​
// 打开添加员工对话框的方法
const openAddEmployeeDialog = () => {dialogVisible.value = true;
};
​
// 关闭对话框的方法
const closeDialog = () => {dialogVisible.value = false;Object.assign(employeeForm.value, {id: '',name: '',position: ''});
};
​
// 添加员工的方法
const addEmployee = async () => {try {const response = await axios.post('http://localhost:8080/api/emp', employeeForm.value, {headers: {'Content-Type': 'application/json'}});console.log('Employee added successfully:', response.data);// 关闭对话框并清空表单closeDialog();// 刷新表格数据fetchData();} catch (error) {console.error('Error adding employee:', error);}
};
​
// 删除员工的方法
const deleteEmployee = async (empNo) => {try {const response = await axios.delete(`http://localhost:8080/api/delEmp`, {params: {empNo: empNo}});console.log('Employee deleted successfully:', response.data.message);ElMessage({message: response.data.message,type: response.data.success ? 'success' : 'error'});// 刷新表格数据fetchData();} catch (error) {console.error('Error deleting employee:', error);ElMessage({message: '删除员工时出错',type: 'error'});}
};
​
// 重置检索条件的方法
const resetSearch = () => {searchEname.value = '';searchJob.value = '';fetchData();
};
</script>
  • 实现效果

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/497743.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【VulnOSv2靶场渗透】

文章目录 一、基础信息 二、信息收集 三、漏洞探测 四、提权 一、基础信息 Kali IP: 192.168.20.146 靶机IP&#xff1a;192.168.20.152 二、信息收集 nmap -sS -sV -p- -A 192.168.20.152 开放了22、80、6667等端口 22端口&#xff1a;openssh 6.6.1p1 80端口&…

无需训练!多提示视频生成最新SOTA!港中文腾讯等发布DiTCtrl:基于MM-DiT架构

文章链接&#xff1a;https://arxiv.org/pdf/2412.18597 项目链接&#xff1a;https://github.com/TencentARC/DiTCtrl 亮点直击 DiTCtrl&#xff0c;这是一种基于MM-DiT架构的、首次无需调优的多提示视频生成方法。本文的方法结合了新颖的KV共享机制和隐混合策略&#xff0c;使…

SpringBoot对静态资源的映射规则

目录 什么是SpringBoot静态资源映射&#xff1f; 如何实现SpringBoot静态资源映射&#xff1f; 1. webjars&#xff1a;以jar包的方式引入静态资源 示例&#xff1a; 2. /** 访问当前项目的任何资源 示例一&#xff1a; 示例二&#xff1a; 3. 静态首页&#xff08;欢…

【EtherCATBasics】- KRTS C++示例精讲(2)

EtherCATBasics示例讲解 目录 EtherCATBasics示例讲解结构说明代码讲解 项目打开请查看【BaseFunction精讲】。 结构说明 EtherCATBasics&#xff1a;应用层程序&#xff0c;主要用于人机交互、数据显示、内核层数据交互等&#xff1b; EtherCATBasics.h &#xff1a; 数据定义…

【论文阅读】Reducing Activation Recomputation in Large Transformer Models

创新点&#xff1a; 针对Transformer结构&#xff0c;通过序列并行和选择性重计算激活值&#xff0c;在节省显存空间占用的情况下&#xff0c;不带来明显通信开销&#xff0c;同时减少重计算成本。 总的来说&#xff0c;就是在原有的张量并行的基础上&#xff0c;对LayerNorm和…

Linux arm 编译安装glibc-2.29

重要的话说三遍&#xff1a; &#xff01;&#xff01;&#xff01;&#xff01;&#xff01;不要轻易自己去安装glibc&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; &#xff01;&#xff01;&#xff01;&#xff01;&#xff01;不要轻易自己去安装glibc&a…

STM32完全学习——FLASH上FATFS文件管理系统

一、需要移植的接口 我们通过看官网的手册&#xff0c;可以看到我们只要完成下面函数的实现&#xff0c;就可以完成移植。我们这里只移植前5个函数&#xff0c;获取时间的函数我们不在这里移植。 二、移植接口函数 DSTATUS disk_status (BYTE pdrv /* Physical drive nmuber…

Docker使用——国内Docker的安装办法

文章目录 参考资料前言Mac安装办法Homebrew 安装1. 直接下报错2. 安装homebrew&#xff0c; 用国内镜像3. 安装Docker4. 启动docker服务5. 测试是否安装成功 参考资料 鸣谢大佬文章。 macOS系统中&#xff1a;Docker的安装&#xff1a;https://blog.csdn.net/sulia1234567890…

Java-38 深入浅出 Spring - AOP切面增强 核心概念 相关术语 Proxy配置

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 大数据篇正在更新&#xff01;https://blog.csdn.net/w776341482/category_12713819.html 目前已经更新到了&#xff1a; MyBatis&#xff…

【CSS in Depth 2 精译_096】16.4:CSS 中的三维变换 + 16.5:本章小结

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第五部分 添加动效 ✔️【第 16 章 变换】 ✔️ 16.1 旋转、平移、缩放与倾斜 16.1.1 变换原点的更改16.1.2 多重变换的设置16.1.3 单个变换属性的设置 16.2 变换在动效中的应用 16.2.1 放大图标&am…

iOS 苹果开发者账号: 查看和添加设备UUID 及设备数量

参考链接&#xff1a;苹果开发者账号下添加新设备UUID - 简书 如果要添加新设备到 Profiles 证书里&#xff1a; 1.登录开发者中心 Sign In - Apple 2.找到证书设置&#xff1a; Certificate&#xff0c;Identifiers&Profiles > Profiles > 选择对应证书 edit &g…

【HENU】河南大学计院2024 计算机网络 期末复习知识点

和光同尘_我的个人主页 一直游到海水变蓝。 计网复习 第一章互联网组成类别交换方式分组交换的要点&#xff1a;分组交换的优点&#xff1a; 网络性能指标体系结构网络协议五层协议 第二章&#xff1a;物理层物理层的主要任务&#xff08;四大特性&#xff09;通信的三种方式…

Kafka中的Topic和Partition有什么关系?

大家好&#xff0c;我是锋哥。今天分享关于【Kafka中的Topic和Partition有什么关系&#xff1f;】面试题。希望对大家有帮助&#xff1b; Kafka中的Topic和Partition有什么关系&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在 Apache Kafka 中&#…

一文读懂变分自编码(VAE)

一文读懂变分自编码(VAE) 概述 变分自编码器&#xff08;Variational Autoencoder, VAE&#xff09;是一种生成模型&#xff0c;用于学习数据的潜在表示并生成与原始数据分布相似的新数据。它是一种概率模型&#xff0c;通过结合深度学习和变分推断的思想&#xff0c;解决了传…

第十七周:Fast R-CNN论文阅读

Fast R-CNN论文阅读 摘要Abstract文章简介1. 引言2. Fast R-CNN框架2.1 RoI位置信息映射2.2 RoI pooling2.3 分类器与边界框回归器2.4 以VGG16为backbone的Fast RCNN的网络结构 3. 训练细节3.1 采样3.2 多任务损失 4. 优缺点分析总结 摘要 这篇博客介绍了Fast R-CNN&#xff0…

ThinkPHP 8开发环境安装

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《ThinkPHP 8高效构建Web应用 夏磊 编程与应用开发丛书 清华大学出版社》【摘要 书评 试读】- 京东图书 1. 安装PHP8 Windows系统用户可以前往https://windows.php.net/downloads/releases/archives/下载PHP 8.0版本&am…

VM虚拟机配置ubuntu网络

目录 桥接模式 NAT模式 桥接模式 特点&#xff1a;ubuntu的IP地址与主机IP的ip地址不同 第一部分&#xff1a;VM虚拟机给ubuntu的网络适配器&#xff0c;调为桥接模式 第二部分&#xff1a;保证所桥接的网络可以上网 第三部分&#xff1a;ubuntu使用DHCP&#xff08;默认&…

日本IT行业|分享实用的开发语言及框架

在日本IT行业中&#xff0c;开发语言与框架的选择非常多样化&#xff0c;但也有一些特定的技术和框架更为流行。以下是对日本IT行业在用的开发语言与框架的详细分享&#xff1a; 开发语言 Java&#xff1a;Java在日本是一门非常稳定且受欢迎的编程语言&#xff0c;很多日本公…

【畅购商城】校验用户名、手机号以及前置技术Redis和阿里大鱼短信验证码

搭建环境 后端web服务&#xff1a;changgou4-service-web修改pom.xml文档 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance&…

[创业之路-222]:波士顿矩阵与GE矩阵在业务组合选中作用、优缺点比较

目录 一、波士顿矩阵 1、基本原理 2、各象限产品的定义及战略对策 3、应用 4、优点与局限性 二、技术成熟度模型与产品生命周期模型的配对 1、技术成熟度模型 2、产品生命周期模型 3、技术成熟度模型与产品生命周期模型的配对 三、产品生命周期与产品类型的对应关系 …