💗博主介绍:✌全网粉丝15W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者,计算机毕设实战导师。目前专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌
💗主要服务内容:免费功能设计、选题定题、开题报告、任务书、程序开发、论文编写和辅导、论文降重、程序讲解、答辩辅导等,欢迎咨询~
👇🏻 精彩专栏 推荐订阅👇🏻
计算机毕业设计精品项目案例(持续更新)
🌟文末获取源码+数据库+文档🌟
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以和学长沟通,希望帮助更多的人
一.前言
随着移动互联网的普及和校园生活节奏的加快,学生们在日常学习生活中面临许多琐碎事务的处理,如外卖购买、快递取送、打印文件等。这些事务往往消耗大量时间和精力,导致学生缺乏足够的时间专注于学习和其他重要活动。同时,跑腿服务作为一种新兴的服务模式,在社会各个领域得到了广泛应用,也逐渐在校园内兴起,成为解决学生生活困扰的有效方式。因此,开发校园跑腿小程序,旨在通过优化功能模块和提升服务质量,满足学生便捷、高效的服务需求,提高他们的生活品质。
校园跑腿小程序主要服务于在校大学生,解决他们在日常生活中遇到的琐碎事务。该程序通过微信等社交平台的小程序形式,方便学生随时随地发起跑腿需求,并由服务人员接单并完成。系统采用微信小程序、SpringBoot架构技术,微信端以小程序页面呈现给用户,结合后台Java语言使页面更加完善,后台使用MySQL数据库进行数据存储。该微信小程序主要设计并完成了管理过程中的用户注册登录、个人信息修改、用户、跑腿员、充值信息、任务类型、跑腿任务、跑腿领单、完成订单、评价信息、入账信息等功能。该微信小程序操作简便,界面设计简洁,不但可以基本满足本行业的日常管理工作,同时又可以有效减少人员成本和时间成本,为用户提供更加便捷、高效的服务,满足其日益增长的需求。
二.技术环境
jdk版本:1.8 及以上
ide工具:Eclipse或者 IDEA,微信小程序开发工具
数据库: mysql5.7 (必须5.7)
编程语言: Java
java框架:SpringBoot
maven: 3.6.1
详细技术:HTML+CSS+JAVA+SpringBoot+MYSQL+VUE+MAVEN+微信开发工具
三.功能设计
校园跑腿小程序综合网络空间开发设计要求。目的是将校园跑腿管理通过网络平台将传统管理方式转换为在网上操作,方便快捷、安全性高、交易规范做了保障,目标明确。校园跑腿小程序可以将功能划分为用户、跑腿员和管理员功能。
(1)管理员用例图如下所示:
(2)跑腿员用例图如下所示:
(3)用户用例图如下所示:
系统功能结构图如下所示:
跑腿小程序主要分为用户、跑腿人员、管理员三个角色
1.用户(小程序端):
用户可以通过填入账户名称、密码、姓名,手机号等信息进行注册,注册后可以通过账户、密码进行登录;登录后可以发布自己所需内容,等待代办人员接单。
(1)登录模块:用户选择用账号密码登录,获取名称、电话、地址。
(2)分类模块:用户可以查看各个任务类型。
(3)发布任务模块:用户可以点击所选任务类型发布,进行所需订单任务的发布(如地址,时间等),通过填写相应的信息以及选择业务类型以进行发布,等待接单。
(4)订单模块:用户可以查看之前的发布的订单,正在进行的订单和全部订单并实时查看任务状态,最终确认订单完成,还可进行订单评价。
(5)用户个人中心模块:此模块包含用户的个人信息,用户可以修改个人信息(如地址,电话等)。
(6)对完成任务的代办人员进行评价
(7)同城论坛,用户可以在论坛里讨论,并询问求答
2.跑腿人员(小程序端):
用户可以提交个人信息和相关证件(如姓名,身份证号等),等待平台管理员审核后,即可接单完成任务。
(1)申请模块:用户可以从个人中心里找到申请成为代跑人员点击申请,提交个人信息和相关证件,等待平台审核后,即可接单完成其他客户的任务。
(2)接单模块:代办人员可以点开任务并进行接单,并按要求完成所接的任务。
(3)订单评价管理模块:代办人员可以查看订单的评价信息。
3.管理员
(1)管理员对客户申请代办人员,不良(违反法律道德)任务的发布,论坛的讨论,用户的评价,任务信息,接单信息,订单信息,代办人员半途舍弃任务的惩罚和客户遇到的问题等进行管理,维护平台的正常运行。
(2)统计分析图表
(3)其他后台管理模块,不过多罗列。
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
四.数据设计
数据库概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。而且Mysql数据库是自我保护能力比较强的数据库,在系统中的局部E-R图,如图所示:
五.部分效果展示
5.1学生微信端功能实现效果
当用户登录微信小程序的网址后,首先看到的就是首页界面。在这里,用户能够看到“随心赚”跑腿小程序的低部导航条显示首页、跑腿任务、公告信息、同城论坛、我的等,微信小程序界面如图所示:
当进入微信小程序时可以通过注册来登录,只需要根据相应的提示,输入用户名、姓名、性别、头像、手机、密码问题、密保答案、微信昵称等信息即可。用户注册界面如图所示:
用户点击跑腿任务,在跑腿任务页面输入标题、图片、任务类型、取货地点、收件地点、费用、单价、物品重量、订单状况、账号、手机、评论数、收藏数等信息,提交即可完成发布跑腿任务等操作,如图所示:
用户点击同城论坛,在同城论坛可以查看帖子标题、用户名、状态、是否置顶、置顶时间等信息,还可以对其他帖子点赞、收藏或评论等,如图所示:
用户点击我的页面,在我的页面可以对 充值信息、跑腿任务、跑腿领单、完成任务、评价信息、我的收藏、客服中心、我的发帖,进行详细操作,如图所示:
5.2跑腿员微信端功能实现效果
当跑腿员微信小程序的网址后,首先看到的就是首页界面。在这里,商家能够看到“随心赚”跑腿小程序的低部导航条显示首页、跑腿任务、公告信息、同城论坛、我的等,微信小程序界面如图所示:
这是跑腿员登录界面,跑腿员在登录页面填写账号或者密码、角色,点击登录,如图所示:
跑腿员点击我的页面,在我的页面可以对跑腿领单、完成订单、评价信息、入账信息、我的收藏、客服中心、我的发帖、修改密码,进行详细操作,如图所示:
5.3管理员服务端功能实现效果
管理员进入主页面,主要功能包括对系统首页、用户管理、跑腿员管理、充值信息管理、任务类型管理、跑腿任务管理、跑腿领单管理、完成订单管理、评价信息管理、入账信息管理、同城论坛、系统管理、我的信息等进行操作。管理员主页面如图所示:
充值信息功能在视图层(view层)进行交互,比如点击“添加”按钮或填写充值信息表单。这些充值信息动作被视图层捕获并作为请求发送给相应的控制器层(control1er层)。控制器接收到这些请求后,调用服务层(service层)以执行相关的业务逻辑,例如验证输入数据的有效性和与数据库的交互。服务层处理完这些逻辑后,进一步与数据访问对象层(DAO层)交互,后者负责具体的数据操作如搜索、添加、更新或删除充值信息,并将操作结果返回给控制器。最终,控制器根据这些结果更新视图层,以便充值信息功能可以看到最新的信息或相应的操作反馈。在充值信息页面的输入栏中输入账号、姓名进行搜索,可以查看到充值信息详细信息,并根据需要进行修改或者删除等操作;如图所示:
管理员点击跑腿员管理:在跑腿员管理页面,可以对跑腿账号、跑腿姓名、性别、头像、联系电话、账户金额、证件图片、状态、审核回复、审核状态等信息,进行查询、添加、审核或者删除跑腿员信息等操作,如图所示:
管理员点击跑腿任务管理:在跑腿任务管理页面,可以对标题、图片、任务类型、取货地点、收件地点、费用、单价、物品重量、订单状况、账号、手机、评论数、收藏数等信息,进行查询、添加或者删除跑腿任务等操作,如图所示:
管理员点击跑腿领单管理:在跑腿领单管理页面,可以对标题、图片、任务类型、费用、订单状态、账号、跑腿账号、跑腿姓名、联系电话、取货地点、收件地点、接单时间等信息,进行查询或者删除跑腿领单信息等操作,如图所示:
管理员点击完成订单管理:在完成订单管理页面,可以对标题、图片、费用、账号、跑腿账号、跑腿姓名、联系电话、完成时间等信息,进行查询或者删除完成订单信息等操作,如图所示:
管理员点击评价信息管理:在评价信息管理页面,可以对标题、图片、费用、评价、账号、跑腿账号、跑腿姓名、联系电话、评价时间、账户余额等信息,进行查询或者删除评价信息等操作,如图所示:
部分功能代码
/**
* 上传文件
*/
@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 `paotuilingdan`
--
DROP TABLE IF EXISTS `paotuilingdan`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `paotuilingdan` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`biaoti` varchar(200) DEFAULT NULL COMMENT '标题',
`tupian` longtext COMMENT '图片',
`renwuleixing` varchar(200) DEFAULT NULL COMMENT '任务类型',
`zhanghujine` int(11) DEFAULT NULL COMMENT '费用',
`dingdanzhuangtai` varchar(200) NOT NULL COMMENT '订单状态',
`zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
`paotuizhanghao` varchar(200) NOT NULL COMMENT '跑腿账号',
`paotuixingming` varchar(200) NOT NULL COMMENT '跑腿姓名',
`lianxidianhua` varchar(200) NOT NULL COMMENT '联系电话',
`quhuodidian` varchar(200) DEFAULT NULL COMMENT '取货地点',
`shoujiandidian` varchar(200) DEFAULT NULL COMMENT '收件地点',
`jiedanshijian` date DEFAULT NULL COMMENT '接单时间',
`sfsh` varchar(200) DEFAULT '待审核' COMMENT '是否审核',
`shhf` longtext COMMENT '审核回复',
`userid` bigint(20) DEFAULT NULL COMMENT '用户id',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=69 DEFAULT CHARSET=utf8 COMMENT='跑腿领单';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Table structure for table `paotuirenwu`
--
DROP TABLE IF EXISTS `paotuirenwu`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `paotuirenwu` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`biaoti` varchar(200) DEFAULT NULL COMMENT '标题',
`tupian` longtext COMMENT '图片',
`renwuleixing` varchar(200) DEFAULT NULL COMMENT '任务类型',
`quhuodidian` varchar(200) DEFAULT NULL COMMENT '取货地点',
`shoujiandidian` varchar(200) DEFAULT NULL COMMENT '收件地点',
`zhanghujine` int(11) DEFAULT NULL COMMENT '费用',
`danjia` int(11) NOT NULL COMMENT '单价',
`wupinzhongliang` int(11) NOT NULL COMMENT '物品重量',
`dingdanzhuangkuang` varchar(200) NOT NULL COMMENT '订单状况',
`zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
`shouji` varchar(200) DEFAULT NULL COMMENT '手机',
`paotuirenwu` longtext COMMENT '跑腿任务',
`clicktime` datetime DEFAULT NULL COMMENT '最近点击时间',
`discussnum` int(11) DEFAULT '0' COMMENT '评论数',
`storeupnum` int(11) DEFAULT '0' COMMENT '收藏数',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=59 DEFAULT CHARSET=utf8 COMMENT='跑腿任务';
/*!40101 SET character_set_client = @saved_cs_client */;
为什么选择我们
大学毕业那年,曾经有幸协助指导老师做过毕业设计课题分类、论文初选(查看论文的格式)、代码刻录等打杂的事情,也帮助过同界N多同学完成过毕业设计工作,毕业后在一家互联网大厂工作8年,先后从事Java前后端开发、系统架构设计等方面的工作,有丰富的编程能力和水平,也在工作之余指导过别人完成过一些毕业设计的工作。2016年至今,团队已指导上万名学生顺利通过毕业答辩,目前是csdn特邀作者、CSDN全栈领域优质创作者,博客之星、掘金/华为云/B站/知乎等平台优质作者,计算机毕设实战导师,专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎咨询~✌
最后
💕💕
最新计算机毕业设计选题篇-选题推荐
小程序毕业设计精品项目案例-200套
Java毕业设计精品项目案例-200套
Python毕业设计精品项目案例-200套
大数据毕业设计精品项目案例-200套
💟💟如果大家有任何疑虑,欢迎在下方位置详细交流。