0

0

Java初学者项目实战:开发一个简单的博客管理系统

P粉602998670

P粉602998670

发布时间:2026-01-07 16:39:17

|

949人浏览过

|

来源于php中文网

原创

初学者应直接使用Spring Boot+Thymeleaf+H2+JPA搭建博客系统,避免手写MVC和数据库连接池;需正确配置主键注解、表单绑定及application.properties,重点关注日志末尾的Caused by错误。

java初学者项目实战:开发一个简单的博客管理系统

Java初学者做博客管理系统,不建议从零手写全套 MVC 架构、数据库连接池、权限控制——那样容易卡在 ClassNotFoundExceptionSQLException: No suitable driver found 三天没跑出首页。直接用 Spring Boot + Thymeleaf + H2(开发阶段)+ JPA 是最务实的起点。

用 Spring Boot 初始化项目,别碰原始 Servlet

手动配 web.xml、写 HttpServlet 子类、自己解析 POST 表单——这些不是练手,是自设路障。Spring Boot 的 @RestController@Controller 能把路由、参数绑定、JSON 返回全包圆。

实操建议:

  • start.spring.io 勾选:Spring WebSpring Data JPAThymeleafH2 Database(开发用)、Lombok(省掉 getter/setter)
  • 生成后导入 IDE,确认 pom.xml 里有 spring-boot-starter-webspring-boot-starter-data-jpa
  • 删掉默认的 Application.java 里的测试逻辑,先跑通空项目:启动后访问 http://localhost:8080 看是否返回 Whitelabel Error Page(说明容器已起来)

定义 Blog 实体类时,JPA 注解别漏掉 @Id@GeneratedValue

很多初学者写完 Blog 类,加了 @Entity 就以为完事,结果启动报错:org.hibernate.AnnotationException: No identifier specified for entity。JPA 必须明确主键策略。

立即学习Java免费学习笔记(深入)”;

正确写法示例(用 Lombok 简化):

@Entity
public class Blog {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String title;
    private String content;
    private LocalDateTime createdAt;

    // 构造、getter/setter(Lombok 自动生成)
}

注意点:

易想商务网
易想商务网

YxB2B商务网是易想网络旗下的门户型B2B行业网站系统,采用先进的标签技术和静态生成技术,通过网站后台管理轻松实现网站前台多种风格和会员网站多风格,让每一个只要懂得简单网页制作常识的网友,轻松制作出精美专业的的行业商务网站系统。系统高速、稳定、安全,完全仿阿里巴巴功能设计,有供应信息、求购信息、产品库、公司库、专项商机、行业信息、展会服务、人才市场、会员助手、网商博客、商友论坛、全方位搜索等栏目

下载
  • GenerationType.IDENTITY 对应 H2 的 IDENTITY 列类型,别写成 AUTO(H2 不支持)
  • LocalDateTime 需要数据库列类型为 TIMESTAMP,H2 默认支持;若换 MySQL,需在 application.propertiesspring.jpa.properties.hibernate.jdbc.time_zone=UTC 避免时区错乱
  • 别给 id 字段加 @Column(name = "id")——冗余,JPA 默认就映射同名字段

Thymeleaf 模板里写 th:objectth:field,别混用 th:value

想做一个新建博客的表单,写成这样会失败:

<form th:action="@{/blogs}" th:method="post">
  <input type="text" name="title" th:value="${blog.title}">
  <textarea name="content" th:text="${blog.content}"></textarea>
</form>

问题在于:th:valueth:text 不绑定对象属性,提交时后端收不到数据;且没启用 Spring 的表单绑定机制,@ModelAttribute 参数为空。

正确写法(必须配对使用):

<form th:action="@{/blogs}" th:method="post" th:object="${blog}">
  <input type="text" th:field="*{title}">
  <textarea th:field="*{content}"></textarea>
  <button type="submit">发布</button>
</form>

关键点:

  • th:object 指定绑定对象(传入 Model 的 key,如 model.addAttribute("blog", new Blog())
  • th:field="*{xxx}" 自动渲染 name="xxx" 并填入值,还支持错误提示(配合 BindingResult
  • 别用 th:name 手动写 name 属性——破坏双向绑定,后端收不到

调试时优先查 application.properties 和日志末尾的 Caused by

启动失败八成不是代码写错,而是配置漏项或版本冲突。比如:

  • 忘了在 application.propertiesspring.datasource.url=jdbc:h2:mem:testdb → 报 Failed to configure a DataSource
  • H2 控制台默认关闭 → 想看数据库内容却打不开 http://localhost:8080/h2-console,得加 spring.h2.console.enabled=true
  • 实体类改了字段但没清 H2 内存库 → 页面报 InvalidDataAccessResourceUsageException: Column "XXX" not found,此时删掉 spring.datasource.url 末尾的 ;DB_CLOSE_DELAY=-1 并重启,或加 spring.sql.init.mode=always 重跑 schema

日志里真正有用的线索永远在最后一段 Caused by:,而不是开头几百行的 Hibernate 启动日志。盯住它,比反复改代码快十倍。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2174

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1683

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 848人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号