首页 > 分享 > 基于java+springboot+vue的网上宠物店系统

基于java+springboot+vue的网上宠物店系统

作者简介:多年编程开发经验,专注java技术领域和毕业设计项目实战,系统定制、远程部署调试、代码讲解、代码修改
擅长语言:springboot、ssm、vue、html、jsp、php、python、爬虫、小程序、安卓app
⬇️源码获取:文末可以获取源码+数据库+文档

⚡感兴趣的可以先收藏+关注,后续会更新更多项目资料,所有项目均配有开发文档和安装配置教程

971985bedcfc412a9414550e658574b3.png

系统介绍

网上宠物店系统按照操作主体分为管理员和用户。管理员的功能包括收货地址管理,购物车管理,客服聊天管理,宠物寄养管理,宠物寄养订单管理,寄存日志管理,商品管理,商品收藏管理。用户的功能包括注册,信息查看,留言等功能。

网上宠物店系统是一款运用软件开发技术设计实现的应用系统,在信息处理上可以达到快速的目的,不管是针对数据添加,数据维护和统计,以及数据查询等处理要求,网上宠物店系统都可以轻松应对。

系统主要技术

开发语言:Java

使用框架:SpringBoot

系统架构:B/S

前端技术:Vue、JavaScript

数据库 :Mysql 5.7/8.0

编译工具:idea或者eclipse,jdk1.8,maven

系统功能结构设计

为了让系统的编码可以顺利进行,特意对本系统功能进行细分设计,设计的系统功能结构见下图。

d5a1d18a43c34f1e99dc93f674fcc5a2.png

系统功能实现

5.1用户信息管理

如图5.1显示的就是用户信息管理页面,此页面提供给管理员的功能有:用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息,还进行了对用户名称的模糊查询的条件

a748f293c9554fed8930d61a34e659f3.png

图5.1 用户信息管理页面

5.2 商品信息管理

如图5.2显示的就是商品信息管理页面,此页面提供给管理员的功能有:查看已发布的商品信息数据,修改商品信息,商品信息作废,即可删除,还进行了对商品信息名称的模糊查询 商品信息信息的类型查询等等一些条件。

图5.2 商品信息管理页面

5.3宠物寄养管理

如图5.3显示的就是宠物寄养管理页面,此页面提供给管理员的功能有:根据宠物寄养进行条件查询,还可以对宠物寄养进行新增、修改、查询操作等等。

6c1a36eda4e841c9be51726313e88cd2.png

图5.3 宠物寄养管理页面

5.1公告信息管理

如图5.4显示的就是公告信息管理页面,此页面提供给管理员的功能有:根据公告信息进行新增、修改、查询操作等等。

0eb3e8e53ff944cb8375e3a64a2fa351.png

图5.4 公告信息管理页面

论文参考

96771922380c4b72a05340a20d6d5c73.png

d4edbbd4c5ca4898a17e113b78231016.png

核心代码

package com.controller;

import java.io.File;

import java.math.BigDecimal;

import java.net.URL;

import java.text.SimpleDateFormat;

import com.alibaba.fastjson.JSONObject;

import java.util.*;

import org.springframework.beans.BeanUtils;

import javax.servlet.http.HttpServletRequest;

import org.springframework.web.context.ContextLoader;

import javax.servlet.ServletContext;

import com.service.TokenService;

import com.utils.*;

import java.lang.reflect.InvocationTargetException;

import com.service.DictionaryService;

import org.apache.commons.lang3.StringUtils;

import com.annotation.IgnoreAuth;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.*;

import com.baomidou.mybatisplus.mapper.EntityWrapper;

import com.baomidou.mybatisplus.mapper.Wrapper;

import com.entity.*;

import com.entity.view.*;

import com.service.*;

import com.utils.PageUtils;

import com.utils.R;

import com.alibaba.fastjson.*;

@RestController

@Controller

@RequestMapping("/chongwujiyang")

public class ChongwujiyangController {

private static final Logger logger = LoggerFactory.getLogger(ChongwujiyangController.class);

private static final String TABLE_NAME = "chongwujiyang";

@Autowired

private ChongwujiyangService chongwujiyangService;

@Autowired

private TokenService tokenService;

@Autowired

private AddressService addressService;

@Autowired

private CartService cartService;

@Autowired

private ChatService chatService;

@Autowired

private ChongwujiyangYuyueService chongwujiyangYuyueService;

@Autowired

private ChongwurizhiService chongwurizhiService;

@Autowired

private ChongwuyongpinService chongwuyongpinService;

@Autowired

private ChongwuyongpinCollectionService chongwuyongpinCollectionService;

@Autowired

private ChongwuyongpinCommentbackService chongwuyongpinCommentbackService;

@Autowired

private ChongwuyongpinOrderService chongwuyongpinOrderService;

@Autowired

private DictionaryService dictionaryService;

@Autowired

private ForumService forumService;

@Autowired

private NewsService newsService;

@Autowired

private YonghuService yonghuService;

@Autowired

private UsersService usersService;

@RequestMapping("/page")

public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){

logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));

String role = String.valueOf(request.getSession().getAttribute("role"));

if(false)

return R.error(511,"永不会进入");

else if("用户".equals(role))

params.put("yonghuId",request.getSession().getAttribute("userId"));

params.put("chongwujiyangDeleteStart",1);params.put("chongwujiyangDeleteEnd",1);

CommonUtil.checkMap(params);

PageUtils page = chongwujiyangService.queryPage(params);

List<ChongwujiyangView> list =(List<ChongwujiyangView>)page.getList();

for(ChongwujiyangView c:list){

dictionaryService.dictionaryConvert(c, request);

}

return R.ok().put("data", page);

}

@RequestMapping("/info/{id}")

public R info(@PathVariable("id") Long id, HttpServletRequest request){

logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);

ChongwujiyangEntity chongwujiyang = chongwujiyangService.selectById(id);

if(chongwujiyang !=null){

ChongwujiyangView view = new ChongwujiyangView();

BeanUtils.copyProperties( chongwujiyang , view );

dictionaryService.dictionaryConvert(view, request);

return R.ok().put("data", view);

}else {

return R.error(511,"查不到数据");

}

}

@RequestMapping("/save")

public R save(@RequestBody ChongwujiyangEntity chongwujiyang, HttpServletRequest request){

logger.debug("save方法:,,Controller:{},,chongwujiyang:{}",this.getClass().getName(),chongwujiyang.toString());

String role = String.valueOf(request.getSession().getAttribute("role"));

if(false)

return R.error(511,"永远不会进入");

Wrapper<ChongwujiyangEntity> queryWrapper = new EntityWrapper<ChongwujiyangEntity>()

.eq("chongwujiyang_name", chongwujiyang.getChongwujiyangName())

.eq("chongwujiyang_types", chongwujiyang.getChongwujiyangTypes())

.eq("chongwujiyang_delete", chongwujiyang.getChongwujiyangDelete())

;

logger.info("sql语句:"+queryWrapper.getSqlSegment());

ChongwujiyangEntity chongwujiyangEntity = chongwujiyangService.selectOne(queryWrapper);

if(chongwujiyangEntity==null){

chongwujiyang.setChongwujiyangClicknum(1);

chongwujiyang.setChongwujiyangDelete(1);

chongwujiyang.setInsertTime(new Date());

chongwujiyang.setCreateTime(new Date());

chongwujiyangService.insert(chongwujiyang);

return R.ok();

}else {

return R.error(511,"表中有相同数据");

}

}

@RequestMapping("/update")

public R update(@RequestBody ChongwujiyangEntity chongwujiyang, HttpServletRequest request) throws NoSuchFieldException, ClassNotFoundException, IllegalAccessException, InstantiationException {

logger.debug("update方法:,,Controller:{},,chongwujiyang:{}",this.getClass().getName(),chongwujiyang.toString());

ChongwujiyangEntity oldChongwujiyangEntity = chongwujiyangService.selectById(chongwujiyang.getId());

String role = String.valueOf(request.getSession().getAttribute("role"));

if("".equals(chongwujiyang.getChongwujiyangPhoto()) || "null".equals(chongwujiyang.getChongwujiyangPhoto())){

chongwujiyang.setChongwujiyangPhoto(null);

}

chongwujiyangService.updateById(chongwujiyang);

return R.ok();

}

@RequestMapping("/delete")

public R delete(@RequestBody Integer[] ids, HttpServletRequest request){

logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());

List<ChongwujiyangEntity> oldChongwujiyangList =chongwujiyangService.selectBatchIds(Arrays.asList(ids));

ArrayList<ChongwujiyangEntity> list = new ArrayList<>();

for(Integer id:ids){

ChongwujiyangEntity chongwujiyangEntity = new ChongwujiyangEntity();

chongwujiyangEntity.setId(id);

chongwujiyangEntity.setChongwujiyangDelete(2);

list.add(chongwujiyangEntity);

}

if(list != null && list.size() >0){

chongwujiyangService.updateBatchById(list);

}

return R.ok();

}

@RequestMapping("/batchInsert")

public R save( String fileName, HttpServletRequest request){

logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);

Integer yonghuId = Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId")));

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

try {

List<ChongwujiyangEntity> chongwujiyangList = new ArrayList<>();

Map<String, List<String>> seachFields= new HashMap<>();

Date date = new Date();

int lastIndexOf = fileName.lastIndexOf(".");

if(lastIndexOf == -1){

return R.error(511,"该文件没有后缀");

}else{

String suffix = fileName.substring(lastIndexOf);

if(!".xls".equals(suffix)){

return R.error(511,"只支持后缀为xls的excel文件");

}else{

URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);

File file = new File(resource.getFile());

if(!file.exists()){

return R.error(511,"找不到上传文件,请联系管理员");

}else{

List<List<String>> dataList = PoiUtil.poiImport(file.getPath());

dataList.remove(0);

for(List<String> data:dataList){

ChongwujiyangEntity chongwujiyangEntity = new ChongwujiyangEntity();

chongwujiyangList.add(chongwujiyangEntity);

}

chongwujiyangService.insertBatch(chongwujiyangList);

return R.ok();

}

}

}

}catch (Exception e){

e.printStackTrace();

return R.error(511,"批量插入数据异常,请联系管理员");

}

}

@IgnoreAuth

@RequestMapping("/list")

public R list(@RequestParam Map<String, Object> params, HttpServletRequest request){

logger.debug("list方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));

CommonUtil.checkMap(params);

PageUtils page = chongwujiyangService.queryPage(params);

List<ChongwujiyangView> list =(List<ChongwujiyangView>)page.getList();

for(ChongwujiyangView c:list)

dictionaryService.dictionaryConvert(c, request);

return R.ok().put("data", page);

}

@RequestMapping("/detail/{id}")

public R detail(@PathVariable("id") Long id, HttpServletRequest request){

logger.debug("detail方法:,,Controller:{},,id:{}",this.getClass().getName(),id);

ChongwujiyangEntity chongwujiyang = chongwujiyangService.selectById(id);

if(chongwujiyang !=null){

chongwujiyang.setChongwujiyangClicknum(chongwujiyang.getChongwujiyangClicknum()+1);

chongwujiyangService.updateById(chongwujiyang);

ChongwujiyangView view = new ChongwujiyangView();

BeanUtils.copyProperties( chongwujiyang , view );

dictionaryService.dictionaryConvert(view, request);

return R.ok().put("data", view);

}else {

return R.error(511,"查不到数据");

}

}

@RequestMapping("/add")

public R add(@RequestBody ChongwujiyangEntity chongwujiyang, HttpServletRequest request){

logger.debug("add方法:,,Controller:{},,chongwujiyang:{}",this.getClass().getName(),chongwujiyang.toString());

Wrapper<ChongwujiyangEntity> queryWrapper = new EntityWrapper<ChongwujiyangEntity>()

.eq("chongwujiyang_name", chongwujiyang.getChongwujiyangName())

.eq("chongwujiyang_types", chongwujiyang.getChongwujiyangTypes())

.eq("chongwujiyang_clicknum", chongwujiyang.getChongwujiyangClicknum())

.eq("chongwujiyang_delete", chongwujiyang.getChongwujiyangDelete())

;

logger.info("sql语句:"+queryWrapper.getSqlSegment());

ChongwujiyangEntity chongwujiyangEntity = chongwujiyangService.selectOne(queryWrapper);

if(chongwujiyangEntity==null){

chongwujiyang.setChongwujiyangDelete(1);

chongwujiyang.setInsertTime(new Date());

chongwujiyang.setCreateTime(new Date());

chongwujiyangService.insert(chongwujiyang);

return R.ok();

}else {

return R.error(511,"表中有相同数据");

}

}

}

相关知识

基于Java+SpringBoot+Vue前后端分离的宠物领养系统
基于JAVA+SpringBoot+Vue的前后端分离的宠物领养系统
基于SpringBoot的网上宠物店系统
基于SpringBoot+Vue+MySQL的网上宠物店系统
基于Java+SpringBoot+Vue前后端分离的宠物领养系统平台
基于Java+SpringBoot+Vue宠物领养救助平台设计和实现
【开题报告】Java基于SSM的网上宠物店商城系统
基于SpringBoot+Vue可爱多宠物店管理系统设计和实现(源码+LW+部署讲解)
网上宠物店系统
基于SSM的网上宠物店商城交易系统

网址: 基于java+springboot+vue的网上宠物店系统 https://m.mcbbbk.com/newsview863267.html

所属分类:萌宠日常
上一篇: 192Java基于SpringB
下一篇: 网上宠物商店不如开【圣宠】宠物店