✨作者主页 :IT研究室✨
个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。
文章目录
一、前言
随着技术的快速发展,特别是云计算、大数据等技术的应用,宠物行业也迎来了数字化转型的机遇。据统计,国内宠物店管理系统市场正处于快速发展阶段,但多数宠物店对此类系统的认识和了解有限,许多宠物店还在采用传统的纸质管理方式,存在效率低下、信息不透明等问题。
现有的宠物店管理系统普遍存在一些问题,如功能单一、用户体验不佳、数据化和智能化水平不高等。这些问题制约了宠物店管理系统在提升宠物店运营效率和服务质量方面的潜力。
本课题旨在设计并实现一个基于Spring Boot和Vue的宠物店管理系统,该系统将集成宠物信息管理、库存管理、订单处理、用户管理等多个模块,提供全面的宠物店管理解决方案。系统将采用现代化的信息技术,如Spring Boot框架和Vue.js前端框架,实现宠物店管理的数字化、智能化和移动化。
在宠物管理系统中,管理员负责系统用户账户的创建与维护、宠物信息的录入与更新、库存管理、订单处理、用户管理、以及系统公告的发布与更新;医生或兽医可以记录宠物的诊疗信息、管理宠物健康档案、跟踪宠物的健康状况;用户则能够浏览宠物信息、预约诊疗服务、购买宠物用品、接收健康提示和通知。系统通过这些功能模块的整合,旨在为宠物主人、兽医和管理员提供一个全面、互动的宠物健康管理平台。
本课题的研究具有重要的理论意义和实际意义。从理论角度来看,它为宠物店管理领域提供了新的研究思路,即如何利用信息技术提升宠物店的管理效率和服务质量。从实际角度来看,该系统的应用将有助于宠物店实现规范化、标准化管理,提高服务质量,吸引更多客户,促进宠物店的发展。同时,系统的推广应用也将推动宠物行业的数字化转型,为宠物店提供更便捷、高效的管理工具。
二、开发环境
- 开发语言:Java/Python
- 数据库:MySQL
- 系统架构:B/S
- 后端:SpringBoot/SSM/Django/Flask
- 前端:Vue
三、系统界面展示
- 宠物管理系统界面展示:
用户-就诊预约:
医生-产看预约信息:
医生-病例登记:
四、代码参考
- 项目实战代码参考:
java(贴上部分代码)
@RestController
@Controller
@RequestMapping("/chongwurenling")
public class ChongwurenlingController {
private static final Logger logger = LoggerFactory.getLogger(ChongwurenlingController.class);
@Autowired
private ChongwurenlingService chongwurenlingService;
@Autowired
private TokenService tokenService;
@Autowired
private DictionaryService dictionaryService;
//级联表service
@Autowired
private YonghuService yonghuService;
/**
* 后端列表
*/
@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(StringUtil.isEmpty(role))
return R.error(511,"权限为空");
else if("用户".equals(role))
params.put("yonghuId",request.getSession().getAttribute("userId"));
if(params.get("orderBy")==null || params.get("orderBy")==""){
params.put("orderBy","id");
}
PageUtils page = chongwurenlingService.queryPage(params);
//字典表数据转换
List<ChongwurenlingView> list =(List<ChongwurenlingView>)page.getList();
for(ChongwurenlingView 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);
ChongwurenlingEntity chongwurenling = chongwurenlingService.selectById(id);
if(chongwurenling !=null){
//entity转view
ChongwurenlingView view = new ChongwurenlingView();
BeanUtils.copyProperties( chongwurenling , view );//把实体数据重构到view中
//级联表
YonghuEntity yonghu = yonghuService.selectById(chongwurenling.getYonghuId());
if(yonghu != null){
BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段
view.setYonghuId(yonghu.getId());
}
//修改对应字典表字段
dictionaryService.dictionaryConvert(view, request);
return R.ok().put("data", view);
}else {
return R.error(511,"查不到数据");
}
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody ChongwurenlingEntity chongwurenling, HttpServletRequest request){
logger.debug("save方法:,,Controller:{},,chongwurenling:{}",this.getClass().getName(),chongwurenling.toString());
String role = String.valueOf(request.getSession().getAttribute("role"));
if(StringUtil.isEmpty(role))
return R.error(511,"权限为空");
else if("用户".equals(role))
chongwurenling.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
Wrapper<ChongwurenlingEntity> queryWrapper = new EntityWrapper<ChongwurenlingEntity>()
.eq("chongwurenling_name", chongwurenling.getChongwurenlingName())
.eq("chongwulingyang_types", chongwurenling.getChongwulingyangTypes())
.eq("yonghu_id", chongwurenling.getYonghuId())
.eq("jieshu_types", chongwurenling.getJieshuTypes())
;
logger.info("sql语句:"+queryWrapper.getSqlSegment());
ChongwurenlingEntity chongwurenlingEntity = chongwurenlingService.selectOne(queryWrapper);
if(chongwurenlingEntity==null){
chongwurenling.setCreateTime(new Date());
chongwurenlingService.insert(chongwurenling);
return R.ok();
}else {
return R.error(511,"表中有相同数据");
}
}
/**
* 后端修改
*/
@RequestMapping("/update")
public R update(@RequestBody ChongwurenlingEntity chongwurenling, HttpServletRequest request){
logger.debug("update方法:,,Controller:{},,chongwurenling:{}",this.getClass().getName(),chongwurenling.toString());
String role = String.valueOf(request.getSession().getAttribute("role"));
if(StringUtil.isEmpty(role))
return R.error(511,"权限为空");
else if("用户".equals(role))
chongwurenling.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
//根据字段查询是否有相同数据
Wrapper<ChongwurenlingEntity> queryWrapper = new EntityWrapper<ChongwurenlingEntity>()
.notIn("id",chongwurenling.getId())
.andNew()
.eq("chongwurenling_name", chongwurenling.getChongwurenlingName())
.eq("chongwulingyang_types", chongwurenling.getChongwulingyangTypes())
.eq("yonghu_id", chongwurenling.getYonghuId())
.eq("jieshu_types", chongwurenling.getJieshuTypes())
;
logger.info("sql语句:"+queryWrapper.getSqlSegment());
ChongwurenlingEntity chongwurenlingEntity = chongwurenlingService.selectOne(queryWrapper);
if("".equals(chongwurenling.getChongwurenlingPhoto()) || "null".equals(chongwurenling.getChongwurenlingPhoto())){
chongwurenling.setChongwurenlingPhoto(null);
}
if(chongwurenlingEntity==null){
// String role = String.valueOf(request.getSession().getAttribute("role"));
// if("".equals(role)){
// chongwurenling.set
// }
chongwurenlingService.updateById(chongwurenling);//根据id更新
return R.ok();
}else {
return R.error(511,"表中有相同数据");
}
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Integer[] ids){
logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
chongwurenlingService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
/**
* 批量上传
*/
@RequestMapping("/batchInsert")
public R save( String fileName){
logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);
try {
List<ChongwurenlingEntity> chongwurenlingList = 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());//读取xls文件
dataList.remove(0);//删除第一行,因为第一行是提示
for(List<String> data:dataList){
//循环
ChongwurenlingEntity chongwurenlingEntity = new ChongwurenlingEntity();
// chongwurenlingEntity.setChongwurenlingName(data.get(0)); //标题 要改的
// chongwurenlingEntity.setChongwulingyangTypes(Integer.valueOf(data.get(0))); //类型 要改的
// chongwurenlingEntity.setChongwurenlingPhoto("");//照片
// chongwurenlingEntity.setYonghuId(Integer.valueOf(data.get(0))); //发布用户 要改的
// chongwurenlingEntity.setJieshuTypes(Integer.valueOf(data.get(0))); //是否找到主人 要改的
// chongwurenlingEntity.setChongwurenlingContent("");//照片
// chongwurenlingEntity.setCreateTime(date);//时间
chongwurenlingList.add(chongwurenlingEntity);
//把要查询是否重复的字段放入map中
}
//查询是否重复
chongwurenlingService.insertBatch(chongwurenlingList);
return R.ok();
}
}
}
}catch (Exception e){
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));
// 没有指定排序字段就默认id倒序
if(StringUtil.isEmpty(String.valueOf(params.get("orderBy")))){
params.put("orderBy","id");
}
PageUtils page = chongwurenlingService.queryPage(params);
//字典表数据转换
List<ChongwurenlingView> list =(List<ChongwurenlingView>)page.getList();
for(ChongwurenlingView 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);
ChongwurenlingEntity chongwurenling = chongwurenlingService.selectById(id);
if(chongwurenling !=null){
//entity转view
ChongwurenlingView view = new ChongwurenlingView();
BeanUtils.copyProperties( chongwurenling , view );//把实体数据重构到view中
//级联表
YonghuEntity yonghu = yonghuService.selectById(chongwurenling.getYonghuId());
if(yonghu != null){
BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段
view.setYonghuId(yonghu.getId());
}
//修改对应字典表字段
dictionaryService.dictionaryConvert(view, request);
return R.ok().put("data", view);
}else {
return R.error(511,"查不到数据");
}
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody ChongwurenlingEntity chongwurenling, HttpServletRequest request){
logger.debug("add方法:,,Controller:{},,chongwurenling:{}",this.getClass().getName(),chongwurenling.toString());
Wrapper<ChongwurenlingEntity> queryWrapper = new EntityWrapper<ChongwurenlingEntity>()
.eq("chongwurenling_name", chongwurenling.getChongwurenlingName())
.eq("chongwulingyang_types", chongwurenling.getChongwulingyangTypes())
.eq("yonghu_id", chongwurenling.getYonghuId())
.eq("jieshu_types", chongwurenling.getJieshuTypes())
;
logger.info("sql语句:"+queryWrapper.getSqlSegment());
ChongwurenlingEntity chongwurenlingEntity = chongwurenlingService.selectOne(queryWrapper);
if(chongwurenlingEntity==null){
chongwurenling.setCreateTime(new Date());
// String role = String.valueOf(request.getSession().getAttribute("role"));
// if("".equals(role)){
// chongwurenling.set
// }
chongwurenlingService.insert(chongwurenling);
return R.ok();
}else {
return R.error(511,"表中有相同数据");
}
}
}
java(贴上部分代码)
@RequestMapping("users")
@RestController
public class UsersController {
@Autowired
private UsersService usersService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UsersEntity user = usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
if(user==null || !user.getPassword().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
R r = R.ok();
r.put("token", token);
r.put("role",user.getRole());
r.put("userId",user.getId());
return r;
}
/**
* 注册
*/
@IgnoreAuth
@PostMapping(value = "/register")
public R register(@RequestBody UsersEntity user){
// ValidatorUtils.validateEntity(user);
if(usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
usersService.insert(user);
return R.ok();
}
/**
* 退出
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
UsersEntity user = usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
if(user==null) {
return R.error("账号不存在");
}
user.setPassword("123456");
usersService.update(user,null);
return R.ok("密码已重置为:123456");
}
/**
* 列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,UsersEntity user){
EntityWrapper<UsersEntity> ew = new EntityWrapper<UsersEntity>();
PageUtils page = usersService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/list")
public R list( UsersEntity user){
EntityWrapper<UsersEntity> ew = new EntityWrapper<UsersEntity>();
ew.allEq(MPUtil.allEQMapPre( user, "user"));
return R.ok().put("data", usersService.selectListView(ew));
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
UsersEntity user = usersService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Integer id = (Integer)request.getSession().getAttribute("userId");
UsersEntity user = usersService.selectById(id);
return R.ok().put("data", user);
}
/**
* 保存
*/
@PostMapping("/save")
public R save(@RequestBody UsersEntity user){
// ValidatorUtils.validateEntity(user);
if(usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
user.setPassword("123456");
usersService.insert(user);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody UsersEntity user){
// ValidatorUtils.validateEntity(user);
usersService.updateById(user);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
usersService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
五、论文参考
- 计算机毕业设计选题推荐-宠物管理系统论文参考:
六、系统视频
宠物管理系统项目视频:
计算机毕业设计选题推荐-宠物管理系统-Java/Python
结语
计算机毕业设计选题推荐-宠物管理系统-Java/Python项目实战
大家可以帮忙点赞、收藏、关注、评论啦~
源码获取:⬇⬇⬇