基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)

博主介绍: ✌全网粉丝30W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌
文末获取源码联系
精彩专栏 推荐订阅 不然下次找不到哟
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》

系统介绍:

互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对乡镇自来水收费信息管理混乱,出错率高,信息安全性差,劳动强度大,费时费力等问题,采用乡镇自来水收费系统可以有效管理,使信息管理能够更加科学和规范。

乡镇自来水收费系统在Eclipse环境中,使用Java语言进行编码,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,其管理员管理水表,审核用户更换水表的请求,管理用户水费,包括抄表以及水费缴费,管理公告,管理留言和用户信息。用户可以申请更换水表,可以完成水费缴费,公告查看,留言发布以及个人信息更改等操作。

总之,乡镇自来水收费系统集中管理信息,有着保密性强,效率高,存储空间大,成本低等诸多优点。它可以降低信息管理成本,实现信息管理计算机化。

在前面分析的管理员功能的基础上,进行接下来的设计工作,最终展示设计的管理员结构图(见下图)。管理员管理水表,审核用户更换水表的请求,管理用户水费,包括抄表以及水费缴费,管理公告,管理留言和用户信息。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第1张图片

图 管理员功能结构图

在前面分析的用户功能的基础上,进行接下来的设计工作,最终展示设计的用户结构图(见下图)。用户可以申请更换水表,可以完成水费缴费,公告查看,留言发布以及个人信息更改等操作。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第2张图片

图 用户功能结构图

功能截图:

5.1.1 水费管理

管理员进入指定功能操作区之后可以管理水费信息。其页面见下图。管理员可以查看各个用户的水费信息,完成用户水表抄表,完成用户水费的线上缴费操作。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第3张图片

图5.1 水费管理页面

5.1.2 水表信息

管理员进入指定功能操作区之后可以处理水表信息。其页面见下图。管理员添加水表,批量删除或针对性删除水表信息,修改水表信息。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第4张图片

图5.2 水表信息页面

5.1.3 水表更换信息

管理员进入指定功能操作区之后可以查看用户申请更换的水表信息。其页面见下图。管理员在本页面可以选择同意更换水表或取消用户更换水表的请求。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第5张图片

图5.3 水表更换信息页面

5.1.4 用户管理

管理员进入指定功能操作区之后可以管理用户。其页面见下图。本功能就是为了方便管理员增加用户,修改用户,批量删除用户而设置的。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第6张图片

图5.4 用户管理页面

5.1.5 留言管理

管理员进入指定功能操作区之后可以管理留言。其页面见下图。管理员批量删除留言,回答用户的留言。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第7张图片

图5.5 留言管理页面

5.2 用户功能实现

5.2.1 在线留言

用户进入指定功能操作区之后可以发布留言。其页面见下图。用户直接提交留言即可,管理员会及时接收到用户的留言。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第8张图片

图5.6 在线留言页面

5.2.2 在线缴费

用户进入指定功能操作区之后可以查看水费并缴费。其页面见下图。用户点击缴费即可完成对应水费的缴费操作。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第9张图片

图5.7 在线缴费页面

5.2.3 更换水表

用户进入指定功能操作区之后可以更换水表。其页面见下图。当用户提交了水表更换信息之后,在管理员未审核前,用户可以自行取消更换水表的请求。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第10张图片

图5.8 更换水表页面

5.2.4 查看公告

用户进入指定功能操作区之后可以查看公告。其页面见下图。公告信息太多时,可以使用公告查询功能快速获取指定的公告。

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第11张图片

图5.9 查看公告页面

代码实现:



/**
 * 
 * 后端接口
 * @author
 * @email
 * @date 2022-01-30
*/
@RestController
@Controller
@RequestMapping("/shuibiaoxinxi")
public class ShuibiaoxinxiController {
    private static final Logger logger = LoggerFactory.getLogger(ShuibiaoxinxiController.class);

    @Autowired
    private ShuibiaoxinxiService shuibiaoxinxiService;

    /**
    * 后端列表
    */
    @RequestMapping("/page")
    public R page(@RequestParam Map params){
        logger.debug("Controller:"+this.getClass().getName()+",page方法");
        PageUtils page = shuibiaoxinxiService.queryPage(params);
        return R.ok().put("data", page);
    }
    /**
    * 后端详情
    */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        logger.debug("Controller:"+this.getClass().getName()+",info方法");
        ShuibiaoxinxiEntity shuibiaoxinxi = shuibiaoxinxiService.selectById(id);
        if(shuibiaoxinxi!=null){
            return R.ok().put("data", shuibiaoxinxi);
        }else {
            return R.error(511,"查不到数据");
        }

    }

    /**
    * 后端保存
    */
    @RequestMapping("/save")
    public R save(@RequestBody ShuibiaoxinxiEntity shuibiaoxinxi, HttpServletRequest request){
        logger.debug("Controller:"+this.getClass().getName()+",save");
        Wrapper queryWrapper = new EntityWrapper()
            .eq("sbname", shuibiaoxinxi.getSbname())
            ;
        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        ShuibiaoxinxiEntity shuibiaoxinxiEntity = shuibiaoxinxiService.selectOne(queryWrapper);
            shuibiaoxinxi.setMoneyTime(new Date());
        if(shuibiaoxinxiEntity==null){
            shuibiaoxinxiService.insert(shuibiaoxinxi);
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 修改
    */
    @RequestMapping("/update")
    public R update(@RequestBody ShuibiaoxinxiEntity shuibiaoxinxi, HttpServletRequest request){
        logger.debug("Controller:"+this.getClass().getName()+",update");
        //根据字段查询是否有相同数据
        Wrapper queryWrapper = new EntityWrapper()
            .notIn("id",shuibiaoxinxi.getId())
            .eq("sbname", shuibiaoxinxi.getSbname())
            ;
        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        ShuibiaoxinxiEntity shuibiaoxinxiEntity = shuibiaoxinxiService.selectOne(queryWrapper);
                shuibiaoxinxi.setMoneyTime(new Date());
        if(shuibiaoxinxiEntity==null){
            shuibiaoxinxiService.updateById(shuibiaoxinxi);//根据id更新
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }


    /**
    * 删除
    */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        logger.debug("Controller:"+this.getClass().getName()+",delete");
        shuibiaoxinxiService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
}

论文参考:

基于Java乡镇自来水收费系统设计实现(源码+lw+部署文档+讲解等)_第12张图片

摘 要I

ABSTRACTII

目 录II

第1章 绪论1

1.1背景及意义1

1.2 国内外研究概况1

1.3 研究的内容1

第2章 相关技术2

2.1 Java技术介绍2

2.2 SSM三大框架2

2.3 MyEclipse开发环境2

2.4 Tomcat服务器3

2.5 MySQL数据库3

第3章 系统分析4

3.1 需求分析4

3.2 系统可行性分析4

3.2.1技术可行性:技术背景4

3.2.2经济可行性5

3.2.3操作可行性:5

3.3 项目设计目标与原则5

3.4系统流程分析6

3.4.1操作流程6

3.4.2添加信息流程7

3.4.3删除信息流程8

第4章 系统设计10

4.1 系统体系结构10

4.2开发流程设计11

4.3 数据库设计原则12

4.4 数据表14

第5章 系统实现20

5.1 管理员功能实现20

5.1.1 水费管理20

5.1.2 水表信息20

5.1.3 水表更换信息21

5.1.4 用户管理21

5.1.5 留言管理22

5.2 用户功能实现22

5.2.1 在线留言22

5.2.2 在线缴费23

5.2.3 更换水表23

5.2.4 查看公告24

第6章 系统测试26

6.1系统测试的目的26

6.2系统测试方法27

6.3功能测试27

结 论29

致 谢30

参考文献31

获取源码:
大家 点赞、收藏、关注、评 啦 、 查看 获取联系方式
精彩专栏 推荐订阅 下方专栏
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》

你可能感兴趣的:(Java毕业设计实战案例,乡镇自来水收费系统,自来水收费系统,Java项目实战,毕业设计,jquery)