基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

🍅文末获取项目下载方式🍅


一、项目背景介绍:

开发背景介绍:

随着社交媒体的普及和移动互联网的快速发展,校友之间的交流和联系变得越来越便捷。然而,传统的社交平台往往缺乏专注于校友之间交流的特点,无法提供更加个性化和专业化的功能。

因此,我们基于JAVA+SpringBoot+Vue+uni-app技术栈,开发了一款面向微信小程序的校友交流平台。该平台旨在为校友们提供一个便捷、高效、安全的交流平台,促进校友之间的互动和合作。

该平台具有以下主要特点和功能:

  1. 微信小程序端:通过微信小程序作为客户端,提供了便捷的登录和使用体验,用户可以通过微信账号直接登录平台。
  2. 前后端分离架构:采用前后端分离架构,前端使用Vue和uni-app框架实现,后端使用SpringBoot框架提供强大的后台支持,实现了前后端分离开发,提高了系统的扩展性和可维护性。
  3. 校友信息管理:用户可以在平台上完善个人信息,包括学校、专业、毕业年份等,方便其他校友查找和联系。
  4. 动态发布和浏览:用户可以发布自己的动态,分享自己的校园经历、工作成果等,其他校友可以浏览和评论,促进信息共享和交流。
  5. 校友圈子和群组:平台支持创建校友圈子和群组,校友们可以根据不同的兴趣、专业或地域等因素加入相应的圈子和群组,方便校友之间的交流和互助。
  6. 消息通知和私信功能:平台支持消息通知和私信功能,校友们可以及时接收到系统通知和其他校友的私信,方便交流和沟通。

通过这个校友交流平台,我们希望能够打破时空限制,让校友们可以更加便捷地找到自己的同窗好友,分享彼此的成长和经验,促进校友之间的合作和发展。

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。
    Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis-Plus:MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。
  6. smart:微信小程序,小程序的一种,英文名Wechat Mini Program,是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用。
    全面开放申请后,主体类型为企业、政府、媒体、其他组织或个人的开发者,均可申请注册小程序。微信小程序、微信订阅号、微信服务号、微信企业号是并行的体系。
    微信小程序是一种不用下载就能使用的应用,也是一项创新,经过将近两年的发展,已经构造了新的微信小程序开发环境和开发者生态。微信小程序也是这么多年来中国IT行业里一个真正能够影响到普通程序员的创新成果,已经有超过150万的开发者加入到了微信小程序的开发,与我们一起共同发力推动微信小程序的发展,微信小程序应用数量超过了一百万,覆盖200多个细分的行业,日活用户达到两个亿,微信小程序还在许多城市实现了支持地铁、公交服务。微信小程序发展带来更多的就业机会,2017年小程序带动就业104万人,社会效应不断提升。

三、系统功能模块介绍:

xyl-modules

四、数据库设计:

1:‘管理员’(admins)

字段名类型默认值列注释
idbigintNULL管理员编号
ad_namevarcharNULL昵称
ad_usernamevarcharNULL账号
ad_passwordvarcharNULL密码
ad_headervarcharNULL头像

2:‘贴吧评论表’(comments)

字段名类型默认值列注释
idbigintNULL贴吧编号
from_stu_idbigintNULL评论学生编号
contenttextNULL评论内容
to_stu_idbigintNULL回复人编号
parent_idbigintNULL父级评论编号
img_listtextNULL图片列表
create_timedatetimeNULL评论时间
typeintNULL类型

3:‘反馈表’(feedback)

字段名类型默认值列注释
idbigintNULL反馈编号
tree_statusintNULL树木状态[0:已种植,1:发芽阶段,2:苗期阶段,3:成长阶段,4:植物阶段,5:开发阶段,6:生殖阶段]
apply_idbigintNULL申请编号
tree_imgvarcharNULL树木图片
infovarcharNULL备注信息
create_timedatetimeNULL反馈时间
user_idbigintNULL用户ID
tree_idbigintNULL树木ID

4:likes(likes)

字段名类型默认值列注释
idbigintNULL主键ID
user_idbigintNULL用户ID
common_idbigintNULL评论ID
create_timedatetimeNULL创建时间

5:‘树木申请’(tree_apply)

字段名类型默认值列注释
idbigintNULL申请编号
user_idbigintNULL用户ID
tree_idbigintNULL树木编号
create_timedatetimeNULL申请时间

6:‘树木分类’(tree_type)

字段名类型默认值列注释
idbigintNULL分类编号
type_namevarcharNULL分类名称
create_timedatetimeNULL创建时间

7:‘树木’(trees)

字段名类型默认值列注释
idbigintNULL树木编号
tree_namevarcharNULL树木名称
tree_imgvarcharNULL树木图片
tree_infotextNULL树木简介
tree_locationvarcharNULL种植地点
tree_conservevarcharNULL养护机构
tree_scoreintNULL所需积分
tree_img_listtextNULL图片列表
tree_type_idbigintNULL所属分类
statusintNULL状态[0:上架,1:下架]
create_timedatetimeNULL创建时间

8:‘校友信息’(users)

字段名类型默认值列注释
idbigintNULL用户编号
namevarcharNULL姓名
head_imgvarcharNULL头像
ageintNULL年龄
sexintNULL性别[0:男,1:女]
graduate_timedateNULL毕业时间
infovarcharNULL个人简介
usernamevarcharNULL账号
passwordvarcharNULL密码
scoreintNULL当前积分
create_timedatetimeNULL创建时间
statusintNULL状态
graduate_imgvarcharNULL毕业证书

五、功能模块:

  • 用户端小程序-校友登录/注册(登录获取积分):通过注册新账户可以登录小程序,登录会获取一定的积分,在积分达到一定量的时候可申请植树

    cb626c6fddb5d11f9f0f5591d5eff4a

    713ee71710757beeaed8b8e4a4da898

  • 用户端小程序-个人中心:在个人中心中可以修改自己的个人信息,并且还能联系系统管理员对系统提出自己的看法

    1f682d5c76e2756a4638a64e80deed7

  • 用户端小程序-个人信息管理:在个人信息管理界面用户可以管理自己的个人信息

    260d38ffe6704ce5c00f0a4209f9544

  • 用户端小程序-联系我们:联系系统管理员对系统提出自己的看法

22c38d2db403945ee77bfde7e1266c6

  • 用户端小程序-林内贴吧详情:在林贴吧中用户可以发布自己的动态,分享自己的校园经历、工作成果等,其他校友可以浏览和评论,促进信息共享和交流

f5f790ae9c3b5bca806d711d1d7fce5

5fb85431bc4c861204c0935b1223783

ae511e023044dac1038f5e3e3e5cfb1

  • 用户端小程序-植树排行榜:

37d725dfe037138ea99a8272fac9185

  • 用户端小程序-树木详情:

    0113f35f90736de0af0f3cc6ce2335a

  • 用户端小程序-植树反馈

d244f6befc06fd0eb4dea65e1372edf

  • 用户端小程序-校友林:

dd9affa39d9b49c97815cc60f4efbd6

  • 用户端小程序-树木列表:

  • PC端后台管理-树木申请管理:管理员在后台管理系统中可以管理小程序端校友申请的种植的树木信息

be7093039065a5f3d4fbc65edce9fe6

  • PC端后台管理-树木分类管理:管理员在后台管理系统中可以管理小程序中用户搜索和查询的树木分类,在这里设置的树木分类也会间接影响树木管理,因为每个树木都应该有属于自己的分类

7870e8c9c7eb2d334cd0b7890907548

  • PC端后台管理-树木管理:管理员在后台管理系统中可以管理小程序内校友可以种植与查看的树木

14625b4decca933aaa72fcdf0c246c0

682ebd8a0e2ea2de376d68ac312ff58

  • PC端后台管理-校友信息管理:管理员在后台管理系统中可以管理小程序校友的基本信息

34c1029bcac5c37d4ef3fc4cc72fe66

  • PC端后台管理-贴吧信息管理:管理员在后台管理系统中可以管理小程序内的贴吧信息

28adb348d0c9e85e0fc458c2056f0bf

  • PC端后台管理-反馈管理:管理员在后台管理系统中可以管理小程序内校友提出的反馈信息

98c9007a7124eac5bfa63387c4daa9f

  • PC端后台管理-管理员信息管理:管理员在后台管理系统中可以管理小程序的后端管理员的基本信息

    a54f568601ccfd05ba367f3ba2a2823

六、代码示例:

/**
生成验证码
 */
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{
 AjaxResult ajax = AjaxResult.success();
 boolean captchaEnabled = configService.selectCaptchaEnabled();
 ajax.put("captchaEnabled", captchaEnabled);
 if (!captchaEnabled)
 {
 return ajax;
 } // 保存验证码信息
 String uuid = IdUtils.simpleUUID();
 String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;
 String capStr = null, code = null;
 BufferedImage image = null;
 // 生成验证码
 String captchaType = RuoYiConfig.getCaptchaType();
 if ("math".equals(captchaType))
 {
 String capText = captchaProducerMath.createText();
 capStr = capText.substring(0, capText.lastIndexOf("@"));
 code = capText.substring(capText.lastIndexOf("@") + 1);
 image = captchaProducerMath.createImage(capStr);
 }
 else if ("char".equals(captchaType))
 {
 capStr = code = captchaProducer.createText();
 image = captchaProducer.createImage(capStr);
 }
 redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
 // 转换流信息写出
 FastByteArrayOutputStream os = new FastByteArrayOutputStream();
 try
 {
 ImageIO.write(image, "jpg", os);
 }
 catch (IOException e)
 {
 return AjaxResult.error(e.getMessage());
 }
 ajax.put("uuid", uuid);
 ajax.put("img", Base64.encode(os.toByteArray()));
 return ajax;

}
/**
通用的本地文件上传
@param multipartFile 文件对象@return 文件访问链接URL
 */
@PostMapping("/file")
public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {
 // 文件后缀
 String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
 File savePathFile = new File(newTomcatFolder);
 if (!savePathFile.exists()) {
 // 若不存在该目录,则创建目录
 savePathFile.mkdir();
 }
 // 通过UUID生成唯一文件名
 String filename = UUID.randomUUID() + "." + suffix;
 try {
 // 将文件保存指定目录
 file.transferTo(new File(newTomcatFolder + filename));
 } catch (Exception e) {
 e.printStackTrace();
 return SimpleResponse.error("保存文件异常");
 }
 // 返回访问链接
 return SimpleResponse.success(newTomcatHost + filename);
}
/**用户登录
 */
@PostMapping("/login")
public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
 if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
 return ReturnMsg.error("用户名或密码错误!");
 }
 ManageDTO manageDTO = new ManageDTO();
 manageDTO.setUserName(param.get("username"));
 manageDTO.setPassWord(param.get("password"));
 QueryWrapper<ManageDTO> manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);
 manageDTOQueryWrapper.last("limit 1");
 ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);
 if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
 Map<String, Object> map = new HashMap<>();
 map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
 map.put("introduction", adminDTOS.getName() + ",你好!");
 map.put("name", adminDTOS.getName());
 map.put("roles", Arrays.asList("admin"));
 map.put("type", adminDTOS.getStatus());
 Map<String, String> returnMap = new HashMap<>();
 String uuid = UUID.randomUUID().toString();
 returnMap.put("token", uuid);
 userInfoMap.put(uuid, JSON.toJSONString(map));
 return ReturnMsg.ok(returnMap);
}

七、项目总结:

通过对基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台的程序时,
我在开发期间,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,
程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,
借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让我开发的基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台得以正常运行。
基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:
(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。
(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级,让开发的基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台中的相关网站更贴合。
(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,
同时对服务器上资源占用的比例进行降低。
基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台的开发一方面是对自身专业知识技能进行最终考核,另一方面也是让自己学会独立解决程序开发过程中所遇到的问题,掌握将理论知识运用于程序开发实践的方法。
基于JAVA+SpringBoot+Vue+uni-app的前后端分离的微信小程序校友交流平台的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻

链接点击直达:下载链接

  • 35
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值