基于微信小程序的剧本杀游玩一体化平台

收藏关注不迷路!!

🌟文末获取源码+数据库🌟

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人


前言

剧本杀游玩一体化平台是一个全面的在线服务平台,旨在提供一个集剧本发现、角色体验和社交互动于一体的环境。该平台涵盖了后台管理员和店家,小程序端用户两份大部分,确保了从剧本创作、预约到游戏体验和反馈收集的完整流程。管理员端具备强大的管理和内容维护功能,包括用户管理、剧本分类、角色安排等,以保障平台的高效运行。店家则聚焦于提供高质量的剧本服务和顾客体验,让店家能够方便地管理剧本和预约,同时跟踪游戏结果和顾客反馈。小程序端为用户带来便捷的游戏体验,允许玩家轻松预约剧本、探索角色和线索,并与其他玩家互动,享受沉浸式的剧情推理乐趣。整个平台的设计致力于简化组织和参与剧本杀的复杂性,提供一个无缝且充满乐趣的游玩环境。

详细视频演示

文章底部名片,联系我看更详细的演示视频

一、项目介绍

开发语言:Java
框架:springboot
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql 5.7(一定要5.7版本)
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven3.3.9

小程序框架:uniapp
小程序开发软件:HBuilder X
小程序运行软件:微信开发者

————————————————

二、功能介绍

系统整功能如下图4-1所示:
在这里插入图片描述

图 4-1 系统总体功能模块图

三、核心代码

部分代码:


package com.example.controller;

import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {

    @Resource
    private CaiwuService caiwuService;

    @PostMapping
    public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
        caiwuService.add(caiwu);
           return Result.success(caiwu);
    }
	
	

    @PostMapping("/deleteList")
    public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
        caiwuService.deleteList(caiwu.getList());
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Long id) {
        caiwuService.delete(id);
        return Result.success();
    }

    @PutMapping
    public Result update(@RequestBody CaiwuVo caiwu) {
        caiwuService.update(caiwu);
        return Result.success();
    }

    @GetMapping("/{id}")
    public Result<Caiwu> detail(@PathVariable Integer id) {
        Caiwu caiwu = caiwuService.findById(id);
        return Result.success(caiwu);
    }

    @GetMapping
    public Result<List<Caiwu>> all() {
        return Result.success(caiwuService.list());
    }

    @PostMapping("/page")
    public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
        return Result.success(caiwuService.findPage(caiwuVo));
    }
	    @PostMapping("/login")
    public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
        if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
            throw new CustomException(ResultCode.PARAM_LOST_ERROR);
        }
        Caiwu login = caiwuService.login(caiwu);
//        if(!login.getStatus()){
//            return Result.error("1001","状态限制,无法登录系统");
//        }
        if(login != null) {
            HashMap hashMap = new HashMap();
            hashMap.put("user", login);
            Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
            String token = JwtUtil.creatToken(map);
            hashMap.put("token", token);
            return Result.success(hashMap);
        }else {
            return Result.error();
        }
    }
    @PutMapping("/updatePassword")
    public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
        Caiwu caiwu = caiwuService.findById(info.getId());
        String oldPassword = SecureUtil.md5(info.getMima());
        if (!oldPassword.equals(caiwu.getMima())) {
            return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
        }
        info.setMima(SecureUtil.md5(info.getNewPassword()));
        Caiwu caiwu1 = new Caiwu();
        BeanUtils.copyProperties(info, caiwu1);
        caiwuService.update(caiwu1);
        return Result.success();
    }
}

数据库参考

-- MySQL dump 10.13  Distrib 5.7.31, for Linux (x86_64)
--
-- Host: localhost    Database: springboothk3o5t38
-- ------------------------------------------------------
-- Server version	5.7.31

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Current Database: `springboothk3o5t38`
--

/*!40000 DROP DATABASE IF EXISTS `springboothk3o5t38`*/;

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `springboothk3o5t38` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;

USE `springboothk3o5t38`;

--
-- Table structure for table `config`
--

DROP TABLE IF EXISTS `config`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `config` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(100) NOT NULL COMMENT '配置参数名称',
  `value` varchar(100) DEFAULT NULL COMMENT '配置参数值',
  `url` varchar(500) DEFAULT NULL COMMENT 'url',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT='配置文件';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `config`
--

LOCK TABLES `config` WRITE;
/*!40000 ALTER TABLE `config` DISABLE KEYS */;
INSERT INTO `config` VALUES (1,'picture1','upload/picture1.jpg',NULL),(2,'picture2','upload/picture2.jpg',NULL),(3,'picture3','upload/picture3.jpg',NULL);
/*!40000 ALTER TABLE `config` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `dianjia`
--

DROP TABLE IF EXISTS `dianjia`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `dianjia` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `dianjiamingcheng` varchar(200) NOT NULL COMMENT '账号',
  `mima` varchar(200) NOT NULL COMMENT '密码',
  `shangjiaxingming` varchar(200) NOT NULL COMMENT '商家姓名',
  `touxiang` longtext COMMENT '头像',
  `xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
  `youxiang` varchar(200) NOT NULL COMMENT '邮箱',
  `dianhua` varchar(200) NOT NULL COMMENT '电话',
  `dizhi` varchar(200) DEFAULT NULL COMMENT '地址',
  PRIMARY KEY (`id`),
  UNIQUE KEY `dianjiamingcheng` (`dianjiamingcheng`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 COMMENT='店家';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `dianjia`
--

LOCK TABLES `dianjia` WRITE;
/*!40000 ALTER TABLE `dianjia` DISABLE KEYS */;
INSERT INTO `dianjia` VALUES (21,'2024-02-18 14:57:49','账号1','123456','商家姓名1','upload/dianjia_touxiang1.jpg','','773890001@qq.com','13823888881','地址1'),(22,'2024-02-18 14:57:49','账号2','123456','商家姓名2','upload/dianjia_touxiang2.jpg','','773890002@qq.com','13823888882','地址2'),(23,'2024-02-18 14:57:49','账号3','123456','商家姓名3','upload/dianjia_touxiang3.jpg','','773890003@qq.com','13823888883','地址3'),(24,'2024-02-18 14:57:49','账号4','123456','商家姓名4','upload/dianjia_touxiang4.jpg','','773890004@qq.com','13823888884','地址4'),(25,'2024-02-18 14:57:49','账号5','123456','商家姓名5','upload/dianjia_touxiang5.jpg','','773890005@qq.com','13823888885','地址5'),(26,'2024-02-18 14:57:49','账号6','123456','商家姓名6','upload/dianjia_touxiang6.jpg','','773890006@qq.com','13823888886','地址6'),(27,'2024-02-18 14:57:49','账号7','123456','商家姓名7','upload/dianjia_touxiang7.jpg','','773890007@qq.com','13823888887','地址7'),(28,'2024-02-18 14:57:49','云梦探案馆','1','王辉','upload/dianjia_touxiang8.jpg','','773890008@qq.com','13823888888','地址8');
/*!40000 ALTER TABLE `dianjia` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `discussjuben`
--

DROP TABLE IF EXISTS `discussjuben`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `discussjuben` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `refid` bigint(20) NOT NULL COMMENT '关联表id',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  `avatarurl` longtext COMMENT '头像',
  `nickname` varchar(200) DEFAULT NULL COMMENT '用户名',
  `content` longtext NOT NULL COMMENT '评论内容',
  `score` double DEFAULT NULL COMMENT '评分',
  `reply` longtext COMMENT '回复内容',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='剧本评论表';
/*!40101 SET character_set_client = @saved_cs_client */;


四、效果图

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

五、文章目录

目 录

1 绪 论 1
1.1研究的背景与意义 1
1.2课题研究现状 1
1.3系统研究的主要内容 2
1.4论文结构 2
2 开发技术介绍 3
2.1 微信开发者工具 3
2.2 MySQL 介绍 3
2.3 springboot框架 3
2.4 JAVA技术 3
2.5 B/S架构 4
3 系统分析 5
3.1系统可行性分析 5
3.1.1技术可行性 5
3.1.2经济可行性 5
3.1.3操作可行性 5
3.2系统性能需求分析 6
3.3系统功能分析 6
3.4系统流程的分析 8
3.4.1 用户管理的流程 8
3.4.2 个人中心管理流程 9
3.4.3 登录流程 9
4系统设计 10
4.1 软件功能模块设计 10
4.2 数据库设计 10
4.2.1 概念模型设计 10
4.2.2 物理模型设计 11
5系统详细设计 19
5.1小程序端功能实现 19
5.1.1登录 19
5.1.2小程序首页的实现 20
5.1.3个人中心 22
5.2后台模块实现 23
5.2.1管理员功能实现 24
5.2.2店家功能实现 26
6系统测试 29
结 论 30
参考文献 31
致 谢 32

六 、源码获取

下方名片联系我即可!!


大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值