当前位置: 首页 > 知识库问答 >
问题:

我输入代码{“name”:“upul”,“email”:upul@gmail.com“}以邮递员的身份作为邮寄请求,

叶富
2023-03-14

但我犯了个错误,

2021-02-05 12:19:08.944WARN 8168---[nio-8080-exec-3]. w. s. m. s.DefaultHandlerExceptionResolver:已解决[org.springframework.web.bind.MisSingServletResestParameterExcture:必需的字符串参数'name'不存在]

依赖关系是,

<?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>2.4.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example.sample</groupId>
    <artifactId>springboot-test</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot-test</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

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


        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

    </dependencies>

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

</project>

**存储库是**

package com.example.sample.springboottest.Model;


import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {

    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private Integer id;

    private String name;

    private String email;

    public Integer getId() {
        return id;
    }



    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

**控制器是**

package com.example.sample.springboottest.Controller;

import com.example.sample.springboottest.Model.User;
import com.example.sample.springboottest.Repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

@Controller
@RequestMapping(path = "/demo")
public class MainController {

@Autowired
private UserRepository userRepository;

@PostMapping(path = "/add")
public @ResponseBody String addNewUser(@RequestParam String name, @RequestParam String email){

    User n =new User();

    n.setName(name);
    n.setEmail(email);
    userRepository.save(n);
    return "Saved";
}


@GetMapping(path = "/all")
public @ResponseBody Iterable<User> getAllUser(){
    return userRepository.findAll();
}




}

**属性是,**

spring.jpa.hibernate.ddl-auto=update
spring.datasource.url=jdbc:mysql://${MYSQL_HOST:localhost}:3306/db_example
spring.datasource.username=root
spring.datasource.password=root


spring.jpa.open-in-view=true

spring.jpa.show-sql=true

请帮我修一下,

共有3个答案

云曦之
2023-03-14
Required String parameter 'name' is not present

默认情况下,需要使用@recestParam注释的方法参数。在调用API时,似乎没有传递name查询参数。

编辑:在这种情况下,我们可以在请求正文中传递用户。

松智勇
2023-03-14

看来你把@RequestParam@RequestBody

您似乎想一个JSON对象发布到您的控制器,在这种情况下,您的方法签名应该是

public@ResponseBody String addNewUser(@RequestBody User User){

相高谊
2023-03-14

因为您使用的是@ReuestParam,所以无法像以前那样传递JSON。为了将JSON格式更改@RequestParam为@RequestBody,如下所示:

    @PostMapping(path = "/add")
    public @ResponseBody String addNewUser(@RequestBody User user){

//        User n =new User();
//
//        n.setName(name);
//        n.setEmail(email);
//        userRepository.save(n);
        userRepository.save(user);
        return "Saved";
    }

邮递员的结果如下:

但如果需要使用@RequestParam,请按如下方式传递查询字符串:

localhost:8811/demo/add?name=upul&email=upul@gmail.com
 类似资料:
  • 我正在做一个关于林达的烧瓶课程,但遇到了一个例子的问题。https://www.lynda.com/Flask-tutorials/Web-API-Development-Flask/521200-2.html 我做一个简单的职位,它的工作时,从一个基本的网络表单,但从邮递员失败。我想这是因为邮递员对请求的编码不同,但不知道为什么会这样,或者为什么烧瓶不能读取它。 查理斯截获的请求: 返回: 从简

  • Postman上有没有办法在执行请求A之前预先执行请求B? 上下文:我创建了一个Symfony应用程序来管理一组web服务。大多数路由只有在用户完全通过身份验证后才能被调用(对于熟悉框架的人使用form_login和防火墙) 因此,我必须先打电话: 邮政 /login 用户名 密码 在能够呼叫之前 获取/某些_安全_路线 (返回 JSON 响应) 当我在Postman构建器中连续手动调用路由时,这

  • 我在Postman中添加了用户名和密码作为基本身份验证 那么,如果我输入了一些错误的用户名/密码或为空,为什么我没有得到401身份验证错误呢?

  • 在本章中,我们将向您展示如何使用Firebase电子邮件/密码身份验证。 创建用户 要对用户进行身份验证,我们可以使用createUserWithEmailAndPassword(email, password)方法。 例子 (Example) 让我们考虑以下示例。 var email = "myemail@email.com"; var password = "mypassword"; fire

  • 有人能帮助我如何使用以下参数发送POST请求吗: 我试着在《邮递员的身体》中发送一个带有以下参数的: 然而,在发送上述请求时,我得到的位置字符串为null。

  • 我通过邮递员以以下方式调用我的java webservice(POST请求),这种方式工作得非常好(即,我可以看到我的记录被插入到数据库中): 下面是选项卡中的内容: 我必须使用CURL在PHP中调用相同的请求,而不是通过POSTMAN调用它。我想知道是否有办法将此命令导出到命令,以便在PHP代码中使用它?我在网上的许多地方发现了相反的方法,有人要求将基于Curl的请求转换为POSTMAN,但却不