团队作业4:第三篇Scrum冲刺博客(歪瑞古德小队)

Author:歪瑞古德小队

Project:海岛漂流

集合贴:团队作业4:项目冲刺集合贴(歪瑞古德小队)

一、Daily Scrum Meeting

1.1 会议照片

image-20200524173829527

1.2 项目进展

团队成员 昨日完成任务 今日计划任务 遇到的困难
黄钰朝 #34统计用户发送的信件
数量,接收的信件数量
#36改进定时发信功能的实现 配置xss过滤器时发现json
格式字符串被转义之后
无法被jackson解析
黄煜淇 #37完成自定义任务的编写 #39时间胶囊模块的开发 redis无法反序列化非静态
内部类,将内部类提取出来
余圣源 #47完成消息界面和功能 #49完成头像上按钮样式修改 尝试打包安卓应用,出现
错误,至今原因未明
张文俊 #55完成海岛列表界面和功能 #56完成海岛界面和功能 配安卓环境有困难
丘丽珊 #62绘制第二天站立会议照片 #63绘制第三天站立会议照片,
一张信纸样式
难以保证工作同步的
时效性,将努力在周末
时间跟上消息更替速度;
作业好多,时间好少,
课程好多。
陈宇 #70用户删除已经创建的树洞 #71用户在树洞下留言 mybatisplus分页不太熟悉

二、项目燃尽图

05-23燃尽图

三、签入记录

3.1 代码/文档签入记录

image-20200523093923263

3.2 Code Review 记录

image-20200523094021843

image-20200523094119588

image-20200523094200242

3.3 issue内容和链接

团队成员 issue内容和链接
黄钰朝 #34统计用户发送的信件
数量,接收的信件数量
黄煜淇 #37完成自定义任务的编写
余圣源 #47完成消息界面和功能
张文俊 #55完成海岛列表界面和功能
丘丽珊 #62绘制第二天站立会议照片
陈宇 #70用户删除已经创建的树洞

四、最新模块截图

4.1 最新模块代码

(1)全局异常处理器

/**
 * @author <a href="mailto:kobe524348@gmail.com">黄钰朝</a>
 * @description 全局异常处理器
 * @date 2019-08-12 19:19
 */
@Slf4j
@RestControllerAdvice
@CrossOrigin
public class GlobalExceptionHandler implements HandlerExceptionResolver {

    @Override
    public ModelAndView resolveException(HttpServletRequest httpServletRequest,
                                         HttpServletResponse httpServletResponse,
                                         Object o, Exception e) {
        log.info("请求异常" + e.getMessage());
        e.printStackTrace();
        return null;
    }

    @ExceptionHandler(com.verygood.island.exception.bizException.BizException.class)
    public ResultBean<?> bizException(BizException e) {
        return new ResultBean<>(e);
    }

    @ExceptionHandler(org.apache.shiro.authc.AuthenticationException.class)
    public ResultBean<?> authenticationException(Exception e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException(e.getMessage()));
    }

    @ExceptionHandler(NullPointerException.class)
    public ResultBean<?> nullPointerException(NullPointerException e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("错误!参数不匹配"));
    }

    @ExceptionHandler({com.alibaba.druid.pool.GetConnectionTimeoutException.class})
    public ResultBean<?> dataBaseException(Exception e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("服务器访问人数过多,请稍后重试"));
    }


    @ExceptionHandler(
            org.springframework.web.multipart.MaxUploadSizeExceededException.class)
    public ResultBean<?> maxUploadexception(
            org.springframework.web.multipart.MaxUploadSizeExceededException e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("您上传的文件大小超过限制"));
    }

    @ExceptionHandler(Throwable.class)
    public ResultBean<?> unknownException(Throwable e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("发生了未知的异常,请告知程序员哥哥前来修复"));
    }

    @ExceptionHandler(
            {org.springframework.web.method.annotation.MethodArgumentTypeMismatchException.class,
                    org.springframework.http.converter.HttpMessageNotReadableException.class,
                    org.springframework.web.bind.MissingServletRequestParameterException.class})
    public ResultBean<?> http400Handler(Exception e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("您的请求错误,缺少请求体或格式错误"));
    }

    @ExceptionHandler(
            org.springframework.web.HttpRequestMethodNotSupportedException.class)
    public ResultBean<?> http405Handler(
            org.springframework.web.HttpRequestMethodNotSupportedException e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("服务器并不支持您所使用的请求方法"));
    }

    @ExceptionHandler(
            org.springframework.web.HttpMediaTypeNotSupportedException.class)
    public ResultBean<?> http405Handler(
            org.springframework.web.HttpMediaTypeNotSupportedException e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("您的请求体格式不正确"));
    }


    @ExceptionHandler(IllegalStateException.class)
    public ResultBean<?> http500Handler(IllegalStateException e) {
        e.printStackTrace();
        return new ResultBean<>(new BizException("您的请求体格式不正确"));
    }

}

(2)定时任务

/**
 * @author huange7
 */
@Slf4j
public class CapsuleSendingTask implements Runnable {

    /**
     * 存储时间胶囊
     */
    private final Letter letter;

    public CapsuleSendingTask() {
        letter = new Letter();
    }

    /**
     * 构造器
     *
     * @param letter 发送的信件
     */
    public CapsuleSendingTask(Letter letter) {
        this.letter = letter;
    }

    @Override
    public void run() {
        // 时间胶囊数量减1
        reduceCapsule();

        LetterServiceImpl letterService = BeanUtils.getBean(LetterServiceImpl.class);
        letter.setReceiveTime(LocalDateTime.now());

        if (letterService.updateById(letter)) {
            log.info("发送id为{}的letter成功,接收时间:{}", letter.getLetterId(), letter.getReceiveTime());
            //发送通知
            this.sendNotice();
        } else {
            log.error("发送id为{}的letter失败", letter.getLetterId());
            throw new BizException("发送失败[id=" + letter.getLetterId() + "]");
        }
    }

    /**
     * 发送通知
     */
    private void sendNotice() {
        Notice notice = new Notice();
        NoticeMapper noticeMapper = BeanUtils.getBean(NoticeMapper.class);
        notice.setTitle("时间胶囊通知");
        String content = "你收到一个来自自己的时间胶囊,快去查收吧!";
        notice.setContent(content);
        notice.setUserId(letter.getReceiverId());
        noticeMapper.insert(notice);
        log.info("发送notice成功,内容为{}", content);
    }

    /**
     * 减去对应的时间胶囊
     */
    private void reduceCapsule() {
        UserMapper userMapper = BeanUtils.getBean(UserMapper.class);
        User user = userMapper.selectById(letter.getSenderId());
        if (user == null) {
            log.info("减去时间胶囊时发送错误!不存在该用户");
            return;
        }
        if (user.getCapsule() <= 0) {
            log.info("减去时间胶囊时发送错误!胶囊数量不足");
            return;
        }
        user.setCapsule(user.getCapsule() - 1);
        userMapper.updateById(user);
    }

    @Override
    public String toString() {
        return "CapsuleSendingTask{" +
                "letter=" + letter +
                '}';
    }
}

(3)删除树洞

@Override
public int deleteTreeHoleById(int id,Integer userId) {
        log.info("正在删除id为{}的treeHole", id);
        if(!userId.equals(treeHoleMapper.getUserIdByTreeId(id))){
            log.error("更新id为{}的treeHole失败,登录用户与树洞拥有用户不同",id);
            throw new BizException("登录用户与树洞拥有用户不同");
        }
        if (super.removeById(id)) {
            log.info("删除id为{}的treeHole成功", id);
            return id;
        } else {
            log.error("删除id为{}的treeHole失败", id);
            throw new BizException("删除失败[id=" + id + "]");
        }
}

4.2 程序运行截图

image-20200523093701486image-20200523175631562

五、每日总结

团队成员 总结内容
黄钰朝 加深了对于springboot中filter,wrapper以及exceptionHandler的使用
黄煜淇 redis反序列化时需要注意补充无参构造方法
余圣源 以后尽量避免跨平台开发复杂应用
张文俊 下次要找个网络好的地方下载
丘丽珊 我不知道画个图有啥总结...
陈宇 学习mybatisplus的分页
posted @ 2020-05-23 17:58  Yuchao_Huang  阅读(278)  评论(0编辑  收藏  举报