SpringBoot入门,html页面提交form表单,后端接收数据,后端处理返回数据给html页面

一、idea创建SpringBoot项目步骤

1.File->New->project
2.在这里插入图片描述
3.
在这里插入图片描述

二、代码开发

1.html页面代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="http://localhost:8080/test" method="post">
    <input type="text" name="username">
    <input type="submit" value="提交">
</form>
</body>
</html>

2.编写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"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.2.4</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>demo</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <scope>compile</scope>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>
        
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.76</version>
        </dependency>

        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>

<!--        <dependency>-->
<!--            <groupId>mysql</groupId>-->
<!--            <artifactId>mysql-connector-java</artifactId>-->
<!--            <scope>runtime</scope>-->
<!--        </dependency>-->

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.23</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.4.5</version>
            </plugin>
        </plugins>
    </build>

</project>

3.SpringBoot项目启动类

@Slf4j 是Lombok 提供的注解之一。简化日志记录代码的编写
举例 log.info(“项目启动”);

exclude = {DataSourceAutoConfiguration.class},用 @SpringBootApplication 的 exclude 属性来排除 DataSourceAutoConfiguration 类,
不然会报错Failed to configure a DataSource: ‘url‘ attribute is not specified and no embedded,是因为我们没用到数据库

package com.example;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.web.servlet.ServletComponentScan;

@Slf4j
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@ServletComponentScan
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
        log.info("项目启动");
    }

}

4.在application.yml中写服务端口

server:
  port: 8080

5.创建controller包,在此包下写MyController控制类

package com.example.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class MyController {
    @PostMapping("/test")
    @ResponseBody//将MyController控制类,处理的数据返回给html页面
    public String test(String username){
        System.out.println("username:"+username);
        return "收到数据";
    }
}

6.项目结构(不同版本的SpringBoot,生成的原始项目结构会不同)

在这里插入图片描述

三、效果展示

在这里插入图片描述

html接收到了数据
在这里插入图片描述

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前端提交表单数据需要使用表单标签,一般情况下使用form和input标签来实现,如下所示: ```html <form method="post" action="/submit"> <label for="name">姓名:</label> <input type="text" id="name" name="name"><br><br> <label for="age">年龄:</label> <input type="text" id="age" name="age"><br><br> <button type="submit">提交</button> </form> ``` 上述代码中,`form`标签的`method`属性设置为`post`,表示使用POST方法提交表单数据。`action`属性值指定了表单数据提交的地址,这里设置为`/submit`。`label`标签为表单项添加了标签,`input`标签用来输入数据,其中`name`属性是必须的,表示表单项的名称,后端接收表单数据时需要使用该名称来获取数据。`button`标签用来提交表单。 在后端,可以使用不同的编程语言和框架来接收表单数据和展示数据。以Node.js和Express框架为例,可以使用以下代码来处理表单数据: ```javascript const express = require('express'); const app = express(); // 解析请求体 app.use(express.urlencoded({ extended: true })); // 处理表单提交数据 app.post('/submit', (req, res) => { const name = req.body.name; const age = req.body.age; // 在这里进行数据处理或保存到数据库等操作 // 返回结果页面 res.send(`提交成功!姓名:${name},年龄:${age}`); }); // 启动服务器 app.listen(3000, () => { console.log('Server is running on port 3000'); }); ``` 上述代码中,`express.urlencoded()`中间件用来解析请求体,将表单数据解析成对象并存储在`req.body`中。在`/submit`路由中获取`name`和`age`数据,进行相应的数据处理,最后返回结果页面。 在前端展示数据时,可以使用模板引擎来实现动态渲染页面。以EJS模板引擎为例,可以使用以下代码展示数据: ```html <!DOCTYPE html> <html> <head> <title>表单提交结果</title> </head> <body> <h1>表单提交结果</h1> <p>姓名: <%= name %> </p> <p>年龄: <%= age %> </p> </body> </html> ``` 在上述代码中,使用`<%= %>`语法来嵌入变量,`name`和`age`变量的值会被替换为后端传递过来的数据。在Express框架中,可以使用`res.render()`方法来渲染模板页面,如下所示: ```javascript // 渲染模板页面 app.post('/submit', (req, res) => { const name = req.body.name; const age = req.body.age; // 在这里进行数据处理或保存到数据库等操作 // 渲染模板页面返回 res.render('result', { name: name, age: age }); }); ``` 上述代码中,使用`res.render()`方法渲染名为`result`的模板页面,并将`name`和`age`变量传递给模板引擎。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值