package com.rabbiter.pet.controller;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.poi.excel.ExcelReader;
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.rabbiter.pet.controller.dto.UserDTO;
import com.rabbiter.pet.controller.dto.UserPasswordDTO;
import com.rabbiter.pet.common.Constants;
import com.rabbiter.pet.common.Result;
import com.rabbiter.pet.config.interceptor.AuthAccess;
import com.rabbiter.pet.entity.User;
import com.rabbiter.pet.exception.ServiceException;
import com.rabbiter.pet.service.IUserService;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.InputStream;
import java.net.URLEncoder;
import java.util.List;
/**
* <p>
* 前端控制器
* </p>
*
* @author
* @since 2023-01-26
*/
@RestController
@RequestMapping("/user")
public class UserController {
@Resource
private IUserService userService;
@PostMapping("/login")
public Result login(@RequestBody UserDTO userDTO) {
String username = userDTO.getUsername();
String password = userDTO.getPassword();
if (StrUtil.isBlank(username) || StrUtil.isBlank(password)) {
return Result.error(Constants.CODE_400, "参数错误");
}
UserDTO dto = userService.login(userDTO);
return Result.success(dto);
}
@PostMapping("/register")
public Result register(@RequestBody UserDTO userDTO) {
String username = userDTO.getUsername();
String password = userDTO.getPassword();
if (StrUtil.isBlank(username) || StrUtil.isBlank(password)) {
return Result.error(Constants.CODE_400, "参数错误");
}
userDTO.setNickname(userDTO.getUsername());
return Result.success(userService.register(userDTO));
}
// 新增或者更新
@PostMapping
public Result save(@RequestBody User user) {
String username = user.getUsername();
if (StrUtil.isBlank(username)) {
return Result.error(Constants.CODE_400, "参数错误");
}
if (user.getId() != null) {
user.setPassword(null);
} else {
user.setNickname(user.getUsername());
if (user.getPassword() == null) {
user.setPassword("123");
}
}
return Result.success(userService.saveOrUpdate(user));
}
/**
* 修改密码
*
* @param userPasswordDTO
* @return
*/
@PostMapping("/password")
public Result password(@RequestBody UserPasswordDTO userPasswordDTO) {
userService.updatePassword(userPasswordDTO);
return Result.success();
}
@AuthAccess
@PutMapping("/reset")
public Result reset(@RequestBody UserPasswordDTO userPasswordDTO) {
if (StrUtil.isBlank(userPasswordDTO.getUsername()) || StrUtil.isBlank(userPasswordDTO.getPhone())) {
throw new ServiceException("-1", "参数异常");
}
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("username", userPasswordDTO.getUsername());
queryWrapper.eq("phone", userPasswordDTO.getPhone());
List<User> list = userService.list(queryWrapper);
if (CollUtil.isNotEmpty(list)) {
User user = list.get(0);
user.setPassword("123");
userService.updateById(user);
}
return Result.success();
}
@DeleteMapping("/{id}")
public Result delete(@PathVariable Integer id) {
return Result.success(userService.removeById(id));
}
@PostMapping("/del/batch")
public Result deleteBatch(@RequestBody List<Integer> ids) {
return Result.success(userService.removeByIds(ids));
}
@GetMapping
public Result findAll() {
return Result.success(userService.list());
}
@GetMapping("/{id}")
public Result findOne(@PathVariable Integer id) {
return Result.success(userService.getById(id));
}
@GetMapping("/username/{username}")
public Result findByUsername(@PathVariable String username) {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("username", username);
return Result.success(userService.getOne(queryWrapper));
}
@GetMapping("/page")
public Result findPage(@RequestParam Integer pageNum,
@RequestParam Integer pageSize,
@RequestParam(defaultValue = "") String username,
@RequestParam(defaultValue = "") String email,
@RequestParam(defaultValue = "") String address) {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.orderByDesc("id");
if (!"".equals(username)) {
queryWrapper.like("username", username);
}
if (!"".equals(email)) {
queryWrapper.like("email", email);
}
if (!"".equals(address)) {
queryWrapper.like("address", address);
}
return Result.success(userService.page(new Page<>(pageNum, pageSize), queryWrapper));
}
/**
* 导出接口
*/
@GetMapping("/export")
public void export(HttpServletResponse response) throws Exception {
// 从数据库查询出所有的数据
List<User> list = userService.list();
// 通过工具类创建writer 写出到磁盘路径
// ExcelWriter writer = ExcelUtil.getWriter(filesUploadPath + "/用户信息.xlsx");
// 在内存操作,写出到浏览器
ExcelWriter writer = ExcelUtil.getWriter(true);
//自定义标题别名
writer.addHeaderAlias("username", "用户名");
writer.addHeaderAlias("password", "密码");
writer.addHeaderAlias("nickname", "昵称");
writer.addHeaderAlias("email", "邮箱");
writer.addHeaderAlias("phone", "电话");
writer.addHeaderAlias("address", "地址");
writer.addHeaderAlias("createTime", "创建时间");
writer.addHeaderAlias("avatarUrl", "头像");
// 一次性写出list内的对象到excel,使用默认样式,强制输出标题
writer.write(list, true);
// 设置浏览器响应的格式
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
String fileName = URLEncoder.encode("用户信息", "UTF-8");
response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");
ServletOutputStream out = response.getOutputStream();
writer.flush(out, true);
out.close();
writer.close();
}
/**
* excel 导入
*
* @param file
* @throws Exception
*/
@PostMapping("/import")
public Result imp(MultipartFile file) throws Exception {
InputStream inputStream = file.getInputStream();
ExcelReader reader = ExcelUtil.getReader(inputStream);
// 方式1:(推荐) 通过 javabean的方式读取Excel内的对象,但是要求表头必须是英文,跟javabean的属性要对应起来
// List<User> list = reader.readAll(User.class);
// 方式2:忽略表头的中文,直接读取表的内容
List<List<Object>> list = reader.read(1);
List<User> users = CollUtil.newArrayList();
for (List<Object> row : list) {
User user = new User();
user.
没有合适的资源?快使用搜索试试~ 我知道了~
玩具系统 玩具系统 玩具系统
共590个文件
java:208个
class:208个
xml:72个
需积分: 5 0 下载量 138 浏览量
2024-03-18
19:37:32
上传
评论
收藏 18.47MB ZIP 举报
温馨提示
玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具系统 玩具
资源推荐
资源详情
资源评论
收起资源包目录
玩具系统 玩具系统 玩具系统 (590个子文件)
UserController.class 10KB
UserController.class 10KB
CommentController.class 8KB
CommentController.class 8KB
FileController.class 8KB
FileController.class 8KB
ApplcationController.class 8KB
ApplcationController.class 8KB
UserServiceImpl.class 8KB
UserServiceImpl.class 8KB
MenuController.class 5KB
MenuController.class 5KB
ArticleKpController.class 5KB
ArticleKpController.class 5KB
Applcation.class 4KB
Applcation.class 4KB
AnimalController.class 4KB
AnimalController.class 4KB
User.class 4KB
User.class 4KB
ArticleController.class 4KB
ArticleController.class 4KB
RoleController.class 4KB
RoleController.class 4KB
SterilizationController.class 4KB
SterilizationController.class 4KB
NoticeController.class 4KB
NoticeController.class 4KB
SalvationController.class 4KB
SalvationController.class 4KB
Animal.class 4KB
Animal.class 4KB
RescueController.class 4KB
RescueController.class 4KB
ActivityController.class 4KB
ActivityController.class 4KB
DonateController.class 4KB
DonateController.class 4KB
LostController.class 4KB
LostController.class 4KB
FeedController.class 4KB
FeedController.class 4KB
MenuServiceImpl.class 3KB
MenuServiceImpl.class 3KB
EchartsController.class 3KB
EchartsController.class 3KB
JwtInterceptor.class 3KB
JwtInterceptor.class 3KB
Menu.class 3KB
Menu.class 3KB
Comment.class 3KB
Comment.class 3KB
UserDTO.class 3KB
UserDTO.class 3KB
TokenUtils.class 3KB
TokenUtils.class 3KB
Files.class 3KB
Files.class 3KB
RoleServiceImpl.class 3KB
RoleServiceImpl.class 3KB
Salvation.class 3KB
Salvation.class 3KB
Lost.class 3KB
Lost.class 3KB
GlobalExceptionHandler.class 2KB
GlobalExceptionHandler.class 2KB
InterceptorConfig.class 2KB
InterceptorConfig.class 2KB
Sterilization.class 2KB
Sterilization.class 2KB
SwaggerConfig.class 2KB
SwaggerConfig.class 2KB
Rescue.class 2KB
Rescue.class 2KB
Activity.class 2KB
Activity.class 2KB
ArticleKp.class 2KB
ArticleKp.class 2KB
Feed.class 2KB
Feed.class 2KB
Result.class 2KB
Result.class 2KB
Article.class 2KB
Article.class 2KB
Role.class 2KB
Role.class 2KB
Donate.class 2KB
Donate.class 2KB
Notice.class 2KB
Notice.class 2KB
UserPasswordDTO.class 2KB
UserPasswordDTO.class 2KB
PathUtils.class 2KB
PathUtils.class 2KB
CorsConfig.class 1KB
CorsConfig.class 1KB
Dict.class 1KB
Dict.class 1KB
RoleMenu.class 1KB
RoleMenu.class 1KB
共 590 条
- 1
- 2
- 3
- 4
- 5
- 6
资源评论
青铜状态
- 粉丝: 0
- 资源: 57
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于tensorflow多特征融合的微表情识别python源码.zip
- 基于yolov8实现人脸检测的python源码+运行说明.zip
- Micron Memory DDR3 SDRAM 全系列AD集成库(原理图库+PCB封装库).IntLib
- 基于tensorflow多特征融合的微表情识别python源码+详细使用说明.zip
- TensorRT部署DETR项目工程C++源码.zip
- Word文字处理软件练习题及答案.doc
- Word普通信纸信纸格式可打印.doc
- TensorRT部署DETR项目工程python源码.zip
- WPSexcel如何做柏拉图.doc
- 基于protel99se设计的PCB封装库PROTEL PCB封装库器件库常用芯片接插件电子元器件封装(1260个).lib
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功