温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SpringBoot接值如何实现

发布时间:2023-10-16 17:20:30 来源:亿速云 阅读:109 作者:栢白 栏目:开发技术

今天小编给大家分享的是SpringBoot接值如何实现,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。


接值

通过方法的参数来接收请求传来值

请求时传值的方式有三种方式 :

  • URL?name=value

  • form表单

  • Ajax异步传值

接收传来的值有三类 :

  • 单一值

  • 对象

  • 数组

传值

URL?传值

URL?标识1=值1&标识2=值2

URL后面使用 ? 连接参数, 每组参数使用 = 连接标识与值, 多组参数使用 & 连接

以 超链接为例 , 通过URL? 进行传值

<a href="/test/test04?name=wang&age=12" rel="external nofollow" >test04</a> <br>
form表单传值

<input name="标识" value="值">

在表单中 可以 , , 等标签传递值, name属性 是传值的标识 , value属性 是要传递的值

以 表单为例, 进行传值

    <form action="/test/test04" method="post" >
        <input name="name" value="wang"> 
        <input name="age" value="12">
        <input type="submit" value="提交">
    </form>
Ajax异步传值

var data = { "标识1" : "值1", "标识2" : "值2" }

将 要传递的信息封装成 JSON 结构, 通过 Ajax异步进行传值

这里使用 JQuery 的 Ajax 写法 , 修改 fn 函数

    function fn() {
        var url = "/test/test04";
        var data = {"name":"wang", "age":12};
        $.ajax({
            async: true,
            type: "POST",
            url: url,
            data: data
        })
    }

接单一值

通过 方法的参数接单一结构的值

在Controller类中增加 test04 方法

    @RequestMapping("/test/test04")
    public String test04(String name , Integer age){
        System.out.println("name = " + name);
        System.out.println("age = " + age);
        System.out.println(" controller 中的测试方法 test 04 ");
        return "ref";
    }

在页面上分别点击 , 进行传值测试 在idea的控制台都可以看到接收到的值

注意 要测试 Ajax 页面要导入 JQuery的依赖 js 包

@RequestParam注解

在不使用 @RequestParam注解 的情况要 , 方法形式参数的名 要与传值的标识对应

使用@RequestParam注解后, 可以通过注解与传值的标识对应, 而方法的形式参数名就不受限制

修改 test04方法为 name参数增加 @RequestParam注解 , 并通过注解与传值标识匹配

    @RequestMapping("/test/test04")
    public String test04(@RequestParam("name") String n , Integer age){
        System.out.println("name = " + n);
        System.out.println("age = " + age);
        System.out.println(" controller 中的测试方法 test 04 ");
        return "ref";
    }

现在测试依然能得到 打印结果

@RequestParam注解属性

但 使用了@RequestParam注解后就必须传递对应的参数

当然也可以通过设置@RequestParam注解的属性进行调整

将页面表单中的 注释掉

    <form action="/test/test04" method="post" >
<!--        <input name="name" value="wang">-->
        <input name="age" value="12">
        <input type="submit" value="提交">
    </form>

再测试, 会报 400 异常

修改 @RequestParam注解的属性

required : 是否是必须的

defaultValue : 没有接到值时, 默认设置的值

    @RequestMapping("/test/test04")
    public String test04(@RequestParam(value = "name", required = false, defaultValue = "hello") String n , Integer age){
        System.out.println("name = " + n);
        System.out.println("age = " + age);
        System.out.println(" controller 中的测试方法 test 04 ");
        return "ref";
    }

对象接值

将传递信息封装成实体类对象, 通过实体类对象接值

创建实体类User

创建 entity 包(文件夹) , 在entity包(文件夹)下创建User实体类

SpringBoot接值如何实现

User实体类

package com.yuan.entity;
import lombok.Data;
@Data
public class User {
    private String name;
    private Integer age;
}
增加新的处理方法

添加test05方法, 参数为 User 类

    @RequestMapping("/test/test05")
    public String test05(User user){
        System.out.println("name = " + user.getName());
        System.out.println("age = " + user.getAge());
        System.out.println(" controller 中的测试方法 test 05 ");
        return "ref";
    }
修改页面并测试

修改start.html页面请求URL

    <a href="/test/test05?name=wang&age=12" rel="external nofollow" >test05</a> <br>
    <form action="/test/test05" method="post" >
        <input name="name" value="wang">
        <input name="age" value="12">
        <input type="submit" value="提交">
    </form>

在浏览器发语法 , 就可以在idea控制台看到接收到信息

数组接值

传数组

多个相同的传值标识, 可以传递数组

修改start.html页面

    <a href="/test/test06?ids=1&ids=2&ids=3" rel="external nofollow" >test06</a> <br>
    <form action="/test/test06" method="post" >
        <input name="ids" value="1">
        <input name="ids" value="2">
        <input name="ids" value="3">
        <input type="submit" value="提交">
    </form>

增加接值方法test06并测试

    @RequestMapping("/test/test06")
    public String test06(Integer[] ids){
        System.out.println("Arrays.toString(ids) = " + Arrays.toString(ids));
        System.out.println(" controller 中的测试方法 test 06 ");
        return "ref";
    }
Ajax传数组一

传递 JS数组结构

修改start.html页面

    function fn() {
        var url = "/test/test07";
        // var data = { "ids" : [1, 2, 3] };
        var idss = $("[name=ids]").map(function () {
            return this.value
        }).get()
        var data = {"ids": idss}
        $.ajax({
            async: true,
            type: "POST",
            url: url,
            data: data
        });
    }

添加新的接值方法test07并测试, 注意这里增加 @RequestParam("ids[]") 注解

    @RequestMapping("/test/test07")
    public String test07(@RequestParam("ids[]") Integer[] ids){
        System.out.println("Arrays.toString(ids) = " + Arrays.toString(ids));
        System.out.println(" controller 中的测试方法 test 07 ");
        return "ref";
    }
字符串传数组

用 “,” 将信息连接成一个字符串进行传递

修改start.html页面

    <a href="/test/test06?ids=1,2,3" rel="external nofollow" >test06</a> <br>
    <form action="/test/test06" method="post" >
        <input name="ids" value="1,2,3">
        <input type="submit" value="提交">
    </form>

使用接值方法test06并测试

    @RequestMapping("/test/test06")
    public String test06(Integer[] ids){
        System.out.println("Arrays.toString(ids) = " + Arrays.toString(ids));
        System.out.println(" controller 中的测试方法 test 06 ");
        return "ref";
    }
Ajax传数组二

从 表单中获取数据, 组成数组, 再将数组使用 ","连接起来

修改start.html页面

    function fn() {
        var url = "/test/test06";
        var idss = $("[name=ids]").map(function () {
            return this.value
        }).get()
        console.log(idss)
        var data = {"ids": idss.join(",")}
        $.ajax({
            async: true,
            type: "POST",
            url: url,
            data: data
        });
    }

使用接值方法test06并测试

    @RequestMapping("/test/test06")
    public String test06(Integer[] ids){
        System.out.println("Arrays.toString(ids) = " + Arrays.toString(ids));
        System.out.println(" controller 中的测试方法 test 06 ");
        return "ref";
    }

关于SpringBoot接值如何实现就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI