目录
实现内容概要
创建Bot相关数据库
实现PoJo层
第一个API插入Bot
然后测试一下接口
实现第二个API-remove
实现下更新操作的API
写最后一个API查询所有Bot
个人中心页面,bot页面
在数据库中创建表bot
表中包含的列:id: int:非空、自动增加、唯一、主键
user_id: int:非空
注意:在pojo中需要定义成userId,在queryWrapper中的名称仍然为user_id
title: varchar(100)
description: varchar(300)
content:varchar(10000)
rating: int:默认值为1500
createtime: datetime
pojo中定义日期格式的注解:@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”)
modifytime: datetime
pojo中定义日期格式的注解:@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”)
id: int:非空、自动增加、唯一、主键
user_id: int:非空
title: varchar(100)
description: varchar(300)
content:varchar(10000)
rating: int:默认值为1500
createtime: datetime
在pojo里最好用Integer,否则会报警告
pojo里要用驼峰命名法,数据库里用下划线
注意:在pojo中需要定义成userId,在queryWrapper中的名称仍然为user_id在 pojo 目录下新建新的文件 Bot.java,数据和数据库中的 bot 表一一对应。
package com.kill9.backend.pojo;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.Date;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Bot {
@TableId(type = IdType.AUTO)
private Integer id;//在pojo里最好用Integer,否则会报警告
private Integer userId;//pojo里要用驼峰命名法和数据库的下划线对应
private String title;
private String description;
private String content;
private Integer rating;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date createtime;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date modifytime;
}
在 Mapper 目录下新建 BotMapper.java 文件,映射 SQL 语句。
package com.kill9.backend.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.kill9.backend.pojo.Bot;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface BotMapper extends BaseMapper {
}
增加一个Bot
在 com/kob/backend/service/user 新建一个新目录 bot 同时新建一个接口文件 AddService
在 com/kob/backend/service/impl/user 新建一个新目录 bot 同时新建一个实现类 AddServiceImpl
package com.kill9.backend.service.impl.user.bot;
import com.kill9.backend.mapper.BotMapper;
import com.kill9.backend.pojo.Bot;
import com.kill9.backend.pojo.User;
import com.kill9.backend.service.impl.utils.UserDetailsImpl;
import com.kill9.backend.service.user.bot.AddService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Service;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
@Service
public class AddServiceImpl implements AddService {
@Autowired
private BotMapper botMapper;
@Override
public Map add(Map data) {
UsernamePasswordAuthenticationToken authenticationToken = (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
User user = loginUser.getUser();
String title = data.get("title");
String description = data.get("description");
String content = data.get("content");
Map map = new HashMap<>();
if(title == null || title.length() == 0){
map.put("error_message","标题不能为空");
return map;
}
if (title.length() > 100) {
map.put("error_message", "标题长度不能大于100");
return map;
}
if (description == null || description.length() == 0) {
description = "这个用户很懒,什么也没有留下~";
}
if (description.length() > 300) {
map.put("error_message", "Bot描述的长度不能大于300");
return map;
}
if (content == null || content.length() == 0) {
map.put("error_message", "代码不能为空");
return map;
}
if (content.length() > 10000) {
map.put("error_message", "代码长度不能超过10000");
return map;
}
Date now = new Date();
Bot bot = new Bot(null, user.getId(), title, description, content, 1500, now, now);
botMapper.insert(bot);
map.put("error_message","success");
return map;
}
}
在 com/kob/backend/controller/user 新建一个新目录 bot 同时新建一个 Controller 类 AddController。
package com.kill9.backend.controller.user.bot;
import com.kill9.backend.service.user.bot.AddService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.Map;
@RestController
public class AddController {
@Autowired
private AddService addService;
@PostMapping("/user/bot/add/")
public Map add(@RequestParam Map data){
return addService.add(data);
}
}
在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
我的Bot
在 com/kob/backend/service/user/bot 新建一个接口文件 RemoveService
package com.kill9.backend.service.user.bot;
import java.util.Map;
public interface RemoveService {
Map remove(Map data);
}
在 com/kob/backend/service/impl/user/bot 新建一个实现类 RemoveServiceImpl
package com.kill9.backend.service.impl.user.bot;
import com.kill9.backend.mapper.BotMapper;
import com.kill9.backend.pojo.Bot;
import com.kill9.backend.pojo.User;
import com.kill9.backend.service.impl.utils.UserDetailsImpl;
import com.kill9.backend.service.user.bot.RemoveService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.Map;
@Service
public class RemoveServiceImpl implements RemoveService {
@Autowired
private BotMapper botMapper;
@Override
public Map remove(Map data) {
UsernamePasswordAuthenticationToken authenticationToken = (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
User user = loginUser.getUser();
int bot_id = Integer.parseInt(data.get("bot_id"));
Bot bot = botMapper.selectById(bot_id);
Map map = new HashMap<>();
if (bot == null) {
map.put("error_message", "Bot不存在或已被删除");
return map;
}
if (!bot.getUserId().equals(user.getId())) {
map.put("error_message", "没有权限删除该Bot");
return map;
}
botMapper.deleteById(bot_id);
map.put("error_message", "success");
return map;
}
}
在 com/kob/backend/controller/user/bot 新建一个 Controller 类 RemoveController
package com.kill9.backend.controller.user.bot;
import com.kill9.backend.service.user.bot.RemoveService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.Map;
@RestController
public class RemoveController {
@Autowired
private RemoveService removeService;
@PostMapping("/user/bot/remove/")
public Map remove(@RequestParam Map data){
return removeService.remove(data);
}
}
删除一个 Bot 测试 记得重启后台
在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
我的Bot
在 com/kob/backend/service/user/bot 新建一个接口文件 UpdateService
package com.kill9.backend.service.user.bot;
import java.util.Map;
public interface UpdateService {
Map update(Map data);
}
在 com/kob/backend/service/impl/user/bot 新建一个实现类 UpdateServiceImpl
package com.kill9.backend.service.impl.user.bot;
import com.kill9.backend.mapper.BotMapper;
import com.kill9.backend.pojo.Bot;
import com.kill9.backend.pojo.User;
import com.kill9.backend.service.impl.utils.UserDetailsImpl;
import com.kill9.backend.service.user.bot.UpdateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Service;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
@Service
public class UpdateServiceImpl implements UpdateService {
@Autowired
private BotMapper botMapper;
@Override
public Map update(Map data) {
UsernamePasswordAuthenticationToken authenticationToken = (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
User user = loginUser.getUser();
int bot_id = Integer.parseInt(data.get("bot_id"));
String title = data.get("title");
String description = data.get("description");
String content = data.get("content");
Map map = new HashMap<>();
if (title == null || title.length() == 0) {
map.put("error_message", "标题不能为空");
return map;
}
if (title.length() > 100) {
map.put("error_message", "标题长度不能大于100");
return map;
}
if (description == null || description.length() == 0) {
description = "这个用户很懒,什么也没有留下~";
}
if (description.length() > 300) {
map.put("error_message", "Bot描述的长度不能大于300");
return map;
}
if (content == null || content.length() == 0) {
map.put("error_message", "代码不能为空");
return map;
}
if (content.length() > 10000) {
map.put("error_message", "代码长度不能超过10000");
}
Bot bot = botMapper.selectById(bot_id);
if (bot == null) {
map.put("error_message", "Bot不存在或已经被删除");
return map;
}
if (!bot.getUserId().equals(user.getId())) {
map.put("error_message", "没有权限修改该Bot");
return map;
}
Bot new_bot = new Bot(
bot.getId(),
user.getId(),
title,
description,
content,
bot.getRating(),
bot.getCreatetime(),
new Date()
);
botMapper.updateById(new_bot);
map.put("error_message", "success");
return map;
}
}
在 com/kob/backend/controller/user/bot 新建一个 Controller 类 UpdateController。
package com.kill9.backend.controller.user.bot;
import com.kill9.backend.service.user.bot.UpdateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Map;
@RestController
public class UpdateController {
@Autowired
private UpdateService updateService;
@PostMapping("/user/bot/update/")
public Map update(@RequestParam Map data) {
return updateService.update(data);
}
}
修改一个 Bot 测试 记得重启后台~
在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
我的Bot
在 com/kob/backend/service/user/bot 新建一个接口文件 GetListService
package com.kill9.backend.service.user.bot;
import com.kill9.backend.pojo.Bot;
import java.util.List;
public interface GetListService {
List getList();
}
在 com/kob/backend/service/impl/user/bot 新建一个实现类 GetListServiceImpl
package com.kill9.backend.service.impl.user.bot;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.kill9.backend.mapper.BotMapper;
import com.kill9.backend.pojo.Bot;
import com.kill9.backend.pojo.User;
import com.kill9.backend.service.impl.utils.UserDetailsImpl;
import com.kill9.backend.service.user.bot.GetListService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class GetListServiceImpl implements GetListService {
@Autowired
private BotMapper botMapper;
@Override
public List getList() {
UsernamePasswordAuthenticationToken authenticationToken = (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
User user = loginUser.getUser();
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.eq("user_id", user.getId());
return botMapper.selectList(queryWrapper);
}
}
在 com/kob/backend/controller/user/bot 新建一个 Controller 类 GetListController。
package com.kill9.backend.controller.user.bot;
import com.kill9.backend.pojo.Bot;
import com.kill9.backend.service.user.bot.GetListService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class GetListController {
@Autowired
private GetListService getListService;
@GetMapping("/user/bot/getlist/")
public List getList() {
return getListService.getList();
}
}
查询 Bot 列表测试
在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
$.ajax({
url: "http://127.0.0.1:3000/user/bot/getlist/",
type: "get",
headers: {
Authorization: "Bearer " + store.state.user.token,
},
success(resp) {
console.log(resp);
},
error(resp) {
console.log(resp);
}
})
完成~