• SpringBoot+Vue项目校园在线拍卖系统


    文末获取源码

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

    前言介绍  

    本系统主要包括管理员,用户和拍卖者三个角色组成,主要包括以下功能:

    1.前台:首页、竞拍商品、拍卖资讯、在线留言、个人中心、后台管理、拍卖咨询。

    2.管理员:首页、个人中心、用户管理、拍卖者管理、商品分类管理、竞拍商品管理、竞拍订单管理、评价订单管理、在线留言、系统管理

    3.用户:首页、个人中心、竞拍订单管理、评价订单管理

    4.拍卖者:首页、个人中心、竞拍商品管理、竞拍订单管理、评价订单管理、在线留言

    系统展示

    前台

    竞拍商品

     

    拍卖资讯

    管理员

     

    拍卖者管理 

    竞拍商品管理 

    用户

    竞拍订单管理

    评价订单管理 

     

    拍卖者

    竞拍商品管理 

    部分核心代码  

    1. /**
    2. * 竞拍订单
    3. * 后端接口
    4. * @author
    5. * @email
    6. * @date 2022-05-03 10:36:55
    7. */
    8. @RestController
    9. @RequestMapping("/jingpaidingdan")
    10. public class JingpaidingdanController {
    11. @Autowired
    12. private JingpaidingdanService jingpaidingdanService;
    13. /**
    14. * 后端列表
    15. */
    16. @RequestMapping("/page")
    17. public R page(@RequestParam Map<String, Object> params,JingpaidingdanEntity jingpaidingdan,
    18. @RequestParam(required = false) @DateTimeFormat(pattern="yyyy-MM-dd") Date jingpaishijianstart,
    19. @RequestParam(required = false) @DateTimeFormat(pattern="yyyy-MM-dd") Date jingpaishijianend,
    20. HttpServletRequest request){
    21. String tableName = request.getSession().getAttribute("tableName").toString();
    22. if(tableName.equals("yonghu")) {
    23. jingpaidingdan.setYonghuzhanghao((String)request.getSession().getAttribute("username"));
    24. }
    25. if(tableName.equals("paimaizhe")) {
    26. jingpaidingdan.setPaimaizhezhanghao((String)request.getSession().getAttribute("username"));
    27. }
    28. EntityWrapper<JingpaidingdanEntity> ew = new EntityWrapper<JingpaidingdanEntity>();
    29. if(jingpaishijianstart!=null) ew.ge("jingpaishijian", jingpaishijianstart);
    30. if(jingpaishijianend!=null) ew.le("jingpaishijian", jingpaishijianend);
    31. PageUtils page = jingpaidingdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jingpaidingdan), params), params));
    32. return R.ok().put("data", page);
    33. }
    34. /**
    35. * 前端列表
    36. */
    37. @IgnoreAuth
    38. @RequestMapping("/list")
    39. public R list(@RequestParam Map<String, Object> params,JingpaidingdanEntity jingpaidingdan,
    40. @RequestParam(required = false) @DateTimeFormat(pattern="yyyy-MM-dd") Date jingpaishijianstart,
    41. @RequestParam(required = false) @DateTimeFormat(pattern="yyyy-MM-dd") Date jingpaishijianend,
    42. HttpServletRequest request){
    43. EntityWrapper<JingpaidingdanEntity> ew = new EntityWrapper<JingpaidingdanEntity>();
    44. if(jingpaishijianstart!=null) ew.ge("jingpaishijian", jingpaishijianstart);
    45. if(jingpaishijianend!=null) ew.le("jingpaishijian", jingpaishijianend);
    46. PageUtils page = jingpaidingdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jingpaidingdan), params), params));
    47. return R.ok().put("data", page);
    48. }
    49. /**
    50. * 列表
    51. */
    52. @RequestMapping("/lists")
    53. public R list( JingpaidingdanEntity jingpaidingdan){
    54. EntityWrapper<JingpaidingdanEntity> ew = new EntityWrapper<JingpaidingdanEntity>();
    55. ew.allEq(MPUtil.allEQMapPre( jingpaidingdan, "jingpaidingdan"));
    56. return R.ok().put("data", jingpaidingdanService.selectListView(ew));
    57. }
    58. /**
    59. * 查询
    60. */
    61. @RequestMapping("/query")
    62. public R query(JingpaidingdanEntity jingpaidingdan){
    63. EntityWrapper< JingpaidingdanEntity> ew = new EntityWrapper< JingpaidingdanEntity>();
    64. ew.allEq(MPUtil.allEQMapPre( jingpaidingdan, "jingpaidingdan"));
    65. JingpaidingdanView jingpaidingdanView = jingpaidingdanService.selectView(ew);
    66. return R.ok("查询竞拍订单成功").put("data", jingpaidingdanView);
    67. }
    68. /**
    69. * 后端详情
    70. */
    71. @RequestMapping("/info/{id}")
    72. public R info(@PathVariable("id") Long id){
    73. JingpaidingdanEntity jingpaidingdan = jingpaidingdanService.selectById(id);
    74. return R.ok().put("data", jingpaidingdan);
    75. }
    76. /**
    77. * 前端详情
    78. */
    79. @IgnoreAuth
    80. @RequestMapping("/detail/{id}")
    81. public R detail(@PathVariable("id") Long id){
    82. JingpaidingdanEntity jingpaidingdan = jingpaidingdanService.selectById(id);
    83. return R.ok().put("data", jingpaidingdan);
    84. }
    85. /**
    86. * 后端保存
    87. */
    88. @RequestMapping("/save")
    89. public R save(@RequestBody JingpaidingdanEntity jingpaidingdan, HttpServletRequest request){
    90. jingpaidingdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    91. //ValidatorUtils.validateEntity(jingpaidingdan);
    92. jingpaidingdanService.insert(jingpaidingdan);
    93. return R.ok();
    94. }
    95. /**
    96. * 前端保存
    97. */
    98. @RequestMapping("/add")
    99. public R add(@RequestBody JingpaidingdanEntity jingpaidingdan, HttpServletRequest request){
    100. jingpaidingdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    101. //ValidatorUtils.validateEntity(jingpaidingdan);
    102. jingpaidingdanService.insert(jingpaidingdan);
    103. return R.ok();
    104. }
    105. /**
    106. * 修改
    107. */
    108. @RequestMapping("/update")
    109. @Transactional
    110. public R update(@RequestBody JingpaidingdanEntity jingpaidingdan, HttpServletRequest request){
    111. //ValidatorUtils.validateEntity(jingpaidingdan);
    112. jingpaidingdanService.updateById(jingpaidingdan);//全部更新
    113. return R.ok();
    114. }
    115. /**
    116. * 删除
    117. */
    118. @RequestMapping("/delete")
    119. public R delete(@RequestBody Long[] ids){
    120. jingpaidingdanService.deleteBatchIds(Arrays.asList(ids));
    121. return R.ok();
    122. }
    123. /**
    124. * 提醒接口
    125. */
    126. @RequestMapping("/remind/{columnName}/{type}")
    127. public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
    128. @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
    129. map.put("column", columnName);
    130. map.put("type", type);
    131. if(type.equals("2")) {
    132. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    133. Calendar c = Calendar.getInstance();
    134. Date remindStartDate = null;
    135. Date remindEndDate = null;
    136. if(map.get("remindstart")!=null) {
    137. Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
    138. c.setTime(new Date());
    139. c.add(Calendar.DAY_OF_MONTH,remindStart);
    140. remindStartDate = c.getTime();
    141. map.put("remindstart", sdf.format(remindStartDate));
    142. }
    143. if(map.get("remindend")!=null) {
    144. Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
    145. c.setTime(new Date());
    146. c.add(Calendar.DAY_OF_MONTH,remindEnd);
    147. remindEndDate = c.getTime();
    148. map.put("remindend", sdf.format(remindEndDate));
    149. }
    150. }
    151. Wrapper<JingpaidingdanEntity> wrapper = new EntityWrapper<JingpaidingdanEntity>();
    152. if(map.get("remindstart")!=null) {
    153. wrapper.ge(columnName, map.get("remindstart"));
    154. }
    155. if(map.get("remindend")!=null) {
    156. wrapper.le(columnName, map.get("remindend"));
    157. }
    158. String tableName = request.getSession().getAttribute("tableName").toString();
    159. if(tableName.equals("yonghu")) {
    160. wrapper.eq("yonghuzhanghao", (String)request.getSession().getAttribute("username"));
    161. }
    162. if(tableName.equals("paimaizhe")) {
    163. wrapper.eq("paimaizhezhanghao", (String)request.getSession().getAttribute("username"));
    164. }
    165. int count = jingpaidingdanService.selectCount(wrapper);
    166. return R.ok().put("count", count);
    167. }
    168. }
    1. /**
    2. * 上传文件映射表
    3. */
    4. @RestController
    5. @RequestMapping("file")
    6. @SuppressWarnings({"unchecked","rawtypes"})
    7. public class FileController{
    8. @Autowired
    9. private ConfigService configService;
    10. /**
    11. * 上传文件
    12. */
    13. @RequestMapping("/upload")
    14. public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
    15. if (file.isEmpty()) {
    16. throw new EIException("上传文件不能为空");
    17. }
    18. String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
    19. File path = new File(ResourceUtils.getURL("classpath:static").getPath());
    20. if(!path.exists()) {
    21. path = new File("");
    22. }
    23. File upload = new File(path.getAbsolutePath(),"/upload/");
    24. if(!upload.exists()) {
    25. upload.mkdirs();
    26. }
    27. String fileName = new Date().getTime()+"."+fileExt;
    28. File dest = new File(upload.getAbsolutePath()+"/"+fileName);
    29. file.transferTo(dest);
    30. /**
    31. * 如果使用idea或者eclipse重启项目,发现之前上传的图片或者文件丢失,将下面一行代码注释打开
    32. * 请将以下的"D:\\springbootq33sd\\src\\main\\resources\\static\\upload"替换成你本地项目的upload路径,
    33. * 并且项目路径不能存在中文、空格等特殊字符
    34. */
    35. // FileUtils.copyFile(dest, new File("D:\\springbootq33sd\\src\\main\\resources\\static\\upload"+"/"+fileName)); /**修改了路径以后请将该行最前面的//注释去掉**/
    36. if(StringUtils.isNotBlank(type) && type.equals("1")) {
    37. ConfigEntity configEntity = configService.selectOne(new EntityWrapper().eq("name", "faceFile"));
    38. if(configEntity==null) {
    39. configEntity = new ConfigEntity();
    40. configEntity.setName("faceFile");
    41. configEntity.setValue(fileName);
    42. } else {
    43. configEntity.setValue(fileName);
    44. }
    45. configService.insertOrUpdate(configEntity);
    46. }
    47. return R.ok().put("file", fileName);
    48. }
    49. /**
    50. * 下载文件
    51. */
    52. @IgnoreAuth
    53. @RequestMapping("/download")
    54. public ResponseEntity<byte[]> download(@RequestParam String fileName) {
    55. try {
    56. File path = new File(ResourceUtils.getURL("classpath:static").getPath());
    57. if(!path.exists()) {
    58. path = new File("");
    59. }
    60. File upload = new File(path.getAbsolutePath(),"/upload/");
    61. if(!upload.exists()) {
    62. upload.mkdirs();
    63. }
    64. File file = new File(upload.getAbsolutePath()+"/"+fileName);
    65. if(file.exists()){
    66. /*if(!fileService.canRead(file, SessionManager.getSessionUser())){
    67. getResponse().sendError(403);
    68. }*/
    69. HttpHeaders headers = new HttpHeaders();
    70. headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
    71. headers.setContentDispositionFormData("attachment", fileName);
    72. return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED);
    73. }
    74. } catch (IOException e) {
    75. e.printStackTrace();
    76. }
    77. return new ResponseEntity<byte[]>(HttpStatus.INTERNAL_SERVER_ERROR);
    78. }
    79. }

  • 相关阅读:
    git学习笔记——分支、commit版本切换篇
    Python之基础数据类型(二)
    Git系列讲解(五):Git常用命令整理
    shein测试开发会问些啥?
    Nginx、MySQL、LNMP安装
    GBase 8a事务和锁语句
    UE5 c++将自定义UserWdiget添加到对应菜单栏
    day01 mybatis
    【设计模式】26.结构型模式-代理模式(Proxy)
    Android11 有线网和wifi优先级设置
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/126058298