springboot搭建一个后台管理(二):最基础的CRUD测试

本文详细介绍如何使用SpringBoot进行增删改查(CRUD)操作,包括创建必要的包结构,自定义JSONResult类以统一响应格式,以及在Service和Controller中实现具体的方法。并通过Postman测试接口,验证操作的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  上一篇我已经写了基于springboot来搭建的基础:https://blog.youkuaiyun.com/LiLrui/article/details/87916534。第二篇就来写下CRUD操作。

  首先需要创建基本的几个包:dao,model,mapper,这些之前generator已经帮我们生成好了。所以还需要再手动创建service,controller,utils,common几个需要的包,大体先用到这些,另外的以后再补上

首先我需要一个统一格式的自定义jsonresult类,这个类帮助我们将所有数据已统一格式的形式返回出去,前端也会经常用到。

/**
 * Created by Lilrui.
 */
@Data
@Slf4j
public class JsonResult {
    private boolean ret;

    private String msg;

    private Object data;

    public JsonResult(boolean ret,String msg) {
        this.ret = ret;
        this.msg=msg;
    }

    public static JsonResult success(Object object, String msg) {
        JsonResult JsonResult = new JsonResult(true,msg);
        JsonResult.data = object;
        return JsonResult;
    }

    public static JsonResult success(Object object) {
        JsonResult JsonResult = new JsonResult(true,"success");
        JsonResult.data = object;
        return JsonResult;
    }

    public static JsonResult success() {
        return new JsonResult(true,"success");
    }

    public static JsonResult fail(String msg) {
        JsonResult JsonResult = new JsonResult(false,msg);
        return JsonResult;
    }

    
}

然后暂时在service包里 写一个test测试类:

@Service
public class TestService implements SysUserMapper{
    @Resource
    private SysUserMapper sysUserMapper;


    @Override
    @Transactional(propagation = Propagation.REQUIRED)
    public int deleteByPrimaryKey(Integer id) {
        return sysUserMapper.deleteByPrimaryKey(id);
    }

    @Override
    @Transactional(propagation = Propagation.REQUIRED)
    public int insert(SysUser user) {
        return sysUserMapper.insert(user);
    }

    @Override
    @Transactional(propagation = Propagation.REQUIRED)
    public int insertSelective(SysUser user) {
        return sysUserMapper.insert(user);
    }

    @Override
    @Transactional(propagation = Propagation.SUPPORTS)
    public SysUser selectByPrimaryKey(Integer id) {
        return sysUserMapper.selectByPrimaryKey(id);
    }

    @Override
    @Transactional(propagation = Propagation.REQUIRED)
    public int updateByPrimaryKeySelective(SysUser record) {
        return sysUserMapper.updateByPrimaryKeySelective(record);
    }

    @Override
    @Transactional(propagation = Propagation.REQUIRED)
    public int updateByPrimaryKey(SysUser record) {
        return sysUserMapper.updateByPrimaryKey(record);
    }

    @Override
    @Transactional(propagation = Propagation.SUPPORTS)
    public List<SysUser> selectAll() {
       return sysUserMapper.selectAll();
    }
}

在controller包下写测试接口:

/**
 * Created by Lilrui.
 */
@RestController
@RequestMapping("/Test")
@Slf4j
public class TestController {

    private final TestService testService;

    public TestController(TestService testService) {
        this.testService=testService;
    }

    @GetMapping("/findAll")
    public JsonResult getAll() {
        return JsonResult.success(testService.selectAll());
    }

    @PostMapping("/insert")
    public JsonResult insert(SysUser user){
        return JsonResult.success(testService.insertSelective(user));
    }

    @PostMapping("/update")
    public JsonResult update(SysUser user) {

        log.info("改动之前:{}",testService.selectByPrimaryKey(5));

        testService.updateByPrimaryKeySelective(user);

        log.info("改动之后:{}",testService.selectByPrimaryKey(5));

        return JsonResult.success(testService.selectByPrimaryKey(5));
    }

    @PostMapping("/del")
    public JsonResult delete(@Param(value = "id") Integer id){
        testService.deleteByPrimaryKey(id);
        return JsonResult.success();
    }
}

因为只是测试下crud是否可以正常执行,所以就写简单点,接下来启动项目,然后用postman来进行测试:

查询操作是正常的,然后在测试添加,修改操作:

没有问题,已经成功回应了,看下数据库是否有这条字段:

注意,如果插入报错的话,很可能是时间字段报错,需要解析一下就可以,在对象字段上增加:

@DateTimeFormat(pattern="yyyy-MM-dd")
private Date operateTime;

然后修改下刚才插入的记录,它的id是6,我们改个名字试试

也没有问题,最后测试下删除刚才插入的记录

以上的CRUD操作测试全部都没有问题,那么接下来就可以继续写后续的代码了,第三篇会写全局异常处理,Validator字段校验,以及AOP切面的编写。包括后台项目可能用到的工具类编写。

核心功能 文章/图片/视频发布、喜欢、统计阅读次数。 文章标签tag功能、支持按tag分 文章支持ueditor/markdown编辑器切换(后台配置) 评论功能,支持回复,支持表情。 第三方(微博、QQ)登录。 lucene实现的站内搜索。 响应式布局 支持用户订阅 先看效果图 SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能) http://localhost:8080/admin/group/list SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能)SpringBoot开发非常美观的java博客系统(包含后台管理功能) 技术选型: JDK8 数据库MySQL 主框架 (Spring-bootSpring-data-jpa) 安全权限 Shiro 搜索工具 Lucene 缓存 Ehcache 视图模板 Freemarker 其它 Jsoup、fastjson jQuery、Seajs Bootstrap 前端框架 UEditor/Markdown编辑器 font-Awesome 字体/图标 准备工作(sql文件在项目里面) 安装 Jdk8 安装 Maven 准备 IDE (如果你不看源码,可以忽略下面的步骤,直接通过Maven编译war包:mvn clean package -DskipTests) IDE 需要配置的东西 编码方式设为UTF-8 配置Maven 设置Jdk8 关于这些配置,网上有一大把的资料,所以此处不再重复。 获取代码导入到IDE 下载代码 导入到IDE的时候请选择以Maven的方式导入 项目配置参考 系统配置手册 配置完毕 启动项目,在控制台看到Mblog加载完毕的信息后,表示启动成功 打开浏览器输入:http//localhost/mblog/ (此处仅是示例,具体具体端口因人而异),访问成功即部署完毕 后台管理的地址是 /admin, 如果你是管理员账号点导航栏的头像会看到"后台管理" 启动成功后,你应该去后台的系统配置里配置你的网站信息等。 常见问题总结 进入系统后, 菜单加载不出来, 那应该是你没有导 db_init.sql 点标签显示乱码, 请设置Tomcat的 URIEncoding 为 UTF-8 项目截图 SpringBoot开发非常美观的java博客系统(包含后台管理功能) 转自:https://gitee.com/mtons/mblog SpringBoot开发非常美观的java博客系统(包含后台管理功能) 注意: 一、java main方式运行mblog-web下的BootApplication.java时抛出异常的解决方案 Unable to start EmbeddedWebApplicationContext due to missing EmbeddedServletContainerFactory bean. SpringBoot开发非常美观的java博客系统(包含后台管理功能) 注释掉后下面图片的这段后,记得maven要重新reimport SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能) 否则maven依赖不生效还是会抛出以上的异常 、第三方登录点击后无响应,那是因为第三方开放平台回调的url失效导致,需要你去对应的第三方开放平台注册app后获取对应的oauth帐号 SpringBoot开发非常美观的java博客系统(包含后台管理功能) 三、idea以maven项目导入该项目后,发现没有maven的依赖包时,需要对每个maven module进行clear和install,并且注意maven的依赖顺序 SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能) 四、访问地址是http://localhost:8080 登录时,帐号,密码只要自己找个密码,然后md5下在更新到db中即可登录成功。 比如:zuidaima 111111,md5后密码是 3931MUEQD1939MQMLM4AISPVNE,md5的java SpringBoot开发非常美观的java博客系统(包含后台管理功能) SpringBoot开发非常美观的java博客系统(包含后台管理功能)
## 平台简介 可以用于所有的Web应用程序,如网站管理后台,网站会员中心,CMS,CRM,OA。所有前端后台代码封装过后十分精简易上手,出错概率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。 诺寒基于hplus和inspinia两套后台系统模板开发。 http://www.zi-han.net/theme/hplus http://webapplayers.com/inspinia_admin-v2.7.1 ## 内置功能 1. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。 2. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现。 3. 岗位管理:配置系统用户所属担任职务。 4. 菜单管理:配置系统菜单,操作权限,按钮权限标识等。 5. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。 6. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。 7. 参数管理:对系统动态配置常用参数。 8. 通知公告:系统通知公告信息发布维护。 9. 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。 10. 登录日志:系统登录日志记录查询包含登录异常。 11. 在线用户:当前系统中活跃用户状态监控。 12. 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。 13. 代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 14. 系统接口:根据业务代码自动生成相关的api接口文档。 15. 在线构建器:拖动表单元素生成相应的HTML代码。 16. 连接池监视:监视当期系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值