• SpringBoot+vue实现前后端分离的摄影跟拍预定管理系统


    文末获取源码

    开发语言:Java
    开发工具:IDEA /Eclipse
    数据库:MYSQL5.7/8.0
    应用服务:Tomcat7/Tomcat8
    是否Maven项目:是
    后端框架:SpringBoot
    前端框架:vue+element等
    JDK版本:jdk1.8
    项目架构:B/S架构

    目录

    前言介绍

    系统功能分析

    系统设计 

    数据库设计 

    系统详细设计 

    首页

    摄影跟拍

    周边商品

    公告信息 

    个人中心

    管理员功能模块

    用户管理

    摄影师管理

    摄影跟拍管理

    类别管理

    周边商品管理

    成品信息管理

    商品订单管理

    系统管理

    摄影师功能模块

    跟拍预约管理

    跟拍流程管理

    用户功能模块 

    成品信息管理

    跟拍预约管理

    部分核心代码: 


     

    前言介绍

    摄影跟拍预定管理方面的任务繁琐,以至于每年都在摄影跟拍预定管理这方面投入较多的精力却效果甚微,摄影跟拍预定管理系统的目标就是为了能够缓解摄影跟拍预定管理工作方面面临的压力,让摄影跟拍预定管理方面的工作变得更加高效准确。

    本项目在开发和设计过程中涉及到原理和技术有: B/S、java技术和MySQL数据库等等;将按以下章节进行开发设计:

    管理员:管理员使用本系统涉到的功能主要有:首页、个人中心、用户管理、摄影师管理、摄影跟拍管理、类别管理、周边商品管理、商品类型管理、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、系统管理等功能。

    摄影师;摄影师使用本系统涉到的功能主要有:首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理等功能。

    用户主要包括首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、评论信息管理、我的收藏管理等功能。 

    系统功能分析

    考虑到实际生活中在摄影跟拍预定方面的需要以及对该系统认真的分析,将系统权限按管理员、摄影师和用户这三类涉及用户划分。

    (a) 管理员;管理员使用本系统涉到的功能主要有:首页、个人中心、用户管理、摄影师管理、摄影跟拍管理、类别管理、周边商品管理、商品类型管理、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、系统管理等功能。管理员用例图如图 

    (b)摄影师;摄影师使用本系统涉到的功能主要有:首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理等功能。摄影师用例图如图

     

    (c)用户主要包括首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、评论信息管理、我的收藏管理等功能。用户用例图如图

     

    系统设计 

    系统整体功能如下图所示:

    数据库设计 

    概念模型是对现实中的问题出现的事物的进行描述,ER图是由实体及其关系构成的图,通过E-R图可以清楚地描述系统涉及到的实体之间的相互关系。

    个人中心实体图如图

    摄影跟拍实体图如图

     

    周边商品实体图如图

     

    系统详细设计 

    首页

    摄影跟拍预定管理系统,在系统首页可以查看首页、摄影跟拍、周边商品、公告信息、个人中心、后台管理等内容,并进行详细操作,如图

    摄影跟拍

    在摄影跟拍页面中可以查看套餐名称、类别、套餐简介、拍摄地点、套餐价格、注意事项、发布日期等内容进行预约、评论或收藏等操作,如图 

    周边商品

    在周边商品页面可以查看商品名称、商品类型、商品规格、商品简介、原材料、生产地、单价、数量、上架日期、点击次数等内容进行购买、收藏或评论等操作,如图 

    公告信息 

     

     

    个人中心

    在个人中心页面通过填写个人账号、密码、 姓名、邮箱、手机号码、图片等内容进行更新信息,并可以根据我的收藏进行相应的操作,如图

     

     

    管理员功能模块

    管理员进行登录,进入系统前在登录页面根据要求填写用户名和密码,选择角色等信息,点击登录进行登录操作,如图

    管理员登录系统后,可以对首页、个人中心、用户管理、摄影师管理、摄影跟拍管理、类别管理、周边商品管理、商品类型管理、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、系统管理等进行相应的操作管理,如图

     

    用户管理

    在用户管理页面可以对索引、个人账号、姓名、性别、邮箱、手机号码、照片等内容进行详情、修改或删除等操作,如图 

    摄影师管理

    在摄影师管理页面可以对索引、工号、员工姓名、性别、邮箱、联系手机、照片等内容进行详情、修改或删除等操作,如图 

    摄影跟拍管理

    在摄影跟拍管理页面可以对索引、套餐名称、套餐图片、类别、拍摄地点、套餐价格、注意事项、发布日期等内容进行详情、修改、查看评论或删除等操作,如图

     

    类别管理

    在课程分类管理页面可以对索引、类型等内容进行详情、修改或删除等操作,如图 

    周边商品管理

    在周边商品管理页面可以对索引、商品名称、商品类型、商品图片、商品规格、生产地、原材料、单价、数量、上架日期等内容进行详情、修改、查看评论或删除等操作,如图 

    成品信息管理

    在成品信息管理页面可以对索引、成品名称、 成品图片、成品附件、个人账号、姓名、手机号码、上传日期、工号、员工姓名、联系手机等内容进行详情或删除等操作,如图 

    商品订单管理

    在商品订单管理页面中可以对索引、商品名称、商品类型、单价、数量、金额、个人账号、姓名、手机号码、下单备注、下单时间、是否支付、审核回复、审核状态、审核等内容进行详情或删除等操作,如图 

     

    系统管理

    在轮播图管理页面中可以对索引、名称、值等内容进行详情或修改等操作,并可以根据公告信息进行相应的操作,如图

     

    摄影师功能模块

    摄影师登录进入摄影跟拍预定管理系统可以对首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理等进行相应操作,如图 

    跟拍预约管理

    在跟拍预约管理页面中可以对索引、套餐名称、类型、拍摄地点、套餐价格、个人账号、姓名、手机号码、预约日期、预约备注、下单时间、是否支付、审核回复、审核状态、审核等内容进行详情或流程等操作,如图

    跟拍流程管理

    在跟拍流程管理页面可以对索引、套餐名称、类别、拍摄地点、个人账号、姓名、手机号码、安排时间、工号、员工姓名、联系手机、操作日期审核回复、审核状态等内容进行详情、成品、修改或删除等操作,如图 

    用户功能模块 

    用户注册,通过填写个人账号、密码、 确认密码、 姓名、邮箱、手机号码等内容进行注册等操作,如图

    用户登录进入摄影跟拍预定管理系统可以对首页、个人中心、跟拍预约管理、跟拍流程管理、成品信息管理、商品订单管理、评论信息管理、我的收藏管理等进行相应操作,如图

    成品信息管理

    在成品信息管理页面可以对索引、成品名称、 成品图片、成品附件、个人账号、姓名、手机号码、上传日期、工号、员工姓名、联系手机等内容进行详情等操作,如图

     

    跟拍预约管理

    在跟拍预约管理页面可以对索引、套餐名称、类型、拍摄地点、套餐价格、个人账号、姓名、手机号码、预约日期、预约备注、下单时间、是否支付、审核回复、审核状态、审核等内容进行详情等操作,如图 

    部分核心代码: 

    1. /**
    2. * 摄影跟拍
    3. * 后端接口
    4. * @author
    5. * @email
    6. * @date 2022-02-24 11:54:57
    7. */
    8. @RestController
    9. @RequestMapping("/sheyinggenpai")
    10. public class SheyinggenpaiController {
    11. @Autowired
    12. private SheyinggenpaiService sheyinggenpaiService;
    13. @Autowired
    14. private StoreupService storeupService;
    15. /**
    16. * 后端列表
    17. */
    18. @RequestMapping("/page")
    19. public R page(@RequestParam Map<String, Object> params,SheyinggenpaiEntity sheyinggenpai,
    20. HttpServletRequest request){
    21. EntityWrapper<SheyinggenpaiEntity> ew = new EntityWrapper<SheyinggenpaiEntity>();
    22. PageUtils page = sheyinggenpaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, sheyinggenpai), params), params));
    23. return R.ok().put("data", page);
    24. }
    25. /**
    26. * 前端列表
    27. */
    28. @IgnoreAuth
    29. @RequestMapping("/list")
    30. public R list(@RequestParam Map<String, Object> params,SheyinggenpaiEntity sheyinggenpai,
    31. HttpServletRequest request){
    32. EntityWrapper<SheyinggenpaiEntity> ew = new EntityWrapper<SheyinggenpaiEntity>();
    33. PageUtils page = sheyinggenpaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, sheyinggenpai), params), params));
    34. return R.ok().put("data", page);
    35. }
    36. /**
    37. * 列表
    38. */
    39. @RequestMapping("/lists")
    40. public R list( SheyinggenpaiEntity sheyinggenpai){
    41. EntityWrapper<SheyinggenpaiEntity> ew = new EntityWrapper<SheyinggenpaiEntity>();
    42. ew.allEq(MPUtil.allEQMapPre( sheyinggenpai, "sheyinggenpai"));
    43. return R.ok().put("data", sheyinggenpaiService.selectListView(ew));
    44. }
    45. /**
    46. * 查询
    47. */
    48. @RequestMapping("/query")
    49. public R query(SheyinggenpaiEntity sheyinggenpai){
    50. EntityWrapper< SheyinggenpaiEntity> ew = new EntityWrapper< SheyinggenpaiEntity>();
    51. ew.allEq(MPUtil.allEQMapPre( sheyinggenpai, "sheyinggenpai"));
    52. SheyinggenpaiView sheyinggenpaiView = sheyinggenpaiService.selectView(ew);
    53. return R.ok("查询摄影跟拍成功").put("data", sheyinggenpaiView);
    54. }
    55. /**
    56. * 后端详情
    57. */
    58. @RequestMapping("/info/{id}")
    59. public R info(@PathVariable("id") Long id){
    60. SheyinggenpaiEntity sheyinggenpai = sheyinggenpaiService.selectById(id);
    61. sheyinggenpai.setClicktime(new Date());
    62. sheyinggenpaiService.updateById(sheyinggenpai);
    63. return R.ok().put("data", sheyinggenpai);
    64. }
    65. /**
    66. * 前端详情
    67. */
    68. @IgnoreAuth
    69. @RequestMapping("/detail/{id}")
    70. public R detail(@PathVariable("id") Long id){
    71. SheyinggenpaiEntity sheyinggenpai = sheyinggenpaiService.selectById(id);
    72. sheyinggenpai.setClicktime(new Date());
    73. sheyinggenpaiService.updateById(sheyinggenpai);
    74. return R.ok().put("data", sheyinggenpai);
    75. }
    76. /**
    77. * 后端保存
    78. */
    79. @RequestMapping("/save")
    80. public R save(@RequestBody SheyinggenpaiEntity sheyinggenpai, HttpServletRequest request){
    81. sheyinggenpai.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    82. //ValidatorUtils.validateEntity(sheyinggenpai);
    83. sheyinggenpaiService.insert(sheyinggenpai);
    84. return R.ok();
    85. }
    86. /**
    87. * 前端保存
    88. */
    89. @RequestMapping("/add")
    90. public R add(@RequestBody SheyinggenpaiEntity sheyinggenpai, HttpServletRequest request){
    91. sheyinggenpai.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    92. //ValidatorUtils.validateEntity(sheyinggenpai);
    93. sheyinggenpaiService.insert(sheyinggenpai);
    94. return R.ok();
    95. }
    96. /**
    97. * 修改
    98. */
    99. @RequestMapping("/update")
    100. public R update(@RequestBody SheyinggenpaiEntity sheyinggenpai, HttpServletRequest request){
    101. //ValidatorUtils.validateEntity(sheyinggenpai);
    102. sheyinggenpaiService.updateById(sheyinggenpai);//全部更新
    103. return R.ok();
    104. }
    105. /**
    106. * 删除
    107. */
    108. @RequestMapping("/delete")
    109. public R delete(@RequestBody Long[] ids){
    110. sheyinggenpaiService.deleteBatchIds(Arrays.asList(ids));
    111. return R.ok();
    112. }
    113. /**
    114. * 提醒接口
    115. */
    116. @RequestMapping("/remind/{columnName}/{type}")
    117. public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
    118. @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
    119. map.put("column", columnName);
    120. map.put("type", type);
    121. if(type.equals("2")) {
    122. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    123. Calendar c = Calendar.getInstance();
    124. Date remindStartDate = null;
    125. Date remindEndDate = null;
    126. if(map.get("remindstart")!=null) {
    127. Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
    128. c.setTime(new Date());
    129. c.add(Calendar.DAY_OF_MONTH,remindStart);
    130. remindStartDate = c.getTime();
    131. map.put("remindstart", sdf.format(remindStartDate));
    132. }
    133. if(map.get("remindend")!=null) {
    134. Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
    135. c.setTime(new Date());
    136. c.add(Calendar.DAY_OF_MONTH,remindEnd);
    137. remindEndDate = c.getTime();
    138. map.put("remindend", sdf.format(remindEndDate));
    139. }
    140. }
    141. Wrapper<SheyinggenpaiEntity> wrapper = new EntityWrapper<SheyinggenpaiEntity>();
    142. if(map.get("remindstart")!=null) {
    143. wrapper.ge(columnName, map.get("remindstart"));
    144. }
    145. if(map.get("remindend")!=null) {
    146. wrapper.le(columnName, map.get("remindend"));
    147. }
    148. int count = sheyinggenpaiService.selectCount(wrapper);
    149. return R.ok().put("count", count);
    150. }
    151. /**
    152. * 前端智能排序
    153. */
    154. @IgnoreAuth
    155. @RequestMapping("/autoSort")
    156. public R autoSort(@RequestParam Map<String, Object> params,SheyinggenpaiEntity sheyinggenpai, HttpServletRequest request,String pre){
    157. EntityWrapper<SheyinggenpaiEntity> ew = new EntityWrapper<SheyinggenpaiEntity>();
    158. Map<String, Object> newMap = new HashMap<String, Object>();
    159. Map<String, Object> param = new HashMap<String, Object>();
    160. Iterator<Map.Entry<String, Object>> it = param.entrySet().iterator();
    161. while (it.hasNext()) {
    162. Map.Entry<String, Object> entry = it.next();
    163. String key = entry.getKey();
    164. String newKey = entry.getKey();
    165. if (pre.endsWith(".")) {
    166. newMap.put(pre + newKey, entry.getValue());
    167. } else if (StringUtils.isEmpty(pre)) {
    168. newMap.put(newKey, entry.getValue());
    169. } else {
    170. newMap.put(pre + "." + newKey, entry.getValue());
    171. }
    172. }
    173. params.put("sort", "clicktime");
    174. params.put("order", "desc");
    175. PageUtils page = sheyinggenpaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, sheyinggenpai), params), params));
    176. return R.ok().put("data", page);
    177. }
    178. }
    1. /**
    2. * 成品信息
    3. * 数据库通用操作实体类(普通增删改查)
    4. * @author
    5. * @email
    6. * @date 2022-02-24 11:54:57
    7. */
    8. @TableName("chengpinxinxi")
    9. public class ChengpinxinxiEntity<T> implements Serializable {
    10. private static final long serialVersionUID = 1L;
    11. public ChengpinxinxiEntity() {
    12. }
    13. public ChengpinxinxiEntity(T t) {
    14. try {
    15. BeanUtils.copyProperties(this, t);
    16. } catch (IllegalAccessException | InvocationTargetException e) {
    17. // TODO Auto-generated catch block
    18. e.printStackTrace();
    19. }
    20. }
    21. /**
    22. * 主键id
    23. */
    24. @TableId
    25. private Long id;
    26. /**
    27. * 成品名称
    28. */
    29. private String chengpinmingcheng;
    30. /**
    31. * 成品图片
    32. */
    33. private String chengpintupian;
    34. /**
    35. * 成品附件
    36. */
    37. private String chengpinfujian;
    38. /**
    39. * 个人账号
    40. */
    41. private String gerenzhanghao;
    42. /**
    43. * 姓名
    44. */
    45. private String xingming;
    46. /**
    47. * 手机号码
    48. */
    49. private String shoujihaoma;
    50. /**
    51. * 上传日期
    52. */
    53. @JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd")
    54. @DateTimeFormat
    55. private Date shangchuanriqi;
    56. /**
    57. * 工号
    58. */
    59. private String gonghao;
    60. /**
    61. * 员工姓名
    62. */
    63. private String yuangongxingming;
    64. /**
    65. * 联系手机
    66. */
    67. private String lianxishouji;
    68. @JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd HH:mm:ss")
    69. @DateTimeFormat
    70. private Date addtime;
    71. public Date getAddtime() {
    72. return addtime;
    73. }
    74. public void setAddtime(Date addtime) {
    75. this.addtime = addtime;
    76. }
    77. public Long getId() {
    78. return id;
    79. }
    80. public void setId(Long id) {
    81. this.id = id;
    82. }
    83. /**
    84. * 设置:成品名称
    85. */
    86. public void setChengpinmingcheng(String chengpinmingcheng) {
    87. this.chengpinmingcheng = chengpinmingcheng;
    88. }
    89. /**
    90. * 获取:成品名称
    91. */
    92. public String getChengpinmingcheng() {
    93. return chengpinmingcheng;
    94. }
    95. /**
    96. * 设置:成品图片
    97. */
    98. public void setChengpintupian(String chengpintupian) {
    99. this.chengpintupian = chengpintupian;
    100. }
    101. /**
    102. * 获取:成品图片
    103. */
    104. public String getChengpintupian() {
    105. return chengpintupian;
    106. }
    107. /**
    108. * 设置:成品附件
    109. */
    110. public void setChengpinfujian(String chengpinfujian) {
    111. this.chengpinfujian = chengpinfujian;
    112. }
    113. /**
    114. * 获取:成品附件
    115. */
    116. public String getChengpinfujian() {
    117. return chengpinfujian;
    118. }
    119. /**
    120. * 设置:个人账号
    121. */
    122. public void setGerenzhanghao(String gerenzhanghao) {
    123. this.gerenzhanghao = gerenzhanghao;
    124. }
    125. /**
    126. * 获取:个人账号
    127. */
    128. public String getGerenzhanghao() {
    129. return gerenzhanghao;
    130. }
    131. /**
    132. * 设置:姓名
    133. */
    134. public void setXingming(String xingming) {
    135. this.xingming = xingming;
    136. }
    137. /**
    138. * 获取:姓名
    139. */
    140. public String getXingming() {
    141. return xingming;
    142. }
    143. /**
    144. * 设置:手机号码
    145. */
    146. public void setShoujihaoma(String shoujihaoma) {
    147. this.shoujihaoma = shoujihaoma;
    148. }
    149. /**
    150. * 获取:手机号码
    151. */
    152. public String getShoujihaoma() {
    153. return shoujihaoma;
    154. }
    155. /**
    156. * 设置:上传日期
    157. */
    158. public void setShangchuanriqi(Date shangchuanriqi) {
    159. this.shangchuanriqi = shangchuanriqi;
    160. }
    161. /**
    162. * 获取:上传日期
    163. */
    164. public Date getShangchuanriqi() {
    165. return shangchuanriqi;
    166. }
    167. /**
    168. * 设置:工号
    169. */
    170. public void setGonghao(String gonghao) {
    171. this.gonghao = gonghao;
    172. }
    173. /**
    174. * 获取:工号
    175. */
    176. public String getGonghao() {
    177. return gonghao;
    178. }
    179. /**
    180. * 设置:员工姓名
    181. */
    182. public void setYuangongxingming(String yuangongxingming) {
    183. this.yuangongxingming = yuangongxingming;
    184. }
    185. /**
    186. * 获取:员工姓名
    187. */
    188. public String getYuangongxingming() {
    189. return yuangongxingming;
    190. }
    191. /**
    192. * 设置:联系手机
    193. */
    194. public void setLianxishouji(String lianxishouji) {
    195. this.lianxishouji = lianxishouji;
    196. }
    197. /**
    198. * 获取:联系手机
    199. */
    200. public String getLianxishouji() {
    201. return lianxishouji;
    202. }
    203. }

  • 相关阅读:
    小红书素人铺量推广费用是多少?
    展讯模块读写IMEI
    位图(bitmap)原理以及实现
    知识蒸馏原理与PVKD论文阅读
    细数APDL中的流程控制命令
    【开源】基于Vue.js的中小学教师课程排课系统
    spring-boot-devtools热部署功能集成使用
    库存三层模型(中)
    OSEP 考试总结
    距离相关系数的原理及其实现(Numpy代码+第三方包的实现)
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/125526109