SpringBoot项目——创建个人中心页面

SpringBoot项目——创建个人中心页面

回顾:
SpringBoot项目——前端页面授权+注册页面实现+登录状态持久化
SpringBoot项目——jwt 登录验证与编写前后端分离API
SpringBoot项目——配置Mysql与session注册登录验证
SpringBoot项目——创建菜单与游戏页面
SpringBoot项目——配置git环境与项目创建


1. 创建后端API(增删改查)

1.1 在数据库中创建表 bot

bot表中包含的列:

  • id: int:非空、自动增加、唯一、主键
    • @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”)

1.2 实现 pojo 层——bot
package com.kob.backend.pojo;

import ...

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Bot {
    @TableId(type = IdType.AUTO) // 注解ID递增
    private Integer id;
    // 数据库里用下划线,pojo中需要用驼峰命名
    private Integer userId;
    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;

}
1.3 实现 mapper 层——bot
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> {
}

实现后端四个API

  • /user/bot/add/:创建一个Bot
  • /user/bot/remove/:删除一个Bot
  • /user/bot/update/:修改一个Bot
  • /user/bot/getlist/:查询Bot列表

1.4 实现 service 层

分别编写四个APIservice接口:
在这里插入图片描述
分别实现四个APIservice接口:

  • AddServiceImpl.class
package com.kob.backend.service.impl.user.bot;

import ...

@Service
public class AddServiceImpl implements AddService {

    // 加入数据库,对数据库操作
    @Autowired
    private BotMapper botMapper;

    @Override
    public Map<String, String> add(Map<String, String> data) {

        // 得到当前token里的user信息赋值给建立User类型的user
        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;
    }
}
  • RemoveServiceImpl.class
package com.kob.backend.service.impl.user.bot;

import ...

@Service
public class RemoveServiceImpl implements RemoveService {
    // 加入数据库,对数据库操作
    @Autowired
    private BotMapper botMapper;

    @Override
    public Map<String, String> remove(Map<String, String> data) {
        // 得到当前token里的user信息赋值给建立User类型的user
        // 判断当前用户是否跟要删除的Bot里的作者user_id一致,一致才能有删除权限
        UsernamePasswordAuthenticationToken authenticationToken =
                (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
        UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
        User user = loginUser.getUser();

        // String user_id = user.getId();
        // 传参要删除的bot_id(自己定义),并找出这个bot_id对应id的bot
        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;
        }

        // getUserId(找到要删除bot的对应的作者user_id)
        // 判断要删除的判Bot里的作者user_id是否是当前作者,即是否有权限删除
        if (!bot.getUserId().equals(user.getId())) {
            map.put("error_message", "没有权限删除该Bot");
            return map;
        }

        botMapper.deleteById(bot_id);
        map.put("error_message", "success");
        return map;
    }
}
  • UpdateServiceImpl.class
package com.kob.backend.service.impl.user.bot;

import ...

@Service
public class UpdateServiceImpl implements UpdateService {

    @Autowired
    private BotMapper botMapper;

    @Override
    public Map<String, String> update(Map<String, String> data) {
        // 获取当前的token所存当前user信息
        UsernamePasswordAuthenticationToken authenticationToken =
                (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
        UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
        User user = loginUser.getUser();

        // 传入要修改的bot_id以及更新的信息
        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");
            return map;
        }

        // 查询是否是作者
        Bot bot = botMapper.selectById(bot_id);
        if (bot == null) {
            map.put("error_message", "Bot不存在或已被删除。");
            return map;
        }

        // 所要删除的bot的作者user_id 是否是当前user
        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()
        );

        // Bot里创建新bot
        botMapper.updateById(new_bot);
        map.put("error_message", "success");
        return map;
    }
}
  • GetListServiceImpl.class
package com.kob.backend.service.impl.user.bot;

import ...

// 查询当前用户下的所有Bot
@Service
public class GetListServiceImpl implements GetListService {
    @Autowired
    private BotMapper botMapper;



    @Override
    public List<Bot> getList() {
        // 得到当前token里的user信息
        UsernamePasswordAuthenticationToken authenticationToken =
                (UsernamePasswordAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
        UserDetailsImpl loginUser = (UserDetailsImpl) authenticationToken.getPrincipal();
        User user = loginUser.getUser();

        // 数据库中查询用到queryWrapper
        QueryWrapper<Bot> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("user_id", user.getId());

        return botMapper.selectList(queryWrapper);
    }
}
1.5 实现 controller 层
  • AddController.class
package com.kob.backend.controller.user.bot;

import ...

@RestController
public class AddController {
    @Autowired
    private AddService addService;

    @PostMapping("/user/bot/add/")
    public Map<String, String> add(@RequestParam Map<String, String> data) {
        return addService.add(data);
    }
}
  • RemoveController.class
package com.kob.backend.controller.user.bot;

import ...

@RestController
public class RemoveController {
    @Autowired
    private RemoveService removeService;

    @PostMapping("/user/bot/remove/")
    public Map<String, String> remove(@RequestParam Map<String, String> data) {
        return removeService.remove(data);
    }
}
  • UpdateController.class
package com.kob.backend.controller.user.bot;

import ...

@RestController
public class UpdateController {
    @Autowired
    private UpdateService  updateService;

    @PostMapping("/user/bot/update/")
    public Map<String, String> update(@RequestParam Map<String, String> data) {
        return updateService.update(data);
    }
}

  • GetListController.class
package com.kob.backend.controller.user.bot;

import ...

@RestController
public class GetListController {
    @Autowired
    private GetListService getListService;

    @GetMapping("/user/bot/getlist/")
    public List<Bot> getlist(){
        return getListService.getList();
    }
}

2. 前端测试后端API

2.1 测试 /user/bot/add/

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

2.2 测试 /user/bot/remove/

在这里插入图片描述
删除后的结果
在这里插入图片描述

2.3 测试 /user/bot/update/

在这里插入图片描述

修改后的结果
在这里插入图片描述

2.4 测试 /user/bot/getlist/

在这里插入图片描述

在这里插入图片描述

3. 实现前端(调用后端API实现相应功能)

3.1 写前端页面展示Bot列表(API:/user/bot/getlist/)

在这里插入图片描述

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

3.2 点击创建Bot弹框添加Bot(API:/user/bot/add/)

在这里插入图片描述
按钮弹框:在这里插入图片描述
单击事件方法写ajax调用API
在这里插入图片描述

3.3 点击删除Bot(API:/user/bot/remove/)

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

在这里插入图片描述

3.4 点击修改Bot(API:/user/bot/update/)

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

在这里插入图片描述

4. 将代码区域写为编辑器

  • vue 安装依赖:vue3-ace-editor
    在这里插入图片描述

  • 代码如下:
    在这里插入图片描述
    在这里插入图片描述

    import { VAceEditor } from 'vue3-ace-editor';
    import ace from 'ace-builds';
    
    ace.config.set(
        "basePath", 
        "https://cdn.jsdelivr.net/npm/ace-builds@" + require('ace-builds').version + "/src-noconflict/")
    
    <VAceEditor
        v-model:value="botadd.content"
        @init="editorInit"
        lang="c_cpp"
        theme="textmate"
        style="height: 300px" />
    

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

    在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
创建SpringBoot项目有两种方式。一种是通过Spring官网提供的快速生成项目的网站,可以在官网下载项目后导入IDEA。另一种是直接在IDEA中创建项目。其中,SpringBoot项目创建需要有一定的Spring基础知识。 在IDEA中创建SpringBoot项目的方法如下: 1. 打开IDEA,点击"File" -> "New" -> "Project"。 2. 在弹出的窗口中,选择"Spring Initializr"。 3. 在"Project SDK"下拉菜单中选择合适的Java版本。 4. 在"Project"面板中,选择"Spring Initializr",点击"Next"。 5. 在"Spring Initializr"面板中,选择"Spring Boot"作为项目类型。 6. 在"Project Metadata"面板中,填写项目的GroupId、ArtifactId和Version信息。 7. 在"Dependencies"面板中,选择你需要的项目依赖。 8. 点击"Next",选择项目的存储路径和项目名称。 9. 点击"Finish",完成项目创建创建完成后,你可以在项目中编写代码。比如,可以创建一个Controller类进行测试。由于SpringBoot内嵌了Tomcat服务器,所以无需再去配置Tomcat。在Controller类中,可以使用@RestController注解来返回json数据,而不需要在方法前面加@ResponseBody注解。示例代码如下: ```java package com.study.helloworld.controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @RequestMapping("/hello") public String hello() { // 调用业务,接收前端参数 return "hello,world"; } } ``` 这样,你就可以在浏览器中访问"http://localhost:8080/hello",看到返回的"hello,world"了。 希望以上的解答能对你有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [如何用IDEA创建SpringBoot项目](https://blog.csdn.net/qq_53860947/article/details/124010794)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值