文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java程序员周末时间搞锭银行信息管理系统毕业设计(java+springboot+mybatis+mysql+vue+elementui)等实现

2023-09-06 08:57

关注

 博主介绍公司项目主程、全网粉丝10W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,CSDN博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计

公众号:java李杨勇 简历模板、学习资料、面试题库等都给你💪

🍅文末获取源码联系🍅

🍅CSDN官方推荐10W+JAVA技术人文章发布打卡社区🍅

前言介绍:

         在社会快速发展的影响下,银行继续发展,大大增加了存取款和贷款的数量、多样性、质量等等的要求,使小型银行的管理和运营比过去十年更加困难。依照这一现实为基础,设计一个快捷而又方便的小型银行管理系统是一项十分重要并且有价值的事情。对于传统的在银行管理制模型来说,银行管理系统具有许多不可比拟的优势,首先是快速更新订单信息,其次是大量信息的管理,最后是高度安全,以及使用简单等特性,这使得小型银行管理系统的管理和运营非常方便。现代社会的网络和信息技术不断提高,人们的生活水平达到一个新的水平。发展小型银行管理系统正是我们所需要的。这篇文章研究了相关管理系统的开发和实现,从需求分析、总体设计到具体实现,最终完成了整个银行管理系统,从而方便了用户和提高了银行的管理水平。

系统设计:

主要实现

首页、个人中心、通知公告管理、用户管理、员工管理、网点信息管理、账户信息管理、账户存款管理、账户取款管理、账户转账管理、在线咨询管理、销户信息管理、贷款产品管理、贷款信息管理、还款信息管理、离职申请管理、系统管理等功能,其具有简单的接口,方便的应用,强大的互动,完全基于互联网的特点。 

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

系统结构图

主要用到以下技术:

Eclipse

本系统使用的是Eclipse, Eclipse是一个集成开发环境,可以用于Java或者移动应用等方面的程序开发。它有许多强大功能如:编译、调试、test和发布等。同时支持一些其他语言如:HTML脚本,SQL,SPRING BOOT,CSS样式,Spring,Hibernate,Javascript等。

 MySQL

MMySQL数据库是较为出名的关系形数据库,它使用大量的二维表来进行存储数据而不是把数据封装存储早同一个“仓库”中,十分有利于提高速度和数据应用的灵活性。

中小企业网站开发商的首选数据库一般也是MySQL。SQL语言是它的标准语言。由于该数据库在体积、速度和运营成本方面的优势,特别是开放源代码的技术特点,因此深受开发者的喜爱。

Spring Boot框架

Spring框架是Java平台上的一种开源应用框架,提供具有控制反转特性的容器。尽管Spring框架自身对编程模型没有限制,但其在Java应用中的频繁使用让它备受青睐,以至于后来让它作为EJB(EnterpriseJavaBeans)模型的补充,甚至是替补。Spring框架为开发提供了一系列的解决方案,比如利用控制反转的核心特性,并通过依赖注入实现控制反转来实现管理对象生命周期容器化,利用面向切面编程进行声明式的事务管理,整合多种持久化技术管理数据访问,提供大量优秀的Web框架方便开发等等。Spring框架具有控制反转(IOC)特性,IOC旨在方便项目维护和测试,它提供了一种通过Java的反射机制对Java对象进行统一的配置和管理的方法。Spring框架利用容器管理对象的生命周期,容器可以通过扫描XML文件或类上特定Java注解来配置对象,开发者可以通过依赖查找或依赖注入来获得对象。Spring框架具有面向切面编程(AOP)框架,SpringAOP框架基于代理模式,同时运行时可配置;AOP框架主要针对模块之间的交叉关注点进行模块化。Spring框架的AOP框架仅提供基本的AOP特性,虽无法与AspectJ框架相比,但通过与AspectJ的集成,也可以满足基本需求。Spring框架下的事务管理、远程访问等功能均可以通过使用SpringAOP技术实现。Spring的事务管理框架为Java平台带来了一种抽象机制,使本地和全局事务以及嵌套事务能够与保存点一起工作,并且几乎可以在Java平台的任何环境中工作。

功能截图:

 登录模块:

用户前台管理:

系统首页:在系统首页可以查看首页、网点信息、贷款产品、银行资讯、个人中心、后台管理等内容进行详细操作

网点信息:在网点信息页面中可以查看网点名称、网点介绍、网点图片、电话、地址等内容进行评论或收藏操作

贷款产品:在贷款产品页面中可以查看产品编号、产品名称、图片、标签、额度范围、月利率、贷款期限、发布日期、产品介绍等内容进行申请贷款、评论或收藏操作

个人中心: 在个人中心页面通过填写用户名、密码、姓名、图片、性别、联系电话、身份证等内容,进行信息更新操作,还可以根据需要对我的收藏进行详细操作

用户后台管理:

管理员登录进入小型银行管理系统可以查看首页、个人中心、通知公告管理、用户管理、员工管理、网点信息管理、账户信息管理、账户存款管理、账户取款管理、账户转账管理、在线咨询管理、销户信息管理、贷款产品管理、贷款信息管理、还款信息管理、离职申请管理、系统管理等功能进行详细操作

通知公告管理:在通知公告管理页面中可以查看索引、公告标题、图片、发布日期等内容,进行详情,修改或删除等操作

用户信息管理:在网点信息管理页面中可以对索引、网点名称、图片、网点介绍、电话、地址等内容,进行详情、修改、查看评论或删除等操作

员工信息管理

员工档案管理

网点信息管理

用户存款管理:在账户信息管理页面中可以对索引、用户名、姓名、联系电话、身份证、卡号、密码、金额、开卡日期等内容进行详情、存款、取款、转账、修改或删除等操作

用户取款管理

用户转账管理:在账户转账管理页面中可以对索引、用户名、姓名、联系电话、身份证、卡号、金额、对方卡号、开户名、转账说明、转账日期、员工工号、员工姓名等内容,进行详情、修改或删除等操作

贷款产品管理:在贷款产品管理页面中可以对索引、产品编号、产品名称、封面图、标签、额度范围、月利率、贷款期限、发布日期等内容,进行详情、修改、查看评论或删除等操作

还款信息管理:在还款信息管理页面中可以对索引、产品编号、产品名称、金额、备注、还款日期、用户名、姓名、联系电话、身份证、审核回复、审核状态、审核等内容,进行详情、修改或删除等操作

员工离职管理

系统设置管理: 

代码实现:

@RestController@RequestMapping("/yonghu")public class YonghuController {    @Autowired    private YonghuService yonghuService;    @Autowiredprivate TokenService tokenService;@IgnoreAuth@RequestMapping(value = "/login")public R login(String username, String password, String captcha, HttpServletRequest request) {YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuming", username));if(user==null || !user.getMima().equals(password)) {return R.error("账号或密码不正确");}String token = tokenService.generateToken(user.getId(), username,"yonghu",  "用户" );return R.ok().put("token", token);}@IgnoreAuth    @RequestMapping("/register")    public R register(@RequestBody YonghuEntity yonghu){    //ValidatorUtils.validateEntity(yonghu);    YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuming", yonghu.getYonghuming()));if(user!=null) {return R.error("注册用户已存在");}Long uId = new Date().getTime();yonghu.setId(uId);        yonghuService.insert(yonghu);        return R.ok();    }@RequestMapping("/logout")public R logout(HttpServletRequest request) {request.getSession().invalidate();return R.ok("退出成功");}    @RequestMapping("/session")    public R getCurrUser(HttpServletRequest request){    Long id = (Long)request.getSession().getAttribute("userId");        YonghuEntity user = yonghuService.selectById(id);        return R.ok().put("data", user);    }            @IgnoreAuth@RequestMapping(value = "/resetPass")    public R resetPass(String username, HttpServletRequest request){    YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuming", username));    if(user==null) {    return R.error("账号不存在");    }        user.setMima("123456");        yonghuService.updateById(user);        return R.ok("密码已重置为:123456");    }        @RequestMapping("/page")    public R page(@RequestParam Map params,YonghuEntity yonghu,HttpServletRequest request){        EntityWrapper ew = new EntityWrapper();PageUtils page = yonghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghu), params), params));        return R.ok().put("data", page);    }            @RequestMapping("/list")    public R list(@RequestParam Map params,YonghuEntity yonghu, HttpServletRequest request){        EntityWrapper ew = new EntityWrapper();PageUtils page = yonghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghu), params), params));        return R.ok().put("data", page);    }    @RequestMapping("/lists")    public R list( YonghuEntity yonghu){       EntityWrapper ew = new EntityWrapper();      ew.allEq(MPUtil.allEQMapPre( yonghu, "yonghu"));         return R.ok().put("data", yonghuService.selectListView(ew));    }     @RequestMapping("/query")    public R query(YonghuEntity yonghu){        EntityWrapper< YonghuEntity> ew = new EntityWrapper< YonghuEntity>(); ew.allEq(MPUtil.allEQMapPre( yonghu, "yonghu")); YonghuView yonghuView =  yonghuService.selectView(ew);return R.ok("查询用户成功").put("data", yonghuView);    }        @RequestMapping("/info/{id}")    public R info(@PathVariable("id") Long id){        YonghuEntity yonghu = yonghuService.selectById(id);        return R.ok().put("data", yonghu);    }        @RequestMapping("/detail/{id}")    public R detail(@PathVariable("id") Long id){        YonghuEntity yonghu = yonghuService.selectById(id);        return R.ok().put("data", yonghu);    }            @RequestMapping("/save")    public R save(@RequestBody YonghuEntity yonghu, HttpServletRequest request){    yonghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());    //ValidatorUtils.validateEntity(yonghu);    YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuming", yonghu.getYonghuming()));if(user!=null) {return R.error("用户已存在");}yonghu.setId(new Date().getTime());        yonghuService.insert(yonghu);        return R.ok();    }            @RequestMapping("/add")    public R add(@RequestBody YonghuEntity yonghu, HttpServletRequest request){    yonghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());    //ValidatorUtils.validateEntity(yonghu);    YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuming", yonghu.getYonghuming()));if(user!=null) {return R.error("用户已存在");}yonghu.setId(new Date().getTime());        yonghuService.insert(yonghu);        return R.ok();    }        @RequestMapping("/update")    public R update(@RequestBody YonghuEntity yonghu, HttpServletRequest request){        //ValidatorUtils.validateEntity(yonghu);        yonghuService.updateById(yonghu);//全部更新        return R.ok();    }            @RequestMapping("/delete")    public R delete(@RequestBody Long[] ids){        yonghuService.deleteBatchIds(Arrays.asList(ids));        return R.ok();    }        @RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,  @PathVariable("type") String type,@RequestParam Map map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper wrapper = new EntityWrapper();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = yonghuService.selectCount(wrapper);return R.ok().put("count", count);}}
@RestController@RequestMapping("/xiaohuxinxi")public class XiaohuxinxiController {    @Autowired    private XiaohuxinxiService xiaohuxinxiService;            @RequestMapping("/page")    public R page(@RequestParam Map params,XiaohuxinxiEntity xiaohuxinxi,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {xiaohuxinxi.setYonghuming((String)request.getSession().getAttribute("username"));}        EntityWrapper ew = new EntityWrapper();PageUtils page = xiaohuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiaohuxinxi), params), params));        return R.ok().put("data", page);    }            @RequestMapping("/list")    public R list(@RequestParam Map params,XiaohuxinxiEntity xiaohuxinxi, HttpServletRequest request){        EntityWrapper ew = new EntityWrapper();PageUtils page = xiaohuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiaohuxinxi), params), params));        return R.ok().put("data", page);    }    @RequestMapping("/lists")    public R list( XiaohuxinxiEntity xiaohuxinxi){       EntityWrapper ew = new EntityWrapper();      ew.allEq(MPUtil.allEQMapPre( xiaohuxinxi, "xiaohuxinxi"));         return R.ok().put("data", xiaohuxinxiService.selectListView(ew));    }     @RequestMapping("/query")    public R query(XiaohuxinxiEntity xiaohuxinxi){        EntityWrapper< XiaohuxinxiEntity> ew = new EntityWrapper< XiaohuxinxiEntity>(); ew.allEq(MPUtil.allEQMapPre( xiaohuxinxi, "xiaohuxinxi")); XiaohuxinxiView xiaohuxinxiView =  xiaohuxinxiService.selectView(ew);return R.ok("查询销户信息成功").put("data", xiaohuxinxiView);    }        @RequestMapping("/info/{id}")    public R info(@PathVariable("id") Long id){        XiaohuxinxiEntity xiaohuxinxi = xiaohuxinxiService.selectById(id);        return R.ok().put("data", xiaohuxinxi);    }        @RequestMapping("/detail/{id}")    public R detail(@PathVariable("id") Long id){        XiaohuxinxiEntity xiaohuxinxi = xiaohuxinxiService.selectById(id);        return R.ok().put("data", xiaohuxinxi);    }            @RequestMapping("/save")    public R save(@RequestBody XiaohuxinxiEntity xiaohuxinxi, HttpServletRequest request){    xiaohuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());    //ValidatorUtils.validateEntity(xiaohuxinxi);        xiaohuxinxiService.insert(xiaohuxinxi);        return R.ok();    }            @RequestMapping("/add")    public R add(@RequestBody XiaohuxinxiEntity xiaohuxinxi, HttpServletRequest request){    xiaohuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());    //ValidatorUtils.validateEntity(xiaohuxinxi);        xiaohuxinxiService.insert(xiaohuxinxi);        return R.ok();    }        @RequestMapping("/update")    public R update(@RequestBody XiaohuxinxiEntity xiaohuxinxi, HttpServletRequest request){        //ValidatorUtils.validateEntity(xiaohuxinxi);        xiaohuxinxiService.updateById(xiaohuxinxi);//全部更新        return R.ok();    }            @RequestMapping("/delete")    public R delete(@RequestBody Long[] ids){        xiaohuxinxiService.deleteBatchIds(Arrays.asList(ids));        return R.ok();    }        @RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,  @PathVariable("type") String type,@RequestParam Map map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper wrapper = new EntityWrapper();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));}int count = xiaohuxinxiService.selectCount(wrapper);return R.ok().put("count", count);}}

论文参考:

源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻微信公众号获取联系方式👇🏻👇🏻👇🏻

打卡 文章 更新 257/  365天

 精彩专栏推荐订阅下方专栏👇🏻👇🏻👇🏻👇🏻

Java项目精品实战案例《100套》

web前端期末大作业网页实战《100套》

来源地址:https://blog.csdn.net/weixin_39709134/article/details/124152580

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯