第五章---创建个人中心页面(上)

news/2024/11/16 14:33:19/

1. 整体框架

在这里插入图片描述
在这里插入图片描述

2. 新建表 bot

在数据库中新建表 bot

表中包含的列:

  • id: int:非空、自动增加、唯一、主键

pojo 中定义主键的注解:@TableId(type = IdType.AUTO)

  • 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")

在这里插入图片描述

在这里插入图片描述

3.实现后端API

3.1 连接数据库和后端
  • pojo 目录下新建新的文件 Bot.java,数据和数据库中的 bot 表一一对应。
package com.kob.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
@AllArgsConstructorpublic 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.kob.backend.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.kob.backend.pojo.Bot;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface BotMapper extends BaseMapper<Bot> {
}

在这里插入图片描述
在这里插入图片描述

3.2 实现 增删改查 API

Ⅰ增加一个Bot

  • com/kob/backend/service/user 新建一个新目录 bot 同时新建一个接口文件 AddService
package com.kob.backend.service.user.bot;import java.util.Map;public interface AddService {Map<String, String> add(Map<String, String> data);
}

在这里插入图片描述

  • com/kob/backend/service/impl/user 新建一个新目录 bot 同时新建一个实现类 AddServiceImpl
package com.kob.backend.service.impl.user.bot;import com.kob.backend.mapper.BotMapper;
import com.kob.backend.pojo.Bot;
import com.kob.backend.pojo.User;
import com.kob.backend.service.impl.utils.UserDetailsImpl;
import com.kob.backend.service.user.bot.AddService;
import lombok.Data;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.core.userdetails.UserCache;
import org.springframework.stereotype.Service;import java.util.Date;
import java.util.HashMap;
import java.util.Map;@Service
public class AddServiceImpl implements AddService {@Autowiredprivate BotMapper botMapper;@Overridepublic Map<String, String> add(Map<String, String> 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<String, String> 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 同时新建一个 ControllerAddController
package com.kob.backend.controller.user.bot;import com.kob.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 {@Autowiredprivate AddService addService;@PostMapping("/user/bot/add/")public Map<String, String> add(@RequestParam Map<String, String> data) {return  addService.add(data);}
}

在这里插入图片描述
增加一个 bot 测试

  • 在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
<template><ContentField>我的Bot</ContentField>
</template><script>
import ContentField from '../../../components/ContentField'
import $ from 'jquery'
import { useStore } from 'vuex';export default {components: {ContentField},setup() {const store = useStore();// 在这里,设置的端口号为 8080,如果你已经修改了端口号,需要修改url。$.ajax({url: "http://127.0.0.1:8080/user/bot/add/",type: "post",data: {title: "Bot的标题",description : "Bot的描述",content: "Bot的代码",},headers: {Authorization: "Bearer " + store.state.user.token,},success(resp) {console.log(resp);},error(resp) {console.log(resp);}})}}
</script><style scoped> 
</style>

效果如下:

在这里插入图片描述
Ⅱ 删除一个Bot

  • com/kob/backend/service/user/bot 新建一个接口文件 RemoveService
package com.kob.backend.service.user.bot;import java.util.Map;public interface RemoveService {Map<String, String> remove(Map<String, String> data);
}
  • com/kob/backend/service/impl/user/bot 新建一个实现类 RemoveServiceImpl
package com.kob.backend.service.impl.user.bot;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.kob.backend.mapper.BotMapper;
import com.kob.backend.pojo.Bot;
import com.kob.backend.pojo.User;
import com.kob.backend.service.impl.utils.UserDetailsImpl;
import com.kob.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 {@Autowiredprivate BotMapper botMapper;@Overridepublic Map<String, String> remove(Map<String, String> 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<String, String> 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 新建一个 ControllerRemoveController
package com.kob.backend.controller.user.bot;import com.kob.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 {@Autowiredprivate RemoveService removeService;@PostMapping("/user/bot/remove/")public Map<String, String> remove(@RequestParam Map<String, String> data) {return removeService.remove(data);}
}

删除一个 Bot 测试

  • 在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
<template><ContentField>我的Bot</ContentField>
</template><script>
import ContentField from '../../../components/ContentField'
import $ from 'jquery'
import { useStore } from 'vuex';export default {components: {ContentField},setup() {const store = useStore();// 在这里,设置的端口号为 8080,如果你已经修改了端口号,需要修改url。$.ajax({url: "http://127.0.0.1:8080/user/bot/remove/",type: "POST",data: {bot_id: 3, //可以修改为自己的bot_id},headers: {Authorization: "Bearer " + store.state.user.token,},success(resp) {console.log(resp);},error(resp) {console.log(resp);}})}}
</script><style scoped> 
</style>

效果如下:

在这里插入图片描述
Ⅲ 修改一个 Bot

  • com/kob/backend/service/user/bot 新建一个接口文件 UpdateService
package com.kob.backend.service.user.bot;import java.util.Map;public interface UpdateService {Map<String, String> update(Map<String, String> data);
}
  • com/kob/backend/service/impl/user/bot 新建一个实现类 UpdateServiceImpl
package com.kob.backend.service.impl.user.bot;import com.kob.backend.mapper.BotMapper;
import com.kob.backend.pojo.Bot;
import com.kob.backend.pojo.User;
import com.kob.backend.service.impl.utils.UserDetailsImpl;
import com.kob.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 {@Autowiredprivate BotMapper botMapper;@Overridepublic Map<String, String> update(Map<String, String> 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<String, String> 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 新建一个 ControllerUpdateController
package com.kob.backend.controller.user.bot;import com.kob.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.RequestParam;
import org.springframework.web.bind.annotation.RestController;import java.util.Map;@RestController
public class UpdateController {@Autowiredprivate UpdateService updateService;@PostMapping("/user/bot/update/")public Map<String, String> update(@RequestParam Map<String, String> data) {return updateService.update(data);}
}

修改一个 Bot 测试

  • 在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
<template><ContentField>我的Bot</ContentField>
</template><script>
import ContentField from '../../../components/ContentField'
import $ from 'jquery'
import { useStore } from 'vuex';export default {components: {ContentField},setup() {const store = useStore();// 在这里,设置的端口号为 8080,如果你已经修改了端口号,需要修改url。$.ajax({url: "http://127.0.0.1:8080/user/bot/update/",type: "POST",data: {bot_id: 1,title: "我是Bot_1的标题",description : "我是Bot_1的描述",content: "我是Bot_1的代码",},headers: {Authorization: "Bearer " + store.state.user.token,},success(resp) {console.log(resp);},error(resp) {console.log(resp);}})}}
</script><style scoped> 
</style>

效果如下:

在这里插入图片描述
在这里插入图片描述
Ⅳ 查询 Bot 列表

  • com/kob/backend/service/user/bot 新建一个接口文件 GetListService
package com.kob.backend.service.user.bot;import com.kob.backend.pojo.Bot;import java.util.List;public interface GetListService {List<Bot> getList();
}
  • com/kob/backend/service/impl/user/bot 新建一个实现类 GetListServiceImpl
package com.kob.backend.service.impl.user.bot;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.kob.backend.mapper.BotMapper;
import com.kob.backend.pojo.Bot;
import com.kob.backend.pojo.User;
import com.kob.backend.service.impl.utils.UserDetailsImpl;
import com.kob.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 {@Autowiredprivate BotMapper botMapper;@Overridepublic List<Bot> getList() {UsernamePasswordAuthenticationToken authenticationToken = (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();User user = loginUser.getUser();QueryWrapper<Bot> queryWrapper = new QueryWrapper<>();queryWrapper.eq("user_id", user.getId());return botMapper.selectList(queryWrapper);}
}
  • com/kob/backend/controller/user/bot 新建一个 ControllerGetListController
package com.kob.backend.controller.user.bot;import com.kob.backend.pojo.Bot;
import com.kob.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 {@Autowiredprivate GetListService getListService;@GetMapping("/user/bot/getlist/")public List<Bot> getList() {return getListService.getList();}
}

查询 Bot 列表测试

  • 在前端 web 项目下 kob/web/src/views/user/bot 的文件 UserBotIndexView.vue 下编写测试。
<template><ContentField>我的Bot</ContentField>
</template><script>
import ContentField from '../../../components/ContentField'
import $ from 'jquery'
import { useStore } from 'vuex';export default {components: {ContentField},setup() {const store = useStore();// 在这里,设置的端口号为 8080,如果你已经修改了端口号,需要修改url。$.ajax({url: "http://127.0.0.1:8080/user/bot/getlist/",type: "get",headers: {Authorization: "Bearer " + store.state.user.token,},success(resp) {console.log(resp);},error(resp) {console.log(resp);}})}}
</script><style scoped> 
</style>

效果如下:

在这里插入图片描述


http://www.ppmy.cn/news/1263356.html

相关文章

RFID在新能源工厂大放异彩

RFID在新能源工厂大放异彩 我国在十四五规划中提出了建设绿色低碳发展的目标&#xff0c;新能源产业成为了国家发展的重点领域之一&#xff0c;开始大力支持各种新能源厂商发展。各个厂商之间不仅比产品、比技术。也比生产想要降本增效&#xff0c;为了实现这一目标&#xff0…

InnoDB Architecture MySQL 5.7 vs 8.0

innodb-architecture-5-7 innodb-architecture-8-0 图片均来源于MySQL官网

2.1 Linux C 编程

一、Hello World 1、在用户根目录下创建一个C_Program&#xff0c;并在这里面创建3.1文件夹来保存Hellow World程序&#xff1b; 2、安装最新版nvim ①sudo apt-get install ninja-build gettext cmake unzip curl ②sudo apt install lua5.1 ③git clone https://github.…

Redis基础系列-持久化

Redis基础系列-持久化 文章目录 Redis基础系列-持久化1. 什么是持久化2. 为什么要持久化3. 持久化的两种方式3.1 持久化方式1&#xff1a;RDB(redis默认持久化方式)3.11 配置步骤-自动触发3.12 配置步骤-手动触发3.12 优点3.13 缺点3.14 检查和修复RDB快照文件3.15 哪些情况会触…

2024年AI视频识别技术的6大发展趋势预测

随着人工智能技术的快速发展&#xff0c;AI视频识别技术也将会得到进一步的发展和应用。2023年已经进入尾声&#xff0c;2024年即将来临&#xff0c;那么AI视频识别技术又将迎来怎样的发展趋势&#xff1f;本文将对2023年的AI视频技术做一个简单的盘点并对2024年的发展趋势进行…

深入理解 Promise:前端异步编程的核心概念

深入理解 Promise&#xff1a;前端异步编程的核心概念 本文将帮助您深入理解 Promise&#xff0c;这是前端异步编程的核心概念。通过详细介绍 Promise 的工作原理、常见用法和实际示例&#xff0c;您将学会如何优雅地处理异步操作&#xff0c;并解决回调地狱问题。 异步编程和…

SAP UI5 walkthrough step10 Descriptor for Applications

在这一步&#xff0c;我们将会把所有的应用相关的描述性的文件独立放到manifest.json 新建一个manifest.json文件 webapp/manifest.json (New) {"_version": "1.58.0","sap.app": {"id": "ui5.walkthrough","i18n&q…

【MySQL】:库的操作

库的操作 一.创建和删除数据库二.认识编码三.库的查改1.查找2.修改 四.库的备份和恢复1.备份2.还原 一.创建和删除数据库 说明&#xff1a; 1.大写的表示关键字 2.[] 是可选项 3.CHARACTER SET: 指定数据库采用的字符集 4.COLLATE: 指定数据库字符集的校验规则首先进入MySQL 创…