1.梳理交互过程
1.页面发送ajax请求,将分页参数(page,pageSize,name)提交到服务端,获取分页数据
/**
* 菜品信息的分页
* @param page
* @param pageSize
* @param name
* @return
*/
@GetMapping("/page")
public R<Page> page(int page,int pageSize,String name){
//第一步,构造分页构造器
Page<Dish> pageInfo = new Page<>(page,pageSize);
Page<DishDto> dishDtoPage = new Page<>();
//第二步,构造条件构造器
LambdaQueryWrapper<Dish> queryWrapper = new LambdaQueryWrapper<>();
//添加过滤条件,根据name来进行查询,like模糊查询
queryWrapper.like(name != null,Dish::getName,name);
//添加排序条件,根据更新时间来降序排列
queryWrapper.orderByDesc(Dish::getUpdateTime);
//第三步,调用DishService.page方法,将分页构造器和条件构造器传进去
dishService.page(pageInfo,queryWrapper);
// return R.success(pageInfo); Dish实体里面只有分类id,没有分类名称。DishDto里面有categoryName
//将pageInfo的值复制到dishDtoPage中,不要records,给它忽略掉
BeanUtils.copyProperties(pageInfo,dishDtoPage,"records");
List<Dish> records = pageInfo.getRecords();
//将集合records处理成DishDto类型
List<DishDto> list = records.stream().map((item) -> {
DishDto dishDto = new DishDto();
//将普通属性复制到dishDto里面去
BeanUtils.copyProperties(item,dishDto);
Long categoryId = item.getCategoryId();//分类id
//拿分类id去查分类表中的分类名称,注入一个分类Service
Category category = categoryService.getById(categoryId);
if (category != null){
//得到分类名称
String categoryName = category.getName();
//转化成dishDto类型的对象
dishDto.setCategoryName(categoryName);
}
return dishDto;
}).collect(Collectors.toList());
dishDtoPage.setRecords(list);
return R.success(dishDtoPage);
}
2.页面发送请求,请求服务端进行图片下载,用于页面展示
/**
* 文件下载
* @param name
* @param response
*/
@GetMapping("/download")
public void download(String name, HttpServletResponse response){
try {
//输入流,通过输入流读取文件内容
FileInputStream fileInputStream = new FileInputStream(new File(basePath + name));
//输出流,通过输出流将文件写回浏览器
ServletOutputStream outputStream = response.getOutputStream();
response.setContentType("image/jpeg");
int len = 0;
byte[] bytes = new byte[1024];
while ((len = fileInputStream.read(bytes)) != -1){
outputStream.write(bytes,0,len);
outputStream.flush();
}
//关闭资源
outputStream.close();
fileInputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
}