基于javaweb+mysql的springboot在线电子书小说阅读系统(java+layui+springboot+maven+mysql+html)

基于javaweb+mysql的springboot在线电子书小说阅读系统(java+layui+springboot+maven+mysql+html)

私信源码获取及调试交流

运行环境

Java≥8、MySQL≥5.7

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的SpringBoot在线电子书小说阅读系统(java+layui+springboot+maven+mysql+html)

一、项目介绍 环境配置:

Jdk1.8 + Tomcat8.5 + mysql + Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)

项目技术:

Layui+Springboot+ SpringMVC + HTML + FTP+ JavaScript + JQuery + Ajax + maven等等。

        // ipAddress = this.getRequest().getRemoteAddr();

        return ipAddress;
    }
}

/**
 */
@RequestMapping("/after/type")
@RestController
public class AfTypeController {

    @Resource
    AfTypeService afTypeService;

    @PostMapping("/addType")
    public Result addType(String cate) {
        if (afTypeService.showByType(cate) == null){
            return Result.success(200,"添加成功",0,afTypeService.addType(cate));
        }
        return Result.success(200,"该分类已存在,请添加新分类",0,0);
    }

    @PostMapping("/showAll")
    public Result showAll() {
        return Result.success(Result.SUCCESS, afTypeService.showAll().size(),afTypeService.showAll());
    }

    @GetMapping("/updateById")
    public Result updateById(@RequestBody TypePO type) {
        return Result.success(afTypeService.updateById(type));
    }

    @PostMapping("/deleteById")
    public Result deleteById(Integer tId) {
     */
    @PostMapping("/deleteById")
    public Result deleteById(Integer bId, Integer status) {
        if (status == 1) {
            return Result.success(200, "下架成功", 200, afBookService.deleteById(bId, 0));
        }
        return Result.success(200, "上架成功", 200, afBookService.deleteById(bId, 1));
    }

    /**
     * detail: 编辑书籍
     *
     * @param book
     * @return int
     */
    @PostMapping("/updateOne")
    public Result updateOne(@RequestBody BookPO book) {
        return Result.success(afBookService.updateOne(book));
    }

    /**
     * detail: 添加章节内容
     *
     * @param chapter
     * @return int
     */
    @PostMapping("/addChap")
    public Result addChap(ChapterPO chapter){
        //获取一个当前时间,精确到毫秒,确保添加时间不会重,为后面客户端页面排序做准备
        //创建一个date对象保存当前时间
        // Date date = new Date();
        // SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
        //format()方法将Date转换成指定格式的String
        // String dateStr = simpleDateFormat.format(date);
        chapter.setETime(DateUtils.getCurrentTime());
        Integer bId = chapter.getBId();
        afBookService.updateByBId(bId,DateUtils.getCurrentTime());
        afBookService.deleteById(bId,1);
        return Result.success(afBookService.addChap(chapter));
    }

    /**
     * detail: 根据小说bId查询小说的所有条数,进而得出下一章的数字
     *
                return Result.success(Result.SUCCESS,res);
            }else {
                return Result.success(Result.NULL, null);
            }
        } catch (Exception e) {
            log.print(e);
            return Result.error(Result.COLLAPSE, String.valueOf(e));
        }
    }

}

/**
 */
@RequestMapping("/front/login")
@RestController
public class FrLoginController {

    @Resource
    FrLoginService frLoginService;

    /**
     * 注册用户
     */
    @PostMapping("/addOne")
    public Result addOne(UserPO user){
        return Result.success(frLoginService.addOne(user));
    }

    /**
    }

    @GetMapping("/deleteBanner")
    public Result deleteBanner(@RequestParam("baId")Integer baId) {
        return Result.success(afBannerService.deleteBanner(baId));
    }

}

/**
 */

@RequestMapping("/after/admin")
@RestController
public class AfAdminController {

    @Resource
    private AfAdminService afAdminService;

    /**
     *  登录验证
     */
    @PostMapping(value = "/login")
    public Result login(@RequestBody AdminPO admin, HttpServletRequest request){
        AdminPO res = afAdminService.showOne(admin);
        HttpSession session = request.getSession();
        if (res != null){
            session.setAttribute("admin",res);
        }
        return Result.success(res);
    }

    /**
     * detail: 批量注销用户
     * @param uIds
     * @return int
     */
    @PostMapping("/deleteByIds")
    Result deleteByIds(Integer[] uIds){
        return Result.success(afUserService.deleteByIds(uIds));
    }

    /**
     * detail: 验证用户,账号和密码
     * @param uAccount
     * @param uPassword
     * @return int
     */
    @GetMapping("/showOne")
    Result showOne(String uAccount,String uPassword){
        return Result.success(afUserService.showOne(uAccount,uPassword));
    }

    /**
     * detail: 修改密码操作:
     *           第一步,showOne,验证通过后,才可以修改密码
     *           第二步,根据已登录的用户名修改密码
     * @param uPassword
     * @param uAccount
     * @return int
     */
    @GetMapping("/updateByUAccount")
    Result updateByUAccount(String uPassword,String uAccount){
        return Result.success(afUserService.updateByUAccount(uPassword,uAccount));
    }

    /**
     * detail: 通过账号查询
     * @param uAccount
     * @return int
     */
    @GetMapping("/showByUAccount")
    Result showByUAccount(String uAccount){
        return Result.success(afUserService.showByUAccount(uAccount));
    }

    @GetMapping("/updateById")
    public Result updateById(@RequestBody TypePO type) {
        return Result.success(afTypeService.updateById(type));
    }

    @PostMapping("/deleteById")
    public Result deleteById(Integer tId) {
        return Result.success(afTypeService.deleteById(tId));
    }

}

/**
 * @Description:
 */
@RestController
@RequestMapping("/common")
public class commonController {

    @Autowired
    private ToolsUtils toolsUtils;

    /**
     * 上传图片
     */
    @PostMapping("/uploadPic")
    public Result uploadPic(MultipartFile file, @RequestParam("type_img")Integer typeImg) {
        try {
            String res = toolsUtils.uploadImg(file,typeImg);
            if (!"".equals(res) && res != null) {
                return Result.success(Result.SUCCESS,res);
     * @param uPassword
     * @param uAccount
     * @return int
     */
    @GetMapping("/updateByUAccount")
    Result updateByUAccount(String uPassword,String uAccount){
        return Result.success(afUserService.updateByUAccount(uPassword,uAccount));
    }

    /**
     * detail: 通过账号查询
     * @param uAccount
     * @return int
     */
    @GetMapping("/showByUAccount")
    Result showByUAccount(String uAccount){
        return Result.success(afUserService.showByUAccount(uAccount));
    }

    /**
     * detail: 添加用户
     * @param user
     * @return int
     */
    @PostMapping("/addOne")
    Result addOne(@RequestBody UserPO user){
        return Result.success(afUserService.addOne(user));
    }

    /**
     * detail: 编辑用户基本信息
     * @param user
     * @return int
     */
    @PostMapping("/updateById")
    Result updateById(@RequestBody UserPO user){
        return Result.success(afUserService.updateById(user));
    }
}

    private AfBookServiceImpl afBookService;

    @GetMapping("/getBannerList")
    public Result getBannerList(Integer page, Integer limit) {
        if ( page == null) {
            return Result.error(0,"没有页数");
        }
        Integer pages = (page - 1) * limit;
        List<BannerDTO> list = afBannerService.getBannerList(pages, limit);
        Integer count = afBannerService.getBannerListCount();
        for (int i = 0; i < list.size(); i++) {
            list.get(i).setBaPicture(ToolsUtils.getImgPath(list.get(i).getBaPicture()));
        }
        return Result.success(Result.SUCCESS, count, list);
    }

    @PostMapping("/addBanner")
    public Result addBanner(@RequestBody BannerDTO bannerDTO ) {
        BookPO book = afBookService.showByBTitle(bannerDTO.getBTitle());
        BannerPO banner = new BannerPO();
        banner.setBaId(bannerDTO.getBaId());
        banner.setBaLevel(bannerDTO.getBaLevel());
        banner.setBaPicture(bannerDTO.getBaPicture());
        banner.setBId(book.getBId());
        banner.setStartDt(bannerDTO.getStartDt());
        banner.setEndDt(bannerDTO.getEndDt());
        return Result.success(afBannerService.addBanner(banner));
    }

    @PostMapping("/updateBanner")
    public Result updateBanner(@RequestBody BannerPO banner) {
        return Result.success(afBannerService.updateBanner(banner));
    }

    @GetMapping("/deleteBanner")
    public Result deleteBanner(@RequestParam("baId")Integer baId) {
        return Result.success(afBannerService.deleteBanner(baId));
    }

}

        List<BookChapterDTO> lastBook = frIndexService.showLastUpdateBook(lastBookNum);
        Map<String,List> map = new HashMap<>();
        map.put("types",types);
        map.put("banners",banners);
        map.put("hotRec",hotRec);
        map.put("lastChapter",lastChapter);
        map.put("lastBook",lastBook);
        return Result.success(map);
    }

    /**
     * type页面的所有数据
     * @return map
     * @param cate 类型
     * @param lastNnm 最近更新章节的条数
     */
    @GetMapping("/frType")
    public Result frType(Integer lastNnm, String cate){
        List<TypePO> types = frIndexService.showTypeAll();
        List<BookPO> hotRec = frIndexService.showByHotRec(cate);
        for (BookPO bookPO : hotRec) {
            bookPO.setBPicture(ToolsUtils.getImgPath(bookPO.getBPicture()));
        }
        List<BookChapterDTO> lastChapter = frIndexService.showLastUpdate(lastNnm,cate);
        Map<String,List> map = new HashMap<>();
        map.put("types",types);
        map.put("hotRec",hotRec);
        map.put("lastChapter",lastChapter);
        return Result.success(map);
    }

    /**
     * details页面的所有数据
     * @return map
     * @param  bId
     */
    @GetMapping("/frDetail")
    public Result frDetail(Integer bId){
        List<TypePO> types = frIndexService.showTypeAll();
        BookPO book = frDetailsService.showBookByBId(bId);
        book.setBPicture(ToolsUtils.getImgPath(book.getBPicture()));
        List<BookPO> list = new ArrayList<>();
        list.add(book);
        List<ChapterPO> chapters = frDetailsService.showChapterByBId(bId);
        Map<String,List> map = new HashMap<>();
        map.put("types",types);
        map.put("book",list);
        map.put("chapters", chapters);
        return Result.success(map);
    }

}

/**
 */
@RequestMapping("/after/type")
@RestController
public class AfTypeController {

    @Resource
    AfTypeService afTypeService;

    @PostMapping("/addType")
    public Result addType(String cate) {
        if (afTypeService.showByType(cate) == null){
            return Result.success(200,"添加成功",0,afTypeService.addType(cate));
        }
        return Result.success(200,"该分类已存在,请添加新分类",0,0);
    }

    @PostMapping("/showAll")
    public Result showAll() {
        return Result.success(Result.SUCCESS, afTypeService.showAll().size(),afTypeService.showAll());
    }

    @GetMapping("/updateById")
    public Result updateById(@RequestBody TypePO type) {
        return Result.success(afTypeService.updateById(type));
    }

    @PostMapping("/deleteById")
    public Result deleteById(Integer tId) {
        return Result.success(afTypeService.deleteById(tId));
    }

}
 */
@Aspect
@Component
public class HttpAspect {

    private static long startTime;
    private static long endTime;

    private static final Logger log = LoggerFactory.getLogger(zl.readCloud.aop.HttpAspect.class);

    /**
     * 切点表达式
     */
    @Pointcut("execution(public * zl.readCloud.controller..*.*(..))")

    /**
     * 切点签名
     */
    public void print() {

    }

    /**
     * @Before注解表示在具体的方法之前执行
     * @param joinPoint
     */
    @Before("print()")
    public void before(JoinPoint joinPoint) {
        startTime = System.currentTimeMillis();
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = requestAttributes.getRequest();
        String requestURI = request.getRequestURI();
        String remoteAddr = "127.0.0.1";
        String requestMethod = request.getMethod();
        String declaringTypeNamepeName = joinPoint.getSignature().getDeclaringTypeName();
        String methodName = joinPoint.getSignature().getName();
        Object[] args = joinPoint.getArgs();
        log.info("请求url:=" + requestURI + ",客户端ip:=" + remoteAddr + ",请求方式:=" + requestMethod + ",请求的类名:=" + declaringTypeNamepeName + ",方法名:=" + methodName);
    }

    /**
     * @After注解表示在方法执行之后执行
     */
    @After("print()")
    public void after() {
        endTime = System.currentTimeMillis() - startTime;
    }

    /**
     * @AfterReturning注解用于获取方法的返回值

/**
 * @Description:
 */
@RestController
@RequestMapping("/common")
public class commonController {

    @Autowired
    private ToolsUtils toolsUtils;

    /**
     * 上传图片
     */
    @PostMapping("/uploadPic")
    public Result uploadPic(MultipartFile file, @RequestParam("type_img")Integer typeImg) {
        try {
            String res = toolsUtils.uploadImg(file,typeImg);
            if (!"".equals(res) && res != null) {
                return Result.success(Result.SUCCESS,res);
            }else {
                return Result.success(Result.NULL, null);
            }
        } catch (Exception e) {
            log.print(e);
            return Result.error(Result.COLLAPSE, String.valueOf(e));
        }
    }

}

/**
 */
@RequestMapping("/front/login")
            Integer count = afBookService.showAllItem().size();
            return Result.success(Result.SUCCESS, count, list);
        }
        List<BookPO> list = afBookService.showScreen(book);
        for (int i = 0; i < list.size(); i++) {
            list.get(i).setBPicture(ToolsUtils.getImgPath(list.get(i).getBPicture()));
        }
        LoggerFactory.getLogger(AfBookController.class).info(list.toString());
        return Result.success(list);
    }

    /**
     * detail: 添加书籍
     */
    @PostMapping("/addOne")
    public Result addOne(@RequestBody BookPO book) {
        // 获取一个当前时间,精确到毫秒,确保添加时间不会重,为后面客户端页面排序做准备
        Date date = new Date();
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
        String dateStr = simpleDateFormat.format(date);
        book.setUpdateTime(dateStr);
        if (book.getBPicture() == null || book.getBPicture() == "") {
            book.setBPicture(ToolsUtils.DEFAULT_IMG);
        }
        return Result.success(afBookService.addOne(book));
    }

    /**
     * detail: 删除书籍,改变状态
     *
     * @param bId
     * @return int
     */
    @PostMapping("/deleteById")
    public Result deleteById(Integer bId, Integer status) {
        if (status == 1) {
            return Result.success(200, "下架成功", 200, afBookService.deleteById(bId, 0));
        }
        return Result.success(200, "上架成功", 200, afBookService.deleteById(bId, 1));
    }

    /**
        List<TypePO> types = frIndexService.showTypeAll();
        List<BookPO> books = frIndexService.showBTitleByLike(bTitle);
        if (books.size() == 0) {

        }
        Map<String,List> map = new HashMap<>();
        map.put("types",types);
        map.put("books",books);
        return Result.success(map);
    }

    /**
     * index页面的所有数据
     * @return map
     * @param lastNnm 最近更新章节的条数
     * @param lastBookNum 最近上架书籍的条数
     */
    @GetMapping("/frIndex")
    public Result frIndex(Integer lastNnm, Integer lastBookNum){
        Date time = new Date();
        SimpleDateFormat sdf = new  SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String nowDate = sdf.format(time);
        List<TypePO> types = frIndexService.showTypeAll();
        List<BannerPO> banners = frIndexService.getBannerList2(nowDate);
        for (BannerPO banner : banners) {
            banner.setBaPicture(ToolsUtils.getImgPath(banner.getBaPicture()));
        }
        List<BookPO> hotRec = frIndexService.showByHotRec(null);
        for (BookPO book : hotRec) {
            book.setBPicture(ToolsUtils.getImgPath(book.getBPicture()) );
        }
        List<BookChapterDTO> lastChapter = frIndexService.showLastUpdate(lastNnm,null);
        List<BookChapterDTO> lastBook = frIndexService.showLastUpdateBook(lastBookNum);
        Map<String,List> map = new HashMap<>();
        map.put("types",types);
        map.put("banners",banners);
        map.put("hotRec",hotRec);
        map.put("lastChapter",lastChapter);
        map.put("lastBook",lastBook);
        return Result.success(map);
    }

    /**
     * type页面的所有数据
    }

    /**
     * detail: 编辑用户基本信息
     * @param user
     * @return int
     */
    @PostMapping("/updateById")
    Result updateById(@RequestBody UserPO user){
        return Result.success(afUserService.updateById(user));
    }
}

/**
 * 通过aop拦截请求 记录运行信息
 *
 */
@Aspect
@Component
public class HttpAspect {

    private static long startTime;
    private static long endTime;

    private static final Logger log = LoggerFactory.getLogger(zl.readCloud.aop.HttpAspect.class);

    /**
     * detail: 编辑用户基本信息
     * @param user
     * @return int
     */
    @PostMapping("/updateById")
    Result updateById(@RequestBody UserPO user){
        return Result.success(afUserService.updateById(user));
    }
}

/**
 * 通过aop拦截请求 记录运行信息
 *
 */
@Aspect
@Component
public class HttpAspect {

    private static long startTime;
    private static long endTime;

    private static final Logger log = LoggerFactory.getLogger(zl.readCloud.aop.HttpAspect.class);

    /**
     * 切点表达式
     */
    @Pointcut("execution(public * zl.readCloud.controller..*.*(..))")

    /**
     * 切点签名
     */
    public void print() {

    }

    /**

/**
 * 通过aop拦截请求 记录运行信息
 *
 */
@Aspect
@Component
public class HttpAspect {

    private static long startTime;
    private static long endTime;

    private static final Logger log = LoggerFactory.getLogger(zl.readCloud.aop.HttpAspect.class);

    /**
     * 切点表达式
     */
    @Pointcut("execution(public * zl.readCloud.controller..*.*(..))")

    /**
     * 切点签名
     */
    public void print() {

    }

    /**
     * @Before注解表示在具体的方法之前执行
     * @param joinPoint
     */
    @Before("print()")
    public void before(JoinPoint joinPoint) {
        startTime = System.currentTimeMillis();
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = requestAttributes.getRequest();
        String requestURI = request.getRequestURI();
        String remoteAddr = "127.0.0.1";
        String requestMethod = request.getMethod();
        String declaringTypeNamepeName = joinPoint.getSignature().getDeclaringTypeName();
        String methodName = joinPoint.getSignature().getName();
        Object[] args = joinPoint.getArgs();
        log.info("请求url:=" + requestURI + ",客户端ip:=" + remoteAddr + ",请求方式:=" + requestMethod + ",请求的类名:=" + declaringTypeNamepeName + ",方法名:=" + methodName);
    }

    /**
        HttpSession session = request.getSession();
        if (res != null){
            session.setAttribute("admin",res);
        }
        return Result.success(res);
    }

    @GetMapping("/showAA")
    public Result showAA(String password,String account){
        AdminPO admin = new AdminPO();
        admin.setPassword(password);
        admin.setAccount(account);
        return Result.success(afAdminService.showOne(admin));
    }

    /**
     *  旧密码通过验证后,修改密码
     */
    @GetMapping("/updateByUAccount")
    Result updateByUAccount(String password,String account){
        return Result.success(afAdminService.updateByUAccount(password,account));
    }

    /**
     *  查询所有的管理员
     */
    @PostMapping(value = "/showAll")
    public Result showAll(){
        return Result.success(Result.SUCCESS,afAdminService.showAll().size(),afAdminService.showAll());
    }

    /**
     * 删除管理员
     */
    @PostMapping(value = "/deleteByAccount")
    public Result deleteByAccount(String account){
        return Result.success(afAdminService.deleteByAccount(account));
    }

    /**
     * 添加管理员
     */

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
运动健康管理系统技术概述 运动健康管理系统是一款基于SpringBootMavenMySQL、JDK1.8等技术栈的Web应用程序。作为一款面向健康人群的应用,其主要功能包括用户信息管理、运动计划管理、运动数据记录以及运动报表展示等几个方面。 技术架构 整个应用主要采用的技术栈包括后端技术和数据库技术两部分,具体如下: 后端技术: 1. SpringBoot:基于SpringBoot框架进行开发,提供了快速开发、便捷集成等优点,使得开发人员可以更加轻松地搭建JavaWeb应用。 2. Maven:采用Maven作为项目构建工具,方便管理项目中的依赖关系,并能统一管理版本等信息。 3. MySQL:采用MySQL数据库进行数据存储,能够支持大量的数据处理,同时也具有较好的性能表现。 4. JDK1.8:使用Java语言开发,采用JDK1.8版本,具有较好的兼容性和可扩展性。 数据库技术: 1. MySQL:作为主要的关系型数据库,MySQL具有广泛的应用场景,支持高并发操作和大量数据存储等特性。 2. MyBatis:采用MyBatis作为ORM框架,将Java对象和数据库之间的映射关系进行处理,能够方便地完成数据持久化操作。 3. Druid:作为连接池技术的代表,Druid能够管理连接、监控访问情况,优化数据库性能。 应用功能 运动健康管理系统主要包括以下几个方面的功能: 1. 用户管理:注册、登录、个人信息修改等操作,支持OAuth2.0协议。 2. 运动计划管理:支持用户创建、修改、删除运动计划。 3. 运动数据记录:支持用户通过APP或手表等设备上传运动数据到系统中。 4. 运动报表展示:根据用户上传的数据生成运动报表,帮助用户分析运动情况。 总结 以上就是运动健康管理系统的相关技术概述,这些技术的运用使得应用具有更好的稳定性、可扩展性和性能表现。希望能对需要开发该领域应用的同学提供帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值