基于SpringBoot+微信小程序的壁纸小程序

news/2024/7/20 2:13:51 标签: 小程序, spring boot, 微信小程序

基于SpringBoot+微信小程序的壁纸小程序

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

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


一、项目背景介绍:

为什么要做壁纸表情包头像的小程序?我们有很多app,每款app都是需要上传头像,壁纸那些,用自拍照可以,但是不可能每次都用自己的自拍照那些来充当吧,届时就有很多自己创作头像,壁纸表情包的博主就出现了,那么这些博主也不是白给的吧,毕竟这是需要用时间精力去创作的。

我们的壁纸表情包头像小程序,对于有创作和有粉丝的博主来说小程序是一个很好展示自己的平台。创建了小程序之后,对接流量主,作品上传到小程序上就可以多端同步体现。

二、项目技术简介:

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

三、系统功能模块介绍:

功能模块图

四、数据库设计:

1:‘管理员’(admins)

字段名类型默认值列注释
idbigintNULL主键ID
user_namevarcharNULL用户名(select)
pass_wordvarcharNULL密码
head_imgvarcharNULL头像(img)
nick_namevarcharNULL姓名
create_timedatetimeNULL创建时间

2:‘用户收藏管理’(collects)

字段名类型默认值列注释
idbigintNULL收藏编号
user_idbigintNULL用户编号
wall_idbigintNULL壁纸编号
create_timedatetimeNULL创建时间

3:‘评论管理’(comment)

字段名类型默认值列注释
idbigintNULL评论编号
wall_idbigintNULL壁纸编号
user_idbigintNULL用户编号
infovarcharNULL评论内容
create_timedatetimeNULL评论时间

4:‘壁纸分类管理’(types)

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

5:‘用户管理’(users)

字段名类型默认值列注释
idbigintNULL用户编号
usernamevarcharNULL用户名
passwordvarcharNULL密码
nick_namevarcharNULL昵称
header_imgvarcharNULL头像
create_timedatetimeNULL创建时间

6:‘壁纸管理’(wallpaper)

字段名类型默认值列注释
idbigintNULL壁纸编号
img_urlvarcharNULL壁纸图片(img)
type_idbigintNULL壁纸分类
create_timedatetimeNULL创建时间
titlevarcharNULL壁纸标题

五、功能模块:

  1. 壁纸分类:不同的壁纸有不同的分类,用户可以通过分类快速查找自己喜欢的壁纸

    壁纸分类

  2. 壁纸详情:用户可以在不知详情界面看到更加清洗的壁纸,对其进行收藏,评论等操作

    壁纸详情

  3. 用户登录注册:用户登录注册之后可以对自己的个人信息或者自己收藏的壁纸进行历史的查看

    用户登录注册

  4. 后台管理:后台管理主要是对壁纸信息,壁纸分类信息,管理员信息,用户信息进行统一的管理操作

    后台管理

六、代码示例:

壁纸分类
async typesFindList() {
				let res = await indexApi.typesFindList({})
				this.tabOneList = res.data
				this.leftText = this.tabOneList[0].typeName
				this.currentTypeId = this.tabOneList[0].id
				this.wallpaperFindList()
			},
			async wallpaperFindList() {
				let param = {}
				param.typeId = this.currentTypeId
				if (this.keyword) param.title = this.keyword
				let res = await indexApi.wallpaperFindList(param)
				this.$refs.waterfallsFlowRef.refresh();
				this.imgList = res.data
				
			},
壁纸详情
addComment(content) {
				console.log(content)
				if (!this.isLogin) {
					Util.showMyToast("尚未登录")
					uni.navigateTo({
						url: '/pages/login/login'
					})
					return
				}
				let param = {}
				param.userId = this.userInfo.id
				param.info = content
				param.wallId = this.imgId
				this.commentSaveUpdate(param)
			},
用户登录注册
async usersFindList(loginForm) {
				let res = await loginApi.usersFindList(loginForm)
				if (res.data.length > 0) {
					let obj = res.data[0]
					app.globalData.userInfo = obj
					app.globalData.userIsLogin = true
					uni.switchTab({
						url: '/pages/index/index'
					})
				} else {
					Util.showMyToast("用户名或密码有误!")
				}
			},
后台管理
@PostMapping
    public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
        if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
            return ReturnMsg.error("用户名或密码错误!");
        }
        AdminsDTO adminsDTO = new AdminsDTO();
        adminsDTO.setUserName(param.get("username"));
        adminsDTO.setPassWord(param.get("password"));
        QueryWrapper<AdminsDTO> adminsDTOQueryWrapper = new QueryWrapper<>(adminsDTO);
        adminsDTOQueryWrapper.last("limit 1");
        AdminsDTO adminDTOS = adminsService.getOne(adminsDTOQueryWrapper);
        if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
        Map<String, Object> map = new HashMap<>();
        map.put("avatar", StrUtil.isNotBlank(adminDTOS.getHeadImg()) ? adminDTOS.getHeadImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
        map.put("introduction", adminDTOS.getNickName() + ",你好!");
        map.put("name", adminDTOS.getNickName());
        map.put("roles", Arrays.asList("admin"));
        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);
    }

七、项目总结:

本次开发的系统整体界面还是比较清晰简明,功能上面考虑得比较全,几乎可以满足用户使用要求。尽管我对这次的毕设付出了许多的努力,但是程序还是有很多不足的地方,系统界面整体感觉还行,但是字体字号的选取上面还是有些不符合现实审美,在程序的CSS样式编码上面,我还有许多不熟悉的地方,虽然经过反复的测试与调试选中了现在这样的程序界面,但是我还是明显感觉到自己对一些常用CSS样式的不熟悉,编码过程中,我还要多次进行资料查看才知道。另外我编写的代码写作不是很规范,可读性比较差,幸运的是,我最终还是实现了系统中所要求的功能。

八、源码获取:

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

的地方,虽然经过反复的测试与调试选中了现在这样的程序界面,但是我还是明显感觉到自己对一些常用CSS样式的不熟悉,编码过程中,我还要多次进行资料查看才知道。另外我编写的代码写作不是很规范,可读性比较差,幸运的是,我最终还是实现了系统中所要求的功能。

八、源码获取:

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

链接点击直达:下载链接


http://www.niftyadmin.cn/n/209568.html

相关文章

HDU1536/POJ2960 S-Nim

题目大意 有一个集合SSS&#xff0c;其元素个数为kkk。两个人玩mmm轮游戏&#xff0c;每轮游戏有nnn堆石子&#xff0c;每次游戏两个人轮流在这nnn堆石子中选一堆&#xff0c;从这一堆中取走若干个石子&#xff0c;取走石子的个数必须为SSS集合中的一个元素的值。双方都采用最…

【kubernetes云原生】k8s资源管理命令与Namespace使用详解

目录 一、前言 二、k8s概述 三、k8s常用操作管理命令 3.1 kubectl 命令用法 3.2 常用控制台管理命令演示 3.2.1 获取全部节点信息 3.2.2 获取当前集群下全部pod 3.2.3 查看某个pod信息 3.2.4 获取当前集群下的所有namespace信息 3.2.5 查看当前集群下已创建的资源 3…

音视频开发的一些学习分享(建议收藏!!!)

前言&#xff1a; 大家好&#xff0c;挺久没有写原创文章了&#xff0c;本次文章主要是给大家分享音视频的入门学习路线&#xff0c;虽然我之前写过&#xff0c;但是这次我会结合最新接触到不同层次的人来做一个总结分享&#xff01;当然还是以入门为主&#xff0c;技术点都是当…

光度立体法检测原理讲解

光度立体法检测 图像辐照度 决定场景表面片辐射的因素有两个: 1.在场景表面片的照明 投在某一特定表面片上的照明量取决于该表面片在场景中相对于光源的分布位置 2.表面片反射的入射照明部分 在某一特定方向上被表面片反射的入射照明部分取决于表面材料的光学特性 反射类…

Notion AI 辅助生成文本

随着 ChatGPT的火热&#xff0c;很多的Ai工具如雨后的春笋不断地涌现出来&#xff0c;其中Notion AI也算是其中的佼佼者了。 Notion AI 是一款智能化的办公软件&#xff0c;它可以帮助用户更高效地管理任务&#xff0c;提高工作效率。Notion AI 提供了许多强大的功能&#xff…

设计模式-单例模式

文章目录一、概述二、饿汉式三、懒汉式1. 非线程安全2. 线程安全一、概述 当一个全局使用的类频繁地创建与销毁&#xff0c;为了控制实例的数量&#xff0c;节省系统资源&#xff0c;我们可以保证该类只有一个实例&#xff0c;并提供一个访问它的全局访问点。 单例模式是 Jav…

C++笔记——第十二篇 二叉搜索树

目录 一、二叉搜索树概念 二、二叉搜索树操作 1. 二叉搜索树的查找 2. 二叉搜索树的插入 a. 树为空&#xff0c;则直接插入&#xff0c;返回true b. 树不空&#xff0c;按二叉搜索树性质查找插入位置&#xff0c;插入新节点 3. 二叉搜索树的删除 情况b&#xff1a;删除该结点…

【C++】多态(上)

文章目录1. 多态概念2.多态的定义和实现1.多态的构成条件无法使用父类对象调用不满足多态条件的调用2. 虚函数虚函数的重写/覆盖虚函数重写的例外例题变形题3.C11 override 和finalfinaloverrride4.重载 、覆盖(重写)、隐藏(重定义)的对比5. 抽象类6. 多态原理虚函数表多态的原…