Web后端:请求(请求参数的接收和封装)

一、简单参数

1、原始方式: 通过HttpServletRequest对象手动获取。
(1)请求url:http://ip:port/myurl?name=Tom&age=10
(2)接收:

@RequestMapping("/myurl")
publi String simpleParam(HttpServletRequest request){
	String name = request.getParameter("name");
	return name;
}

2、SpringBoot方式:参数名与形参变量名相同,定义形参即可接收参数。
(1)请求url:http://ip:port/myurl?name=Tom&age=10
(2)接收:

@RequestMapping("/myurl")
publi String simpleParam(String name, Integer age){
	return name;
}

3、SpringBoot方式:参数名与形参变量名不相同,使用@RequestParam完成映射。
(1)请求url:http://ip:port/myurl?name=Tom&age=10
(2)接收:

@RequestMapping("/myurl")
publi String simpleParam(String name, @RequestParam(name="age")Integer age123){
	return name;
}

注意:@RequestParam中的required属性默认为true,代表该请求参数必须传递,如果不传递将报错。 如果该参数是可选的,可以将required属性设置为false。

二、实体参数

1、简单实体对象:请求参数名与形参对象属性名相同,定义POJO接收即可。
(1)请求url:http://ip:port/myurl?name=Tom&age=10
(2)接收:

@RequestMapping("/myurl")
public String simplePojo(User user){
    System.out.println(user);
    return "OK";
}

public class User {
    private String name;
    private Integer age;
}

2、复杂实体对象(对象的属性包含对象):
(1)请求url:http://ip:port/myurl?name=Tom&age=10&address.provience=heilongjiang&address.city=harbin
(2)接收:

@RequestMapping("/myurl")
public String simplePojo(User user){
    System.out.println(user);
    return "OK";
}

public class User {
    private String name;
    private Integer age;
    private Address address;
}

public class Address {
    private String province;
    private String city;

三、Json参数:

JSON数据键名与形参对象属性名相同,定义POJO类型形参即可接收参数,需要使用 @RequestBody注解。
(1)请求url:http://ip:port/myurl
在Body中设置参数
在这里插入图片描述

(2)接收:

@RequestMapping("/myurl")
public String simplePojo(@RequestBody User user){
    System.out.println(user);
    return "OK";
}

public class User {
    private String name;
    private Integer age;
    private Address address;
}

public class Address {
    private String province;
    private String city;

四、路径参数

通过请求URL直接传递参数,使用{…}来标识该路径参数,需要使用 @PathVariable 获取路径参数
1)请求url:http://ip:port/myurl/Tom/10

(2)接收:

@RequestMapping("/myurl/{name}/{id}")
public String simplePojo(@PathVariable String name, @PathVariable Integer id){
    System.out.println(name);
    return "OK";
}

五、数组集合参数

数组:请求参数名与数组名一致,直接封装
集合:请求参数名与集合名一致,@RequestParam绑定关系

六、日期参数

@DateTimeFormat

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 我不会写JAVA后端代码,但是可以提供一些建议:1. 首先,您需要定义一个Servlet,用于接受前端的请求并处理它们。2. 使用Java的I/O流处理请求,以获取文件,并将其发送到前端。3. 最后,您可以使用Java的HttpServletResponse对象来将文件发送到前端。 ### 回答2: 下面是一个示例的Java后端代码,实现了根据前端请求进行文件下载的功能: ```java import org.springframework.core.io.Resource; import org.springframework.core.io.UrlResource; import org.springframework.http.HttpHeaders; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.nio.file.Paths; @RestController @RequestMapping("/api/download") public class FileDownloadController { @GetMapping("/{filename}") public ResponseEntity<Resource> downloadFile(@PathVariable String filename, HttpServletRequest request) throws IOException { // 获取要下载的文件路径 String filePath = "/path/to/files/" + filename; Path path = Paths.get(filePath); Resource resource = new UrlResource(path.toUri()); // 根据文件的MIME类型设置响应头 String contentType = request.getServletContext().getMimeType(resource.getFile().getAbsolutePath()); contentType = contentType == null ? "application/octet-stream" : contentType; // 构建并返回响应实体 return ResponseEntity.ok() .contentType(MediaType.parseMediaType(contentType)) .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + resource.getFilename() + "\"") .body(resource); } } ``` 在上述代码中,我们定义了一个名为`downloadFile`的方法,用于处理前端的下载文件请求。该方法使用`@GetMapping`注解来映射请求路径,并通过`@PathVarliable`注解来获取请求中的文件名。 在方法体内,我们首先根据文件名构建文件的绝对路径,并将其封装为`Resource`对象。然后,我们根据文件的MIME类型设置响应头中的Content-Type,并通过`ResponseEntity.ok()`来构建响应实体。 最后,我们设置响应实体的Content-Disposition头,将文件名作为附件提供下载。最后,返回包含文件内容的`Resource`对象作为响应体,完成文件下载过程。 请注意,你需要根据自己的实际情况修改代码中的文件路径和文件类型相关的代码。 ### 回答3: 以下是一个简单的JAVA后端代码示例,用于接受前端请求并通过IO流将文件下载至前端。 ```java @RestController public class FileController { @GetMapping("/download") public void downloadFile(HttpServletRequest request, HttpServletResponse response) { // 获取要下载的文件路径(可以根据前端请求参数或其他方式获得) String filePath = "/path/to/file.ext"; File file = new File(filePath); if (file.exists()) { try { // 设置响应头,指定文件下载方式 response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + file.getName()); // 创建输入流读取文件数据 FileInputStream inputStream = new FileInputStream(file); // 创建输出流将文件数据写入 response ServletOutputStream outputStream = response.getOutputStream(); byte[] buffer = new byte[1024]; int len; while ((len = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, len); } // 关闭流 outputStream.flush(); inputStream.close(); outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } else { // 文件不存在的处理逻辑 } } } ``` 这个示例中,我们使用`@GetMapping("/download")`注解将方法映射为接收前端请求的路径。根据实际情况,你可以根据实际需求添加其他的请求映射注解(如`@PostMapping`)。 在方法中,我们首先获取要下载的文件路径,然后创建一个`File`对象。如果文件存在,我们设置响应头,指定文件下载方式,并创建输入流和输出流。 通过读取输入流的数据,并将其写入输出流中,我们实现了将文件数据发送给前端进行下载的功能。最后,记得关闭流。 当然,在实际开发中,你可能还需要处理异常、验证请求、设置文件名等其他逻辑。这个示例只是提供了一种简单的实现思路。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值