具体实现截图
使用技术介绍
开发工具采用VSCode,前端采用Vue+ElementUI,后端采用Node.js,数据库采用MySQL。
小程序端运行软件 微信开发者工具/hbuiderx
数据库:mysql
数据库工具:Navicat/SQLyog都可以
Nodejs+Vue.js+Express -vscode
uni-app框架:使用Vue.js开发跨平台应用的前端框架,编写一套代码,可编译到Android、小程序等平台。
小程序框架以及目录结构介绍
小程序自身分为两个主要部分独立运行:view 模块和 service 模块。在开发者工具中,它们独立运行于不同的 webivew tag 中。
view 模块负责前端界面显示,它由 wxml 和 wxss 转换后代码以及微信提供相关辅助模块组成。 一个 view 模块对应一个 页面, 小程序支持同时多个 view 存在。
service 模块负责后台逻辑,它由 js 代码以及微信提供的相关辅助模块组成。 一个应用只有一个 service 进程,它同样也是一个页面。它在程序生命周期内后台运行,service 模块通过与 view 模块实现不同但接口格式一样的微信JSBridge 对象跟后台通信。
小程序需要使用微信开发者工具来进行开发,同时最常用的参考文档是微信小程序官方文档。在开发者工具中包含了模拟器、调试器等,内容很全面。也可以用云模式来在腾讯云进行后台开发。使得开发者不用搭建数据库等,专注于逻辑设计,简化后台设计,另外为了更好的展示小程序可以用一些工具插件,例如wx-charts和echarts等,这两个都可用于图形化展示统计数据。
软硬件平台要求
服务器系统:Windows操作系统;
客户端系统:Windows 操作系统。
小程序硬件环境需求并不是非常苛刻,服务器端和用户端都不需要太高的配置。目前主流的硬件配置足够满足运行条件。项目的体积不大,所需资源不多,推荐配置为,CPU达到1Ghz,内存达到2GB,磁盘空间达到500G,便可以流畅运行。
开发工具和技术简介
HBuilder 是基于HTML、js、css的等H5语法的开发技术,使得开发者很容易上手学习,里面涉及的数据绑定基于Vue语法涉及,在开发效率上也比传统的jquery快,当然HBuilder 也保留了对jquery的支持,两种语法可以结合项目的需要,可以混合开发。
VScode是我们最常用的网页编辑器,通过日常学习,我们基本熟练运用,在完成项目的过程中,我们可以更加节省时间。而且VScode包含很多插件并且免费,下载更加快捷方便,可以给我们提供很多便捷条件。运行的便捷给我提供很大帮助。
Nodejs语言
Node.js是一个完整的解析器,而且OS允许js来定义多种多样种类繁多的数据结构,从而处理各种运算,还准许js使用系统环境所提供的多种内置对象和方式做各类计算。当处在浏览器运行环境下时,js技术的用途是进行DOM相关的运算,在这个情况下,该环境便提供一个document类别的内置操作对象。而在node.js运行环境下的js的用途是对磁盘文件进行操作或者是对http服务器进行搭建,此时,node.js就相应提供了fs,http等系统内置对象。
Express不对node.js已有的特性进行二次抽象,只是在它之上扩展了Web应用所需的功能。丰富的HTTP工具以及来自Connect框架的中间件随取随用,创建强健、友好的API变得快速又简单。Express是Web开发人员最欢迎的Node.js框架之一,提供一系列强大特性帮助创建各种Web应用。
性能要求
性能要求指系统需要的存储容量,安全性,运行效率等方面。模块测试 ,测试每个模块的 程序 是否 有错 误; 组装测试 ,测试模块之 间的接口是否 正确 ;确认测试,测试 整个软件系统 是否满足用户 功能 和性 能的要求。
nodejs类核心代码部分展示
import { version } from '../../package.json'
import { Router } from 'express'
import { Op } from 'sequelize'
import toRes from '../lib/toRes'
import UsersModel from '../models/UsersModel'
import jwt from 'jsonwebtoken'
export default ({ config, db }) => {
let api = Router()
// 用户登录接口
api.post('/login', async (req, res) => {
try {
let userinfo = await UsersModel.findOne({ where: { username: req.query.username, password: req.query.password } })
if (userinfo === null) {
toRes.session(res, -1, '用户名或密码错误!')
return;
}
const token = jwt.sign(
{
id: userinfo.dataValues.id,
username: userinfo.dataValues.username,
role: userinfo.dataValues.role
},
config.jwtSecret,
{
expiresIn: 60 * 60 * 24 * 1
}
)
userinfo.dataValues.token = token
delete userinfo.dataValues.password
req.session.userinfo = userinfo
toRes.session(res, 0, '登录成功!', token)
} catch(err) {
toRes.session(res, 500, '服务器错误!', '', 500)
}
})
// 用户退出接口
api.all('/logout', (req, res) => {
if (!toRes.auth(req, res, '管理员')) return
req.session.destroy(err => {
toRes.session(res, 0, '退出成功!')
})
})
// 注册接口
api.post('/register', async (req, res) => {
try {
const userinfo = await UsersModel.create(req.body)
if (userinfo === null) {
toRes.session(res, -1, '注册失败!')
} else {
toRes.session(res, 0, '注册成功!')
}
} catch(err) {
toRes.session(res, 500, '服务器错误!', '', 500)
}
})
论文写作大纲参考
目 录
摘 要 I
Pick to I
1绪论 1
1.1项目研究的背景
1.2开发意义
1.3项目研究现状及内容
1.4论文结构
2开发技术介绍
2.1微信小程序技术
2.2 编程语言
2.3 MySQL环境配置
2.4uniapp框架
2.5微信开发者工具
3系统分析
3.1 系统可行性分析
3.1.1 经济可行性
3.1.2 技术可行性
3.1.3 运行可行性
3.1.4 操作可行性
3.2 需求分析
3.3流程的分析
3.3.1 用户管理流程
3.3.2 系统登录流程图
3.3.3 添加信息流程
3.3.4 删除信息流程
3.4微信序的性能
4系统设计
4.1 系统结构设计
4.2 数据库设计
4.2.1 数据库表说明
4.2.2 数据库逻辑设计
5系统详细设计
5.1 小程序端
5.2管理员功能模块
6系统测试
6.1 功能测试
6.2 可用性测试
6.3 性能测试
6.4 测试结果分析
7总结与心得体会
7.1 总结
7.2 心得体会
参考文献
致 谢
源码获取/详细视频演示
需要成品,加我们的时候,记得把页面截图发下我,方便查找相应的源代码和演示视频。
如果你对本设计介绍不满意或者想获取更详细的信息
文章最下方名片联系我即可~