当前位置: 首页 > news >正文

构建 Java Web 应用程序:从 Servlet 到数据库交互(Eclipse使用JDBC连接Mysql数据库)

第 1 部分:环境设置
  1. 安装 Java Development Kit (JDK):下载并安装 JDK。
  2. 设置 IDE:安装并配置 IDE(如 IntelliJ IDEA 或 Eclipse)。
  3. 安装数据库:下载并安装 MySQL 数据库。
  4. 配置数据库:创建数据库和用户,设置权限。
  5. 确保MySQL数据库服务正在运行。
  6. 使用数据库管理工具(如终端命令行或Navicat)测试连接。
第 2 部分:创建 Web 应用程序项目
  1. 创建新项目:在 IDE 中创建新的 Java Web 项目。
  2. 配置项目结构:设置 src/main/java 和 src/main/webapp 目录。
  3. 添加依赖:如果使用 Maven 或 Gradle,添加 MySQL JDBC 驱动程序依赖。

第 3 部分:设计实体类
  1. 创建 Student 实体类:定义学生的属性和方法。
package  ; // 定义了该类所属的包名 根据自己的项目进行补充/*** Student 类用于表示一个学生实体,包含学生的基本信息和相关操作。*/
public class Student {private int id; // 学生的ID,唯一标识一个学生private int age; // 学生的年龄private String name; // 学生的姓名private String gender; // 学生的性别private String password; // 学生的密码,用于系统登录private String email; // 学生的电子邮件地址private String hobbies; // 学生的兴趣爱好,以字符串形式存储private String introduction; // 学生的自我介绍// 无参构造函数,创建一个Student对象时不初始化任何属性public Student() {}// Getter 和 Setter 方法,用于获取和设置Student对象的属性// ID相关的Getter和Setterpublic int getId() {return id; // 返回学生ID}public void setId(int id) {this.id = id; // 设置学生ID}// 年龄相关的Getter和Setterpublic int getAge() {return age; // 返回年龄}public void setAge(int age) {this.age = age; // 设置年龄}// 姓名相关的Getter和Setterpublic String getName() {return name; // 返回姓名}public void setName(String name) {this.name = name; // 设置姓名}// 性别相关的Getter和Setterpublic String getGender() {return gender; // 返回性别}public void setGender(String gender) {this.gender = gender; // 设置性别}// 密码相关的Getter和Setterpublic String getPassword() {return password; // 返回密码}public void setPassword(String password) {this.password = password; // 设置密码}// 电子邮件相关的Getter和Setterpublic String getEmail() {return email; // 返回电子邮件地址}public void setEmail(String email) {this.email = email; // 设置电子邮件地址}// 兴趣爱好相关的Getter和Setterpublic String getHobbies() {return hobbies; // 返回兴趣爱好}public void setHobbies(String hobbies) {this.hobbies = hobbies; // 设置兴趣爱好}// 自我介绍相关的Getter和Setterpublic String getIntroduction() {return introduction; // 返回自我介绍}public void setIntroduction(String introduction) {this.introduction = introduction; // 设置自我介绍}
}
第 4 部分:数据库连接服务
  1. 创建 DBConnection 类:实现获取数据库连接的方法。
package  ; // 指定该类所在的包名  根据自己的项目进行更改import java.sql.Connection; // 导入Java SQL Connection接口
import java.sql.DriverManager; // 导入 DriverManager 类,用于加载数据库驱动
import java.sql.SQLException; // 导入 SQLException,用于捕获获数据库异常/*** DBConnection 类用于建立和管理与MySQL数据库的连接。* 提供一个静态方法 getConnection() 用于获取数据库连接实例。*/
public class DBConnection {// 定义数据库驱动类名,用于Class.forName() 方法加载驱动private static final String DRIVER = "com.mysql.cj.jdbc.Driver";// 定义数据库连接URL,包括数据库地址、端口、数据库名以及连接参数private static final String URL = "jdbc:mysql://localhost:3306/student?useSSL=false&serverTimezone=UTC";// 定义数据库的用户名private static final String USERNAME = "root";// 定义数据库的密码private static final String PASSWORD = "123456";// 私有成员变量 conn 用于存储数据库连接对象private Connection conn;/*** 获取数据库连接的方法。* 首先尝试加载数据库驱动,然后使用 DriverManager 获取数据库连接。* @return 返回一个 Connection 对象,表示与数据库的连接。*/public Connection getConnection() {try {// 加载并注册 MySQL JDBC 驱动Class.forName(DRIVER);// 通过 DriverManager 获取数据库连接conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);// 如果连接成功,打印确认信息System.out.println("MySQL JDBC driver is loaded and connection is established.");} catch (ClassNotFoundException e) {// 如果找不到 JDBC 驱动类,打印错误信息并输出堆栈跟踪System.out.println("MySQL JDBC driver is not found.");e.printStackTrace();} catch (SQLException e) {// 如果数据库连接失败,输出堆栈跟踪e.printStackTrace();}// 返回数据库连接对象return conn;}
}
  1. 创建 DatabaseService 类:封装数据库连接逻辑。
第 5 部分:数据访问对象 (DAO)
  1. 创建 StudentDAO 类:实现插入学生信息到数据库的方法。
package  ; // 指定该类所在的包名 根据自己的项目进行更改import java.sql.Connection; // 导入Java的数据库连接接口
import java.sql.PreparedStatement; // 导入PreparedStatement,用于预编译SQL语句
import java.sql.SQLException; // 导入SQLException,用于捕获数据库异常
import java.util.logging.Level; // 导入日志记录级别
import java.util.logging.Logger; // 导入Java的日志记录器/*** StudentDAO类用于处理与学生相关的数据库操作。*/
public class StudentDAO {// 获取Logger实例,用于记录日志private static final Logger logger = Logger.getLogger(StudentDAO.class.getName());// 数据库连接服务,用于获取数据库连接private DBConnection dbService = new DBConnection(); /*** 将学生信息插入数据库的方法。* @param student 要插入的学生对象* @return 操作结果,包含是否成功和消息*/public Result insertStudent(Student student) {// 定义SQL插入语句String sql = "INSERT INTO info (name, email, age, gender, password, hobbies, introduction) VALUES (?, ?, ?, ?, ?, ?, ?)";try (Connection conn = dbService.getConnection(); // 获取数据库连接PreparedStatement pstmt = conn.prepareStatement(sql)) { // 创建PreparedStatement对象// 设置PreparedStatement参数pstmt.setString(1, student.getName());pstmt.setString(2, student.getEmail());pstmt.setInt(3, student.getAge());pstmt.setString(4, student.getGender());pstmt.setString(5, student.getPassword());pstmt.setString(6, student.getHobbies());pstmt.setString(7, student.getIntroduction());// 打印接收到的学生数据logger.log(Level.INFO, "接收到的学生数据: 名字={0}, 邮箱={1}, 年龄={2}, 性别={3}, 爱好={4}, 简介={5}",new Object[]{student.getName(), student.getEmail(), student.getAge(), student.getGender(),student.getHobbies(), student.getIntroduction()});int affectedRows = pstmt.executeUpdate(); // 执行SQL语句if (affectedRows > 0) {logger.log(Level.INFO, "数据插入成功,影响行数:{0}", affectedRows);return new Result(true, "注册成功");} else {logger.log(Level.WARNING, "数据插入失败,没有行受到影响");return new Result(false, "注册失败");}} catch (SQLException e) {logger.log(Level.SEVERE, "数据库错误: " + e.getMessage(), e); // 记录数据库异常return new Result(false, "数据库错误: " + e.getMessage());}}
}
  1. 异常处理:在 DAO 类中添加异常处理逻辑。
第 6 部分:Servlet 处理 HTTP 请求
  1. 创建 RegServlet 类:处理用户注册请求。
package   ; // 定义了该Servlet类所属的包名 根据自己的项目进行补充import jakarta.servlet.ServletException; // 导入Servlet异常处理类
import jakarta.servlet.annotation.WebServlet; // 用于定义Servlet的注解
import jakarta.servlet.http.HttpServlet; // 扩展HttpServlet以创建Servlet
import jakarta.servlet.http.HttpServletRequest; // 用于获取客户端请求
import jakarta.servlet.http.HttpServletResponse; // 用于发送响应客户端
import java.io.IOException; // 导入IOException类// 使用@WebServlet注解将此Servlet映射到"/RegServlet"路径
@WebServlet("/RegServlet")
public class RegServlet extends HttpServlet {private static final long serialVersionUID = 1L; // 用于序列化// 处理POST请求的方法protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// 从请求中获取表单数据String name = request.getParameter("name");String email = request.getParameter("email");String password = request.getParameter("password");String gender = request.getParameter("gender");String ageStr = request.getParameter("age");String[] hobbiesArray = request.getParameterValues("hobby"); // 获取兴趣爱好数组String introduction = request.getParameter("introduction");// 将兴趣爱好数组转换为逗号分隔的字符串String hobbies = (hobbiesArray != null) ? String.join(", ", hobbiesArray) : "";// 创建Student对象并设置属性Student student = new Student();student.setName(name);student.setEmail(email);student.setGender(gender);student.setPassword(password);student.setAge(Integer.parseInt(ageStr)); // 将年龄字符串转换为整数student.setHobbies(hobbies);student.setIntroduction(introduction);// 创建StudentDAO对象处理数据库操作StudentDAO studentDAO = new StudentDAO();// 调用insertStudent方法尝试将学生信息插入数据库Result result = studentDAO.insertStudent(student);// 根据数据库操作结果重定向到相应页面if (result.isSuccess()) { response.sendRedirect("success.jsp"); // 成功则跳转到成功页面} else {response.sendRedirect("error.jsp"); // 失败则跳转到错误页面}}// 处理GET请求的方法,可以选择显示注册表单或重定向到注册页面protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {response.sendRedirect("index.jsp"); // 默认重定向到注册页面}
}
  1. 获取请求参数:从 HTTP 请求中获取用户输入。
  2. 调用 DAO 方法:使用获取的数据调用 DAO 类的方法。
  3. 重定向:根据操作结果重定向到成功或错误页面。
第 7 部分:创建 JSP 页面
  1. 创建 index.jsp:用户注册表单页面。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head><title>用户注册页面</title><style>body {/* 设置页面主体样式,使用Arial字体,居中显示,背景白色 */font-family: Arial, sans-serif;display: flex;justify-content: center;align-items: center;height: 100vh;margin:  return 0;background-color: #fff;}.background-image {/* 设置背景图片样式,固定在底部,覆盖背景 */position: fixed;bottom: 0;left: 0;width: 500px;height: 320px;background-image: url('bg.png');background-size: cover;z-index: -1;}.container {/* 设置表单容器样式,半透明背景,圆角,阴影效果 */width: 600px;padding: 20px;background-color: rgba(255, 255, 255, 0.9);border-radius: 8px;box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);backdrop-filter: blur(10px);display: flex;flex-direction: column;}/* 其他样式类定义,如.form-group, .hobbies, .register-btn 等,用于设置表单元素的布局和外观 */</style>
</head>
<body><div class="background-image"></div><div class="container"><h2>用户注册</h2><form action="RegServlet" method="post"><!-- 昵称输入框 --><div class="form-group"><label for="name">昵称:</label><input type="text" id="name" name="name" required></div><!-- 邮箱输入框 --><div class="form-group"><label for="email">注册邮箱:</label><input type="email" id="email" name="email" required></div><!-- 密码输入框 --><div class="form-group"><label for="password">密码:</label><input type="password" id="password" name="password" required></div><!-- 性别单选按钮 --><div class="form-group"><label>性别:</label><input type="radio" id="male" name="gender" value="male"><label for="male">男</label><input type="radio" id="female" name="gender" value="female"><label for="female">女</label></div><!-- 年龄输入框 --><div class="form-group"><label for="age">年龄:</label><input type="number" id="age" name="age" required></div><!-- 兴趣爱好多选框 --><div class="form-group"><label>兴趣爱好:</label><div class="hobbies"><!-- 爱好1 --><input type="checkbox" id="hobby1" name="hobby" value="hobby1"><label for="hobby1">爱好1</label><!-- 爱好2 --><input type="checkbox" id="hobby2" name="hobby" value="hobby2"><label for="hobby2">爱好2</label><!-- 爱好3 --><input type="checkbox" id="hobby3" name="hobby" value="hobby3"><label for="hobby3">爱好3</label></div><div class="hobbies"><!-- 爱好4 --><input type="checkbox" id="hobby4" name="hobby" value="hobby4"><label for="hobby4">爱好4</label><!-- 爱好5 --><input type="checkbox" id="hobby5" name="hobby" value="hobby5"><label for="hobby5">爱好5</label><!-- 爱好6 --><input type="checkbox" id="hobby6" name="hobby" value="hobby6"><label for="hobby6">爱好6</label></div></div><!-- 自我介绍文本域 --><div class="form-group"><label for="introduction">自我介绍:</label><textarea id="introduction" name="introduction" maxlength="100" required></textarea></div><!-- 注册按钮 --><button type="submit" class="register-btn">立即注册</button></form></div>
</body>
</html>
  1. 创建 success.jsp:注册成功页面。
  2. 创建 error.jsp:注册失败页面。
第 8 部分:测试应用程序
  1. 部署应用程序:将应用程序部署到服务器(如 Tomcat)。
  2. 测试注册功能:填写表单并提交,检查是否正确重定向。
  3. 检查数据库:确认数据已正确插入数据库。
第 9 部分:调试和错误处理
  1. 查看日志:了解如何查看和解读日志文件。
  2. 常见问题解决:提供一些常见问题的解决方案。
第 10 部分:项目优化和扩展
  1. 使用连接池:介绍如何使用连接池来优化数据库连接。
  2. 添加更多功能:提供思路如何添加更多功能到应用程序。

结语

一个迷茫的大学生

相关文章:

构建 Java Web 应用程序:从 Servlet 到数据库交互(Eclipse使用JDBC连接Mysql数据库)

第 1 部分&#xff1a;环境设置 安装 Java Development Kit (JDK)&#xff1a;下载并安装 JDK。设置 IDE&#xff1a;安装并配置 IDE&#xff08;如 IntelliJ IDEA 或 Eclipse&#xff09;。安装数据库&#xff1a;下载并安装 MySQL 数据库。配置数据库&#xff1a;创建数据库…...

mfc100u.dll是什么?分享几种mfc100u.dll丢失的解决方法

mfc100u.dll 是一个动态链接库&#xff08;DLL&#xff09;文件&#xff0c;属于 Microsoft Foundation Classes (MFC) 库的一部分。MFC 是微软公司开发的一套用于快速开发 Windows 应用程序的 C 类库。mfc100u.dll 文件包含了 MFC 库中一些常用的函数和类的定义&#xff0c;这…...

Java面试之多线程并发篇

前言 本来想着给自己放松一下&#xff0c;刷刷博客&#xff0c;突然被几道面试题难倒&#xff01;说一说自己对于 synchronized 关键字的了解&#xff1f;说说自己是怎么使用 synchronized 关键字&#xff1f;什么是线程安全&#xff1f;Vector是一个线程安全类吗&#xff1f;…...

视频推拉流EasyDSS互联网直播点播平台技术特点及应用场景剖析

在数字科技日新月异的今天&#xff0c;视频直播和点播已经成为互联网内容传播的重要方式之一。而互联网直播点播平台EasyDSS作为功能强大的流媒体直播点播视频能力平台&#xff0c;提供了一站式的视频推拉流、转码、直播、点播、时移回放、存储等视频服务&#xff0c;广泛应用于…...

安全加固方案

交换机安全加固 查看是否关闭未使用的接口 25GE1/0/1、25GE1/0/47、25GE1/0/48需要使用&#xff0c;暂不关闭 system-view # interface Eth-Trunk99 shutdown quit interface Eth-Trunk100 shutdown quit interface Eth-Trunk110 shutdown quit interface 25GE1/…...

Linux firewall防火墙规则

官网 https://firewalld.org/ 查看所有防火墙规则&#xff1a; firewall-cmd --list-all-zones查看当前区域防火墙规则&#xff1a; firewall-cmd --list-all添加一个开放服务规则&#xff1a; firewall-cmd --add-servicessh删除一个开放服务规则&#xff1a; firewall-cmd…...

速盾:CDN缓存的工作原理是什么?

CDN&#xff08;内容分发网络&#xff09;是一种将内容分发到全球不同地理位置的网络架构&#xff0c;以提供更快速、可靠的内容传输。其核心原理是利用缓存技术&#xff0c;将数据内容分布到离用户最近的边缘节点上。当用户请求内容时&#xff0c;CDN将根据用户的IP地址&#…...

日常开发记录-正确的prop传参,reduce搭配promise的使用

日常开发记录-正确的prop传参&#xff0c;reduce搭配promise的使用 1.正确的prop传参2.reduce搭配promise的使用 1.正确的prop传参 一般会的父组件传参子组件 //父组件 <A :demodata.sync"testData" :listData.sync"testData2"></A> data ()…...

Hyper-V配置-cnblog

启用Hyper-V以在 Windows 10上创建虚拟机 &#xff08;1&#xff09;控制面板检查系统要求&#xff1a; 确保您的计算机符合 Hyper-V 的系统要求。通常情况下&#xff0c;您的计算机需要运行 Windows 10 专业版、企业版或教育版&#xff0c;并且具有启用了虚拟化技术的处理器。…...

运维Tips:Docker或K8s集群拉取Harbor私有容器镜像仓库配置指南

[ 知识是人生的灯塔,只有不断学习,才能照亮前行的道路 ] Docker与Kubernetes集群拉取Harbor私有容器镜像仓库配置 描述:在现在微服务、云原生的环境下,通常我们会在企业中部署Docker和Kubernetes集群,并且会在企业内部搭建Harbor私有镜像仓库以保证开发源码安全,以及加快…...

openssl颁发包含主题替代名的证书–SAN

原文地址&#xff1a;openssl颁发包含主题替代名的证书–SAN – 无敌牛 欢迎参观我的个人博客&#xff1a;无敌牛 – 技术/著作/典籍/分享等 在 X.509 证书中&#xff0c;commonName&#xff08;CN&#xff09;字段只能有一个值。如果让证书支持多个域名和IP地址&#xff0c;…...

Stable Diffusion入门教程

要入门Stable Diffusion&#xff0c;你可以按照以下步骤进行&#xff1a; 1. 安装Stable Diffusion 获取安装包&#xff1a;你可以从GitHub上的 Stable Diffusion Web UI开源地址获取安装包。 一键启动程序包&#xff1a;如果你是小白不会装&#xff0c;可以使用国内秋葉aaaki开…...

H.265流媒体播放器EasyPlayer.js无插件H5播放器关于移动端(H5)切换网络的时候,播放器会触发什么事件

EasyPlayer.js无插件H5播放器作为一款功能全面的H5流媒体播放器&#xff0c;凭借其多种协议支持、多种解码方式、丰富的渲染元素和强大的应用功能&#xff0c;以及出色的跨平台兼容性&#xff0c;为用户提供了高度定制化的选项和优化的播放体验。无论是视频直播还是点播&#x…...

conan2 c/c++包管理入门之--------------------------conanfile.py

书接上回,用过使用cmake去手动指定CMAKE_TOOLCHAINE_FILE和CMAKE_BUILD_TYPE太麻烦,有没有更简单的办法了,经过我的大量探索下终于发现,使用conan build和conanfile.py。大致原理是conan在构建时会自动调用conanfile.py里面定义数据和函数。举个例子: from conan import …...

DICOM图像深入解析:为何部分DR/CR图像默认显示为反色?

概述 在数字医学影像处理中,CR(Computed Radiography,计算机放射摄影)和DR(Digital Radiography,数字放射摄影)技术广泛应用于医疗影像获取与分析。然而,临床实践中常常遇到这样一个问题:部分CR/DR图像在默认打开时呈现为反色(即负片效果),需手动反色后才能正常阅片…...

重新定义社媒引流:AI社媒引流王如何为品牌赋能?

在社交媒体高度竞争的时代&#xff0c;引流已经不再是单纯追求流量的数字游戏&#xff0c;而是要找到“对的用户”&#xff0c;并与他们建立真实的连接。AI社媒引流王通过技术创新和智能策略&#xff0c;重新定义了社媒引流的方式&#xff0c;帮助品牌在精准触达和高效互动中脱…...

【FPGA】Verilog:利用 4 个串行输入- 串行输出的 D 触发器实现 Shift_register

0x00 什么是寄存器 寄存器(Register)是顺序逻辑电路中使用的基本组成部分之一。寄存器用于在数字系统中存储和处理数据。寄存器通常由位(bit)构成,每个位可以存储一个0或1的值。通过寄存器,可以设计出计数器、加法器等各种数据处理电路。 0x01 寄存器的种类 基于 D 触发…...

《硬件架构的艺术》笔记(五):低功耗设计

介绍 能量以热量形式消耗&#xff0c;温度升高芯片失效率也会增加&#xff0c;增加散热片或风扇会增加整体重量和成本&#xff0c;在SoC级别对功耗进行控制就可以减少甚至可能消除掉这些开支&#xff0c;产品也更小更便宜更可靠。本章描述了减少动态功耗和静态功耗的各种技术。…...

Hive离线数仓结构分析

Hive离线数仓结构 首先&#xff0c;在数据源部分&#xff0c;包括源业务库、用户日志、爬虫数据和系统日志&#xff0c;这些都是数据的源头。这些数据通过Sqoop、DataX或 Flume 工具进行提取和导入操作。这些工具负责将不同来源的数据传输到基于 Hive 的离线数据仓库中。 在离线…...

鱼眼相机模型-MEI

参考文献&#xff1a; Single View Point Omnidirectional Camera Calibration from Planar Grids 1. 相机模型如下&#xff1a; // 相机坐标系下的点投影到畸变图像// 输入&#xff1a;相机坐标系点坐标cam 输出&#xff1a; 畸变图像素点坐标disPtvoid FisheyeCamAdapter::…...

机电一体化系统设计的核心挑战与跨学科协同

1. 机电一体化系统设计的核心挑战与机遇十年前我第一次参与工业机器人控制系统开发时&#xff0c;机械团队和电气团队还在用纸质图纸传递设计变更。某个周五下午的机械结构改动&#xff0c;直到下周一才通知到电气组&#xff0c;导致整个控制柜布局需要返工。这种割裂的开发模式…...

AI图像编辑中的性别擦除现象与视觉公平性测试

1. 项目概述&#xff1a;当AI“擦除”男性面孔时&#xff0c;我们到底在测试什么&#xff1f;“AI Erases Men Too: A Visual Test of Bias Across Four Leading Tools”——这个标题乍看像一则科技媒体的警示快讯&#xff0c;但背后是一次扎实、可复现、有明确方法论支撑的视觉…...

从ARM到FPGA:手把手教你用Vivado双口RAM IP核搭建跨芯片通信桥

从ARM到FPGA&#xff1a;构建高性能双口RAM通信桥的工程实践 在异构计算架构中&#xff0c;FPGA与处理器的协同工作已成为提升系统性能的关键方案。Xilinx Vivado工具链中的双口RAM IP核&#xff0c;为解决跨芯片数据交换提供了硬件级的优雅实现。本文将深入探讨如何将这一技术…...

如何快速上手Podgrab:5分钟搭建个人播客下载中心完整指南

如何快速上手Podgrab&#xff1a;5分钟搭建个人播客下载中心完整指南 【免费下载链接】podgrab A self-hosted podcast manager/downloader/archiver tool to download podcast episodes as soon as they become live with an integrated player. 项目地址: https://gitcode.…...

程序员连夜带团队跑路,省了23万:这AI太贵,真的用不起了

好的&#xff0c;收到&#xff01;你说得对&#xff0c;之前的风格可能信息密度太高&#xff0c;有点“极客狂欢”的味道。 今天咱们换个姿势&#xff0c;用唠家常、说人话的方式&#xff0c;把5月11日AI圈最有趣、最魔幻的几件事儿聊明白。保证你在地铁上、蹲坑时&#xff0c;…...

Sora 2生成素材在AE中频繁掉帧?20年合成老炮儿用CUDA Graph重构图层管线,性能提升3.8倍(含Profile对比图)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Sora 2生成素材在AE中频繁掉帧&#xff1f;20年合成老炮儿用CUDA Graph重构图层管线&#xff0c;性能提升3.8倍&#xff08;含Profile对比图&#xff09; 当Sora 2输出的4K/60fps高动态范围视频序列导入…...

【Midjourney×Photoshop黄金工作流】:20年Adobe+AI实战专家亲授5步无缝整合法,97%设计师尚未掌握的智能修图新范式

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;MidjourneyPhotoshop黄金工作流的范式革命 传统图像创作正经历一场静默却深刻的重构——当 Midjourney 生成的高语义图像与 Photoshop 的像素级控制能力深度耦合&#xff0c;工作流不再只是“AI出图→人…...

保姆级排错:Keil里J-Link选项神秘消失?手把手教你定位GD32E23等ARM-M23内核芯片的调试器兼容问题

当Keil调试器选项消失时&#xff1a;深度解析ARM-M23内核芯片的调试兼容性问题 第一次在Keil的Debug配置界面发现J-Link选项神秘消失时&#xff0c;我盯着屏幕愣了几秒钟——前一天明明还能正常使用的工具链&#xff0c;怎么突然就"罢工"了&#xff1f;这种看似"…...

团队知识管理的失效:人员流动如何不导致知识流失

一、软件测试团队知识管理的特殊价值与脆弱性在软件测试领域&#xff0c;知识是保障产品质量的核心资产。不同于开发环节的代码沉淀&#xff0c;测试知识兼具显性与隐性双重属性&#xff1a;显性知识体现在测试用例、缺陷报告、自动化脚本等文档中&#xff0c;而隐性知识则蕴含…...

文献阅读 260511-Wildfire damages and the cost-effective role of forest fuel treatments

Wildfire damages and the cost-effective role of forest fuel treatments 来自 <https://www.science.org/doi/10.1126/science.aea6463> ## Abstract: Gave the core question: Wildfires are among the most pressing environmental challenges of the 21st century,…...