项目介绍
随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,四六级词汇小程序被用户普遍使用,为方便用户能够可以随时进行四六级词汇小程序的数据信息管理,特开发了基于四六级词汇小程序的管理系统。
四六级词汇小程序的设计主要是对系统所要实现的功能进行详细考虑,确定所要实现的功能后进行界面的设计,在这中间还要考虑如何可以更好的将功能及页面进行很好的结合,方便用户可以很容易明了的找到自己所需要的信息,还有系统平台后期的可操作性,通过对信息内容的详细了解进行技术的开发。
四六级词汇小程序的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与四六级词汇小程序管理的实际需求相结合,讨论了基于四六级词汇小程序管理的使用。
开发环境
编程语言:Java
数据库 :Mysql
系统架构:B/S
后端框架:SSM
编译工具:idea或者eclipse,微信开发者工具,jdk1.8,maven
支持定做:java/php/python/android/小程序vue/爬虫/c#/asp.net
系统实现
5.1用户客户端功能实现
注册用户通过注册窗口,进行在线填写自己的用户名、姓名、性别、身份证、手机等等,信息编辑完成后核对信息无误后进行选择注册,系统核对用户所输入的账号信息是否准确,核对信息准确无误后系统进入到操作界面。
用户通过登录进入到系统操作界面后,可以根据需求对首页、英语词汇、易错词、论坛中心、我的等模块进行管理维护操作。
如图5-1所示。
图5-1注册用户界面图
用户登录通过账号、密码行页面,进入到四六级词汇小程序主界面,进入到操作界面,进行相对应操作,如图5-2所示。
图5-2用户登录界面图
用户首页页面可以查看首页、英语词汇、易错词、论坛中心、我的等信息,进行提交操作,如图5-3所示。
图5-3首页界面图
用户进入我的页面可以填写英语词汇、学习笔记、签到打卡、我的收藏、我要发帖、留言板等信息,进行提交操作,如图5-4所示。
图5-4我的界面图
用户进入用户信息页面可以填写用户名、密码、姓名、性别、头像、身份证、手机等信息,进行保存操作,如图5-5-所示。
图5-5用户信息界面图
用户进入英语词汇页面可以填写单词、等级、图片、字母、音标等信息,进行做笔记操作,如图5-6-所示。
图5-6英语词汇界面图
用户进入添加易错词页面可以填写易错单词、字母、发音、发布日期、备注等信息,进行收藏操作,如图5-7-所示。
图5-7易错单词界面图
用户进入学习笔记页面可以填写笔记名称、姓名、日期、用户名、学习进度等信息,进行提交操作,如图5-8-所示。
图5-8学习笔记界面图
用户进入签到打卡页面可以填写编号、签到日期、星期、用户名、备注等信息,进行提交操作,如图5-9-所示。
图5-9签到打卡界面图
用户进入我要发布页面可以填写内容等信息,进行确认提交操作,如图5-10-所示。
图5-10我要发布界面图
5.2 管理员服务端功能实现
管理员通过四六级词汇小程序进行确认,管理员进入到四六级词汇小程序主界面,管理员进入到操作界面,通过登录窗口进行在线填写自己的用户名和密码、角色进行登录,登录成功后进入到系统操作界面进行相应信息的获取,如图5-11所示。
图5-11管理员登录主界面图
管理员进入到界面,通过界面的任务大厅,登录成功后进入到系统可以进行查看首页、个人中心、用户管理,英语词汇管理、易错词管理、学习笔记管理、签到打卡管理、论坛管理、我的收藏管理、留言板管理、系统管理等功能模块,进行相对应操作,如图5-12所示。
图5-12管理员功能界面图
管理员点击用户管理进入页面可以查看用户名、密码、姓名、性别、头像、身份证、手机等信息,进行详情、修改、删除操作,如图5-13示。
图5-13用户管理界面图
管理员进入英语词汇管理界面,通过界面的任务大厅,登录成功后进入到系统可以进行查看单词、等级、图片、字母、音标、翻译、听力、发布日期等信息,进行相对应操作,如图5-14所示。
图5-14英语词汇管理界面图
管理员进入到易错词管理界面,通过界面的任务大厅,登录成功后进入到系统可以查看易错单词、字母、图片、发音、备注、发布日期等信息,进行相对应操作,如图5-15所示。
图5-15易错词管理界面图
管理员进入到学习笔记管理界面,通过界面的任务大厅,登录成功后进入到系统可以查看笔记名称、日期、学习进度、学习心得、用户名、姓名等信息,进行相对应操作,如图5-16所示。
图5-16学习笔记界面图
管理员进入到签到打卡管理界面,通过界面的任务大厅,登录成功后进入到系统可以查看编号、签到日期、星期、备注、用户名等信息,进行相对应操作,如图5-17所示。
图5-17签到打卡管理界面图
管理员进入我的收藏管理界面,通过界面的任务大厅,登录成功后进入到系统可以查看收藏ID、表名、收藏名称、收藏图片等信息,进行相对应操作,如图5-18所示。
图5-18我的收藏管理界面图
轮播图;该页面为轮播图管理界面。管理员可以在此页面进行首页轮播图的管理,通过新建操作可在轮播图中加入新的图片,还可以对以上传的图片进行修改操作,以及图片的删除操作,如图5-19所示。
图5-19轮播图管理界面图
核心代码
package com.controller;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;
import com.entity.SijicihuiEntity;
import com.entity.view.SijicihuiView;
import com.service.SijicihuiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MPUtil;
import com.utils.CommonUtil;
/**
* 四级词汇
* 后端接口
* @author
* @email
* @date
*/
@RestController
@RequestMapping("/sijicihui")
public class SijicihuiController {
@Autowired
private SijicihuiService sijicihuiService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,SijicihuiEntity sijicihui, HttpServletRequest request){
EntityWrapper<SijicihuiEntity> ew = new EntityWrapper<SijicihuiEntity>();
PageUtils page = sijicihuiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, sijicihui), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@RequestMapping("st")
public R list(@RequestParam Map<String, Object> params,SijicihuiEntity sijicihui, HttpServletRequest request){
EntityWrapper<SijicihuiEntity> ew = new EntityWrapper<SijicihuiEntity>();
PageUtils page = sijicihuiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, sijicihui), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("sts")
public R list( SijicihuiEntity sijicihui){
EntityWrapper<SijicihuiEntity> ew = new EntityWrapper<SijicihuiEntity>();
ew.allEq(MPUtil.allEQMapPre( sijicihui, "sijicihui"));
return R.ok().put("data", sijicihuiService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(SijicihuiEntity sijicihui){
EntityWrapper< SijicihuiEntity> ew = new EntityWrapper< SijicihuiEntity>();
ew.allEq(MPUtil.allEQMapPre( sijicihui, "sijicihui"));
SijicihuiView sijicihuiView = sijicihuiService.selectView(ew);
return R.ok("查询四级词汇成功").put("data", sijicihuiView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
SijicihuiEntity sijicihui = sijicihuiService.selectById(id);
return R.ok().put("data", sijicihui);
}
/**
* 前端详情
*/
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") String id){
SijicihuiEntity sijicihui = sijicihuiService.selectById(id);
return R.ok().put("data", sijicihui);
}
/**
* 后端保存
*/
@RequestMapping("ve")
public R save(@RequestBody SijicihuiEntity sijicihui, HttpServletRequest request){
sijicihui.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(sijicihui);
sijicihuiService.insert(sijicihui);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody SijicihuiEntity sijicihui, HttpServletRequest request){
sijicihui.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(sijicihui);
sijicihuiService.insert(sijicihui);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody SijicihuiEntity sijicihui, HttpServletRequest request){
//ValidatorUtils.validateEntity(sijicihui);
sijicihuiService.updateById(sijicihui);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
sijicihuiService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
/**
* 提醒接口
*/
@RequestMapping("/remind/{columnName}/{type}")
public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
@PathVariable("type") String type,@RequestParam Map<String, Object> map) {
map.put("column", columnName);
map.put("type", type);
if(type.equals("2")) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Calendar c = Calendar.getInstance();
Date remindStartDate = null;
Date remindEndDate = null;
if(map.get("remindstart")!=null) {
Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindStart);
remindStartDate = c.getTime();
map.put("remindstart", sdf.format(remindStartDate));
}
if(map.get("remindend")!=null) {
Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindEnd);
remindEndDate = c.getTime();
map.put("remindend", sdf.format(remindEndDate));
}
}
Wrapper<SijicihuiEntity> wrapper = new EntityWrapper<SijicihuiEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = sijicihuiService.selectCount(wrapper);
return R.ok().put("count", count);
}
}
论文参考
目 录
摘 要 I
Abstract II
第一章 绪 论 6
1.1选题背景 6
1.2研究现状 6
1.3研究内容 7
第二章 开发工具及关键技术介绍 8
2.1微信开发者工具 8
2.2小程序框架以及目录结构介绍 8
2.3 JAVA技术 8
2.4 Mysql数据库 8
2.5 SSM框架 8
第三章 系统分析 10
3.1需求分析 10
3.2可行性分析 10
3.2.1技术可行性:技术背景 10
3.2.2经济可行性 11
3.2.3操作可行性: 11
3.3性能分析 11
3.4系统操作流程 12
3.4.1管理员登录流程 12
3.4.2信息添加流程 12
3.4.3信息删除流程 13
第四章 系统设计与实现 15
4.1系统架构设计 15
4.2开发流程设计 15
4.3数据库设计 16
4.3.1实体ER图 16
4.3.2数据表 18
第五章 系统实现 21
5.1 用户客户端功能实现 24
5.2 管理员服务端功能实现 24
第六章 系统的测试 27
6.1 测试目的 27
6.2 测试方案设计 27
6.2.1 测试策略 27
6.2.2 测试分析 28
6.3 测试结果 28
结 论 29
参考文献 30
致 谢 31