基于微信小程序的问卷调查系统设计与实现

💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。
👇🏻 精彩专栏 推荐订阅👇🏻
计算机毕业设计精品项目案例(持续更新)
🌟文末获取源码+数据库+文档🌟
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以和学长沟通,希望帮助更多的人

一.前言

在这里插入图片描述

随着移动互联网技术的飞速发展和智能手机的普及,微信作为国内领先的即时通讯工具,其用户基数日益庞大。微信小程序以其无需下载安装、即用即走的便捷性,迅速成为连接用户与服务的新型应用生态。在传统问卷调查领域,纸质或简单在线问卷方式存在数据收集效率低、处理繁琐等问题,难以满足现代社会高效信息收集与处理的需求。因此,设计和实现一个基于微信小程序的问卷调查系统显得尤为重要。该系统旨在利用微信小程序平台的广泛覆盖和便捷操作,提升问卷调查的效率和参与度,同时支持多样化的互动和实时反馈,为教育、市场研究以及社会科学等领域的数据收集工作提供有力支持。

微信小程序问卷调查系统是在微信的应用平台。为防止出现兼容性及稳定性问题,开发工具选择的是微信开发者工具和Idea,用户与后台之间的数据存储主要通过MySQL。用户在使用应用时产生的数据通过 java等语言传递给数据库。通过此方式促进微信小程序问卷调查系统信息流动和数据传输效率,提供一个内容丰富、功能多样、易于操作的微信小程序问卷调查系统。


二.技术环境

jdk版本:1.8 及以上
ide工具:Eclipse或者 IDEA,微信小程序开发工具
数据库: mysql5.7 (必须5.7)
编程语言: Java
java框架:SpringBoot
maven: 3.6.1
详细技术:HTML+CSS+JAVA+SpringBoot+MYSQL+VUE+MAVEN+微信开发工具


三.功能设计

本系统采用前后端分离的方式进行设计,前台移动端的主体是用户、后台服务端的主体是管理员、调查人;其用例分别如下:
管理员用例图如图所示。
在这里插入图片描述

调查人用例图如图所示。
在这里插入图片描述
用户用例图如图所示。
在这里插入图片描述
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
在这里插入图片描述

四.数据设计

数据库概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。而且Mysql数据库是自我保护能力比较强的数据库,系统部分实体E-R图,如图所示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五.部分效果展示

5.1用户微信端功能实现效果

首先双击打开移动,连上网络之后会显示出本系统的登录界面,这是进入移动的第初始页面“登录”,能成功进入到该登录界面则代表移动开启是成功的,接下来就可以操作本系统所带有的其他所有的功能。用户登录界面如图所示。
在这里插入图片描述
移动首页是用户注册登录后进入的第一个界面,用户可通过移动端首页的最下面的那一行导航栏中的“首页、公告信息、问卷调查、我的”进入到相应的网页进行操作;点击“我的”进入我的页面,在我的页面可以对在线咨询、修改密码等进行详细操作。移动首页界面如图所示。
在这里插入图片描述

用户点击公告信息,在公告信息页面的搜索栏输入标题,进行查询,然后可以查看标题、分类名称、发布人、点击次数、收藏数、图片等信息,还可以点赞或者收藏等。如图所示。

在这里插入图片描述
用户点击“问卷调查”进入问卷列表页面,可选择对应问卷进行填报等操作。如图所示。
在这里插入图片描述

用户点击“我的”进入我的页面,在我的页面可以对在线咨询、修改密码等进行详细操作。如图所示。

在这里插入图片描述

5.2管理员服务端功能实现效果

管理员登录,通过登录页面填写用户名和密码等信息,点击登录操作,如图所示。

在这里插入图片描述

管理员登录进入系统可以查看系统首页、个人中心、用户管理、调查人管理、问卷调查管理、问卷题目管理、系统管理等功能进行详细操作。

管理员点击调查人管理;在调查人管理页面输入账号、姓名、性别、年龄、手机号、头像等信息,进行查询,添加或删除调查人信息等操作;如图所示。
在这里插入图片描述

管理员点击问卷调查管理,在问卷调查管理页面输入问卷调查名称、问卷调查时长(分钟)、问卷调查状态、账号等信息,进行查询,添加或删除问卷调查等操作;如图所示。
在这里插入图片描述

管理员点击问卷题目管理,在问卷题目管理页面对问卷调查、问卷题目名称、类型等信息,进行查询、添加或删除问卷题目等操作;如图所示。
在这里插入图片描述

管理员点击系统管理,在系统管理页面对轮播图管理、公告 信息、公告信息分类、在线咨询等信息,进行查询、添加或删除系统信息等操作;如图所示。
在这里插入图片描述

5.3调查人服务端功能实现效果

调查人注册登录,通过注册登录页面填写详细信息,点击注册登录操作,如图所示。

在这里插入图片描述

调查人登录进入系统可以查看系统首页、个人中心、问卷调查管理、问卷题目管理等功能进行详细操作,如图所示。
在这里插入图片描述

部分功能代码

	/**
	 * 上传文件
	 */
	@RequestMapping("/upload")
    @IgnoreAuth
	public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
		if (file.isEmpty()) {
			throw new EIException("上传文件不能为空");
		}
		String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
		File path = new File(ResourceUtils.getURL("classpath:static").getPath());
		if(!path.exists()) {
		    path = new File("");
		}
		File upload = new File(path.getAbsolutePath(),"/upload/");
		if(!upload.exists()) {
		    upload.mkdirs();
		}
		String fileName = new Date().getTime()+"."+fileExt;
        if(StringUtils.isNotBlank(type) && type.contains("_template")) {
            fileName = type + "."+fileExt;
            new File(upload.getAbsolutePath()+"/"+fileName).deleteOnExit();
        }
		File dest = new File(upload.getAbsolutePath()+"/"+fileName);
		file.transferTo(dest);
		if(StringUtils.isNotBlank(type) && type.equals("1")) {
			ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));
			if(configEntity==null) {
				configEntity = new ConfigEntity();
				configEntity.setName("faceFile");
				configEntity.setValue(fileName);
			} else {
				configEntity.setValue(fileName);
			}
			configService.insertOrUpdate(configEntity);
		}
		return R.ok().put("file", fileName);
	}

	/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(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);
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }

数据库参考


--
-- Table structure for table `exampaper`
--

DROP TABLE IF EXISTS `exampaper`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `exampaper` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `name` varchar(200) NOT NULL COMMENT '问卷调查名称',
  `time` int(11) NOT NULL COMMENT '调整时长(分钟)',
  `status` int(11) NOT NULL DEFAULT '0' COMMENT '问卷调查状态',
  `zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='问卷调查表';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Table structure for table `examquestion`
--

DROP TABLE IF EXISTS `examquestion`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `examquestion` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `paperid` bigint(20) NOT NULL COMMENT '所属问卷调查id(外键)',
  `papername` varchar(200) NOT NULL COMMENT '问卷调查名称',
  `questionname` varchar(200) NOT NULL COMMENT '问卷题目名称',
  `options` longtext COMMENT '选项,json字符串',
  `score` bigint(20) DEFAULT '0' COMMENT '分值',
  `answer` varchar(200) DEFAULT NULL COMMENT '正确答案',
  `analysis` longtext COMMENT '答案解析',
  `type` bigint(20) DEFAULT '0' COMMENT '问卷题目类型,0:单选题 1:多选题 2:判断题 3:填空题(暂不考虑多项填空)4:主观题',
  `sequence` bigint(20) DEFAULT '100' COMMENT '问卷题目排序,值越大排越前面',
  `zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 COMMENT='问卷题目';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Table structure for table `examrecord`
--

DROP TABLE IF EXISTS `examrecord`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `examrecord` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  `username` varchar(200) DEFAULT NULL COMMENT '用户名',
  `paperid` bigint(20) NOT NULL COMMENT '问卷调查id(外键)',
  `papername` varchar(200) NOT NULL COMMENT '问卷调查名称',
  `questionid` bigint(20) NOT NULL COMMENT '问卷题目id(外键)',
  `questionname` varchar(200) NOT NULL COMMENT '问卷题目名称',
  `options` longtext COMMENT '选项,json字符串',
  `score` bigint(20) DEFAULT '0' COMMENT '分值',
  `answer` varchar(200) DEFAULT NULL COMMENT '正确答案',
  `analysis` longtext COMMENT '答案解析',
  `ismark` bigint(20) DEFAULT '0' COMMENT '是否批卷',
  `type` bigint(20) DEFAULT '0' COMMENT '问卷题目类型,0:单选题 1:多选题 2:判断题 3:填空题(暂不考虑多项填空) 4:主观题',
  `myscore` bigint(20) NOT NULL DEFAULT '0' COMMENT '问卷题目得分',
  `myanswer` varchar(200) DEFAULT NULL COMMENT '考生答案',
  `zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='调整记录表';
/*!40101 SET character_set_client = @saved_cs_client */;

源码及文档获取

文章下方名片联系我即可~
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻

最新计算机毕业设计选题篇-选题推荐
小程序毕业设计精品项目案例-200套
Java毕业设计精品项目案例-200套
Python毕业设计精品项目案例-200套
大数据毕业设计精品项目案例-200套
💟💟如果大家有任何疑虑,欢迎在下方位置详细交流。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一点毕设

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值