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);
    }
}
相关推荐
朦胧之8 小时前
AI 编程-老项目改造篇
java·前端·后端
程序猿大帅13 小时前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪14 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly14 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
众少成多积小致巨14 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
东坡白菜15 小时前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
SimonKing21 小时前
艹,维护AI写的代码,我心态崩了......
java·后端·程序员
用户2986985301421 小时前
Java Word 文档样式进阶:段落与文本背景色设置完全指南
java·后端
小bo波2 天前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
用户3521802454752 天前
🎆从 Prompt 到 Skill:让 Spring AI Agent 学会"装新技能"
人工智能·spring boot·ai编程