springboot-mvc项目示例代码

混编项目代码示例,前端去写视图层,后端去写控制器

项目目录结构:

powershell 复制代码
src/
├── main/
│   ├── java/
│   │   └── com/
│   │       └── example/
│   │           └── app/
│   │               ├── Application.java
│   │               ├── controller/
│   │               │   └── UserController.java
│   │               └── model/
│   │                   ├── User.java
│   │                   └── ApiResponse.java
│   └── resources/
│       ├── templates/
│       │   └── user-list.html
│       ├── static/
│       │   ├── css/
│       │   ├── js/
│       │   └── images/
│       └── application.properties
pom.xml

UserController文件

java 复制代码
package com.example.app.controller;

import com.example.app.model.User;
import com.example.app.model.ApiResponse;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;

import java.util.ArrayList;
import java.util.List;

@Controller
public class UserController {

    private List<User> userList = new ArrayList<>();

    // 视图层方法 - 返回用户列表页面
    @GetMapping("/users")
    public String userListPage(Model model) {
        model.addAttribute("users", userList);
        model.addAttribute("newUser", new User());
        return "user-list";
    }

    // 后端接口 - 获取所有用户 (REST API)
    @GetMapping("/api/users")
    @ResponseBody
    public List<User> getAllUsers() {
        return userList;
    }

    // 后端接口 - 添加用户 (REST API)
    @PostMapping("/api/users")
    @ResponseBody
    public ApiResponse addUser(@RequestBody User user) {
        user.setId(System.currentTimeMillis());
        userList.add(user);
        return new ApiResponse(true, "用户添加成功", user);
    }

    // 后端接口 - 删除用户 (REST API)
    @DeleteMapping("/api/users/{id}")
    @ResponseBody
    public ApiResponse deleteUser(@PathVariable Long id) {
        boolean removed = userList.removeIf(user -> user.getId().equals(id));
        if (removed) {
            return new ApiResponse(true, "用户删除成功");
        } else {
            return new ApiResponse(false, "用户不存在");
        }
    }
}

user-list.html文件

html 复制代码
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>用户管理系统</title>
    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    <style>
        .container { max-width: 800px; margin: 0 auto; padding: 20px; }
        .form-group { margin-bottom: 15px; }
        label { display: block; margin-bottom: 5px; }
        input { width: 100%; padding: 8px; border: 1px solid #ddd; }
        button { padding: 10px 20px; background: #007bff; color: white; border: none; cursor: pointer; }
        .user-item { padding: 10px; border: 1px solid #eee; margin: 5px 0; display: flex; justify-content: space-between; }
        .error { color: red; }
        .success { color: green; }
    </style>
</head>
<body>
<div class="container">
    <h1>用户管理系统</h1>

    <!-- 添加用户表单 -->
    <div class="form-section">
        <h2>添加用户</h2>
        <form id="userForm">
            <div class="form-group">
                <label>姓名:</label>
                <input type="text" id="name" name="name" required>
            </div>
            <div class="form-group">
                <label>邮箱:</label>
                <input type="email" id="email" name="email" required>
            </div>
            <button type="submit">添加用户</button>
        </form>
    </div>

    <!-- 消息显示 -->
    <div id="message"></div>

    <!-- 用户列表 -->
    <div class="user-list">
        <h2>用户列表</h2>
        <div id="usersContainer">
            <!-- 用户列表将通过JavaScript动态加载 -->
        </div>
    </div>
</div>

<script>
    document.addEventListener('DOMContentLoaded', function() {
        loadUsers();
        setupForm();
    });

    function loadUsers() {
        axios.get('/api/users')
            .then(response => {
                displayUsers(response.data);
            })
            .catch(error => {
                showMessage('加载用户列表失败: ' + error.message, 'error');
            });
    }

    function displayUsers(users) {
        const container = document.getElementById('usersContainer');

        if (users.length === 0) {
            container.innerHTML = '<p>暂无用户</p>';
            return;
        }

        let html = '';
        users.forEach(user => {
            html += `
                    <div class="user-item">
                        <div>
                            <strong>${user.name}</strong> - ${user.email}
                        </div>
                        <button onclick="deleteUser(${user.id})">删除</button>
                    </div>
                `;
        });
        container.innerHTML = html;
    }

    function setupForm() {
        document.getElementById('userForm').addEventListener('submit', function(e) {
            e.preventDefault();

            const user = {
                name: document.getElementById('name').value,
                email: document.getElementById('email').value
            };

            axios.post('/api/users', user)
                .then(response => {
                    if (response.data.success) {
                        showMessage(response.data.message, 'success');
                        document.getElementById('userForm').reset();
                        loadUsers();
                    } else {
                        showMessage(response.data.message, 'error');
                    }
                })
                .catch(error => {
                    showMessage('添加用户失败: ' + error.message, 'error');
                });
        });
    }

    function deleteUser(userId) {
        if (confirm('确定要删除这个用户吗?')) {
            axios.delete(`/api/users/${userId}`)
                .then(response => {
                    if (response.data.success) {
                        showMessage(response.data.message, 'success');
                        loadUsers();
                    } else {
                        showMessage(response.data.message, 'error');
                    }
                })
                .catch(error => {
                    showMessage('删除用户失败: ' + error.message, 'error');
                });
        }
    }

    function showMessage(message, type) {
        const messageDiv = document.getElementById('message');
        messageDiv.textContent = message;
        messageDiv.className = type;

        setTimeout(() => {
            messageDiv.textContent = '';
            messageDiv.className = '';
        }, 3000);
    }
</script>
</body>
</html>

application.properties文件

powershell 复制代码
# 服务器配置
server.port=8080

# Thymeleaf配置
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
spring.thymeleaf.mode=HTML
spring.thymeleaf.encoding=UTF-8
spring.thymeleaf.servlet.content-type=text/html
spring.thymeleaf.cache=false

# 静态资源路径
spring.web.resources.static-locations=classpath:/static/

User文件

java 复制代码
package com.example.app.model;

import lombok.Data;

@Data
public class User {
    private Long id;
    private String name;
    private String email;
}

ApiResponse文件

java 复制代码
package com.example.app.model;

import lombok.Data;

@Data
public class ApiResponse {
    private boolean success;
    private String message;
    private Object data;
    public ApiResponse(boolean success, String message) {
        this.success = success;
        this.message = message;
    }

    public ApiResponse(boolean success, String message, Object data) {
        this.success = success;
        this.message = message;
        this.data = data;
    }
}

Application文件

java 复制代码
package com.example.app;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
相关推荐
不懂英语的程序猿2 小时前
【Java 工具类】Java通过 TCP/IP 调用斑马打印机(完整实现)
java
多多*4 小时前
分布式系统中的CAP理论和BASE理论
java·数据结构·算法·log4j·maven
sg_knight4 小时前
Docker 实战:如何限制容器的内存使用大小
java·spring boot·spring·spring cloud·docker·容器·eureka
小马爱打代码4 小时前
Spring Boot 3 :实现分布式追踪
spring boot·分布式·microsoft
合作小小程序员小小店4 小时前
web网页开发,在线考勤管理系统,基于Idea,html,css,vue,java,springboot,mysql
java·前端·vue.js·后端·intellij-idea·springboot
serendipity_hky4 小时前
【微服务 - easy视频 | day03】服务与服务之间的调用
spring boot·spring cloud·微服务·架构
随便叫个啥呢6 小时前
java使用poi-tl模版+vform自定义表单生成word,使用LibreOffice导出为pdf
java·pdf·word
面向星辰7 小时前
扣子开始节点和结束节点
java·服务器·前端
烤麻辣烫7 小时前
黑马程序员苍穹外卖(新手)Day1
java·数据库·spring boot·学习·mybatis