基于SpringBoot+Vue的宠物领养饲养交流管理平台设计与实现

简介: 基于SpringBoot+Vue的宠物领养饲养交流管理平台设计与实现

系统功能结构图

具体实现

系统功能模块

宠物领养饲养交流管理平台,在系统首页可以查看首页、宠物领养、饲料购买、宠物论坛、宠物资讯、个人中心、后台管理、购物车等内容,如图5-1所示。

图5-1系统首页界面图


用户注册,在用户注册页面通过填写账号、密码、姓名、手机、邮箱、身份证等信息完成用户注册,如图5-2所示。


2aac4aceba73d8085ea781ef4ca2fc17_446fa1ec7f27cc436047c14b7742c2e0.jpeg


图5-2用户注册界面图


宠物领养,在宠物领养页面可以查看宠物编号、宠物名称、宠物种类、宠物性别、宠物年龄、账号、姓名、宠物照片等信息,进行领养,如图5-3所示。

d88026208247f1dfc40d77095283a203_e3f16f1bc515ab7640d185de3f88adc7.jpeg

图5-3宠物领养界面图


饲料购买,在饲料购买页面可以查看饲料名称、适用宠物、饲料种类、饲料配料、出厂公司、饲料图片、价格、点击次数等信息,进行添加到购物车,如图5-4所示。


24c2b750e50f1e5f8fba8d6aaee23226_a1aa992feaaef443dd2cdf907a836bb1.jpeg


图5-4饲料购买界面图


宠物论坛,在宠物论坛页面通过填写标题、类型、内容等信息进行发布帖子,如图5-5所示。

9bd7d7a06e7714fa470bd02a12175d15_13e49524660b4843751f5bcfa411c502.jpeg

图5-5宠物论坛界面图

个人中心,在个人中心页面通过填写账号、密码、姓名、性别、手机、邮箱、身份证等信息进行更新信息,根据需要对我的发布、我的订单、我的地址、我的收藏进行相对应操作,如图5-6所示。

图5-6个人中心界面图

购物车,在购物车页面可以查看购买商品、价格、数量、总价等信息,如图5-7所示。

图5-7购物车界面图


管理员功能模块

管理员登录,管理员通过输入用户、密码、角色等信息进行系统登录,如图5-8所示。

图5-8管理员登录界面图

管理员登录进入宠物领养饲养交流管理平台可以查看首页、个人中心、用户管理、宠物领养管理、宠物种类管理、领养详情管理、饲料购买管理、宠物论坛、系统管理、订单管理等内容,如图5-9所示。

图5-9管理员功能界面图

用户管理,在用户管理页面可以查看索引、账号、姓名、性别、手机、邮箱、身份证、照片等信息,并可根据需要进行修改或删除等操作,如图5-10所示。

图5-10用户管理界面图

宠物领养管理,在宠物领养管理页面可以查看索引、宠物编号、宠物名称、宠物种类、宠物性别、宠物年龄、账号、姓名、宠物照片等信息,并可根据需要进行查看评论、修改或删除等操作,如图5-12所示。

图5-12宠物领养管理界面图

宠物种类管理,在宠物种类管理页面可以查看索引、种类等信息,并可根据需要进行修改或删除等操作,如图5-13所示。

图5-13宠物种类管理界面图

领养详情管理,在领养详情管理页面可以查看索引、宠物编号、宠物名称、宠物种类、宠物年龄、账号、姓名、领养时间、领养地点、审核回复、审核状态、审核等信息,并可根据需要进行修改或删除等操作,如图5-14所示。

图5-14领养详情管理界面图

饲料购买管理,在饲料购买管理页面可以查看索引、饲料名称、适用宠物、饲料种类、饲料配料、出厂公司、饲料图片、价格等信息,并可根据需要进行查看评论、修改或删除等操作,如图5-15所示。

图5-15饲料购买管理界面图

宠物论坛,在宠物论坛页面可以查看索引、帖子标题、用户名、状态等信息,并可根据需要进行修改或删除等操作,如图5-16所示。

图5-16宠物论坛界面图

系统管理,在轮播图管理页面可以查看索引、名称、值等信息,并可根据需要对宠物资讯进行操作,如图5-17所示。

图5-17系统管理界面图

订单管理,在已支付订单页面可以查看索引、订单编号、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、支付类型、状态、地址等信息,并可根据需要对已退款订单、已完成订单、已发货订单、未支付订单、已取消订单进行相对应操作,如图5-18所示。


07586fac5d9ce2e8bb4adac141952818_a84b4bb2596e92e25e227e00f4b85dc1.jpeg


图5-18订单管理界面图


用户后台功能模块

用户登录进入宠物领养饲养交流管理平台可以查看首页、个人中心、宠物领养管理、领养详情管理、订单管理等内容,如图5-19所示。

图5-19用户后台功能界面图


个人中心,在个人中心页面通过填写账号、姓名、性别、手机、邮箱、身份证、照片等信息进行修改,如图5-20所示。

图5-20个人中心界面图

宠物领养管理,在宠物领养管理页面可以查看索引、宠物编号、宠物名称、宠物种类、宠物性别、宠物年龄、账号、姓名、宠物照片等信息,并可根据需要进行修改或删除等操作,如图5-21所示。

图5-21宠物领养管理界面图


订单管理,在已完成订单页面可以查看索引、订单编号、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、支付类型、状态、地址等信息,并可根据需要对已退款订单、已发货订单、未支付订单、已取消订单、已支付订单进行相对应操作,如图5-22所示。


693b59af15d280f8f1584fc1e9cad629_a5a0edd088ed1cad3599e16ad7b2d040.jpeg


图5-22订单管理界面图


代码参考

@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
   UsersEntity user = userService.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());
   return R.ok().put("token", token);
}
  @Override
  public String generateToken(Long userid,String username, String tableName, String role) {
    TokenEntity tokenEntity = this.selectOne(new EntityWrapper<TokenEntity>().eq("userid", userid).eq("role", role));
    String token = CommonUtil.getRandomString(32);
    Calendar cal = Calendar.getInstance();   
      cal.setTime(new Date());   
      cal.add(Calendar.HOUR_OF_DAY, 1);
    if(tokenEntity!=null) {
      tokenEntity.setToken(token);
      tokenEntity.setExpiratedtime(cal.getTime());
      this.updateById(tokenEntity);
    } else {
      this.insert(new TokenEntity(userid,username, tableName, role, token, cal.getTime()));
    }
    return token;
  }
/**
 * 权限(Token)验证
 */
@Component
public class AuthorizationInterceptor implements HandlerInterceptor {
    public static final String LOGIN_TOKEN_KEY = "Token";
    @Autowired
    private TokenService tokenService;
  @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    //支持跨域请求
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with,request-source,Token, Origin,imgType, Content-Type, cache-control,postman-token,Cookie, Accept,authorization");
        response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
  // 跨域时会首先发送一个OPTIONS请求,这里我们给OPTIONS请求直接返回正常状态
  if (request.getMethod().equals(RequestMethod.OPTIONS.name())) {
          response.setStatus(HttpStatus.OK.value());
            return false;
        }
        IgnoreAuth annotation;
        if (handler instanceof HandlerMethod) {
            annotation = ((HandlerMethod) handler).getMethodAnnotation(IgnoreAuth.class);
        } else {
            return true;
        }
        //从header中获取token
        String token = request.getHeader(LOGIN_TOKEN_KEY);
        /**
         * 不需要验证权限的方法直接放过
         */
        if(annotation!=null) {
          return true;
        }
        TokenEntity tokenEntity = null;
        if(StringUtils.isNotBlank(token)) {
          tokenEntity = tokenService.getTokenEntity(token);
        }
        if(tokenEntity != null) {
          request.getSession().setAttribute("userId", tokenEntity.getUserid());
          request.getSession().setAttribute("role", tokenEntity.getRole());
          request.getSession().setAttribute("tableName", tokenEntity.getTablename());
          request.getSession().setAttribute("username", tokenEntity.getUsername());
          return true;
        }
    PrintWriter writer = null;
    response.setCharacterEncoding("UTF-8");
    response.setContentType("application/json; charset=utf-8");
    try {
        writer = response.getWriter();
        writer.print(JSONObject.toJSONString(R.error(401, "请先登录")));
    } finally {
        if(writer != null){
            writer.close();
        }
    }
//        throw new EIException("请先登录", 401);
    return false;
    }
}


论文参考

相关文章
|
5月前
|
Java 数据库连接 应用服务中间件
基于springboot的母婴健康交流系统
本平台旨在为新手父母提供专业、系统的婴幼儿健康知识与交流空间,整合权威资源,解决育儿信息碎片化与误导问题,支持经验分享与情感互助,助力科学育儿。
|
4月前
|
人工智能 Java 关系型数据库
基于springboot的画品交流系统
本项目构建基于Java+Vue+SpringBoot+MySQL的画品交流系统,旨在解决传统艺术交易信息不透明、流通受限等问题,融合区块链与AI技术,实现画品展示、交易、鉴赏与社交一体化,推动艺术数字化转型与文化传播。
|
9月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
885 1
|
5月前
|
前端开发 安全 Java
基于springboot+vue开发的会议预约管理系统
一个完整的会议预约管理系统,包含前端用户界面、管理后台和后端API服务。 ### 后端 - **框架**: Spring Boot 2.7.18 - **数据库**: MySQL 5.6+ - **ORM**: MyBatis Plus 3.5.3.1 - **安全**: Spring Security + JWT - **Java版本**: Java 11 ### 前端 - **框架**: Vue 3.3.4 - **UI组件**: Element Plus 2.3.8 - **构建工具**: Vite 4.4.5 - **状态管理**: Pinia 2.1.6 - **HTTP客户端
710 4
基于springboot+vue开发的会议预约管理系统
|
6月前
|
前端开发 JavaScript Java
基于springboot+vue开发的校园食堂评价系统【源码+sql+可运行】【50809】
本系统基于SpringBoot与Vue3开发,实现校园食堂评价功能。前台支持用户注册登录、食堂浏览、菜品查看及评价发布;后台提供食堂、菜品与评价管理模块,支持权限控制与数据维护。技术栈涵盖SpringBoot、MyBatisPlus、Vue3、ElementUI等,适配响应式布局,提供完整源码与数据库脚本,可直接运行部署。
367 6
基于springboot+vue开发的校园食堂评价系统【源码+sql+可运行】【50809】
|
5月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
499 2
|
4月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
421 137
|
8月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
967 0
|
8月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
9月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1231 78