🍅 作者简介:CSDN特邀作者✌、java领域优质创作者💪
🍅关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你
🍅文末获取源码联系🍅
目录
一、前言介绍:
二、功能设计:
三、功能截图:
四、关键代码:
五、数据库设计:
七、论文报告:
八、源码获取:
一、前言介绍:
网络的快速发展从根本上更改了世界各组织的管理方式,自二十世纪九十年代开始,我国的政府、企事业等单位就设想可以通过互联网系统来进行管理信息。由于以前存在各方面的原因,比如网络普及度低、用户不接受、互联网的相关法律法规也不够完善、开发技术也不够成熟等,阻碍了互联网在各大机构中的发展速度。进入二十一世纪以后,我国经济有了快速的发展,限制机构管理的各个难题逐一被解决,国内各大机构都加入到了电子信息化的管理模式中来。
以往的高校校园网站相关信息管理,都是工作人员手工统计。这种方式不但时效性低,而且需要查找和变更的时候很不方便。随着科学的进步,技术的成熟,计算机信息化也日新月异的发展,社会也已经深刻的认识,计算机功能非常的强大,计算机已经进入了人类社会发展的各个领域,并且发挥着十分重要的作用。本系统利用网络沟通、计算机信息存储管理,有着与传统的方式所无法替代的优点。比如计算检索速度特别快、可靠性特别高、存储容量特别大、保密性特别好、可保存时间特别长、成本特别低等。在工作效率上,能够得到极大地提高,延伸至服务水平也会有好的收获,有了网络,在线高校校园网站的各方面的管理更加科学和系统,更加规范和简便。
二、功能设计:
主要功能设计师实现个人中心、教师管理、学生管理、校园概况管理、名师风采管理、校园公告管理、试卷管理、试题管理、校园论坛、系统管理、考试管理的相关信息管理服务。
开发工具:IDEA 2021.3、navicat for mysql 、postman。
开发语言:java、jdk1.8、mysql5
硬件环境:Win 10操作系统、Google浏览器等。
主要技术:springmvc、mybatis、html css jsp、mysql等
主要功能角色模块设计:
三、功能截图:
普通用户登录注册:
首页主要功能介绍:可以查看首页、校园概况、名师风采、校园公告、论坛信息、试卷列表、新闻资讯、我的、跳转到后台等内容
名师风采,在名师风采页面通过填写标题、图片、内容、发布时间等信息进行收藏
在校园概况页面通过填写标题、图片、内容、发布时间等信息进行收藏操作
校园概况详情
校园新闻资讯:
新闻资讯详情:
我的个人中心: 可查看修改个人信息、发布论坛、考试记录以及错题本等信息
管理员后台:分角色登录
管理员主要功能:进入校园网站可以查看个人中心、教师管理、学生管理、校园概况管理、名师风采管理、校园公告管理、试卷管理、试题管理、校园论坛、系统管理、考试管理等信息
学生管理:
校园概况信息管理:
名师风采管理:
校园公告管理:
试卷试题管理:
系统轮播图和校园资讯等信息:
四、关键代码:
登录相关:
/*** 登录相关*/
@RequestMapping("users")
@RestController
public class UserController{@Autowiredprivate UserService userService;@Autowiredprivate TokenService tokenService;/*** 登录*/@IgnoreAuth@PostMapping(value = "/login")public R login(String username, String password, String captcha, HttpServletRequest request) {UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().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 UserEntity user){
// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 退出*/@GetMapping(value = "logout")public R logout(HttpServletRequest request) {request.getSession().invalidate();return R.ok("退出成功");}/*** 密码重置*/@IgnoreAuth@RequestMapping(value = "/resetPass")public R resetPass(String username, HttpServletRequest request){UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));if(user==null) {return R.error("账号不存在");}user.setPassword("123456");userService.update(user,null);return R.ok("密码已重置为:123456");}/*** 列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,UserEntity user){EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/list")public R list( UserEntity user){EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();ew.allEq(MPUtil.allEQMapPre( user, "user")); return R.ok().put("data", userService.selectListView(ew));}/*** 信息*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") String id){UserEntity user = userService.selectById(id);return R.ok().put("data", user);}/*** 获取用户的session用户信息*/@RequestMapping("/session")public R getCurrUser(HttpServletRequest request){Long id = (Long)request.getSession().getAttribute("userId");UserEntity user = userService.selectById(id);return R.ok().put("data", user);}/*** 保存*/@PostMapping("/save")public R save(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);userService.updateById(user);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){userService.deleteBatchIds(Arrays.asList(ids));return R.ok();}
}
文件上传:
/*** 上传文件映射表*/
@RestController
@RequestMapping("file")
@SuppressWarnings({"unchecked","rawtypes"})
public class FileController{@Autowiredprivate ConfigService configService;/*** 上传文件*/@RequestMapping("/upload")public R upload(@RequestParam("file") MultipartFile file, String type,HttpServletRequest request) throws Exception {if (file.isEmpty()) {throw new EIException("上传文件不能为空");}String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);String fileName = new Date().getTime()+"."+fileExt;File dest = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+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("/download")public void download(@RequestParam String fileName, HttpServletRequest request, HttpServletResponse response) {try {File file = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+fileName);if (file.exists()) {response.reset();response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName+"\"");response.setHeader("Cache-Control", "no-cache");response.setHeader("Access-Control-Allow-Credentials", "true");response.setContentType("application/octet-stream; charset=UTF-8");IOUtils.write(FileUtils.readFileToByteArray(file), response.getOutputStream());}} catch (IOException e) {e.printStackTrace();}}}
五、数据库设计:
数据库的表信息属于设计的一部分,下面介绍数据库中的各个表的详细信息。
表名:token
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
userid | bigint | 用户id | |
username | varchar | 100 | 用户名 |
tablename | varchar | 100 | 表名 |
role | varchar | 100 | 角色 |
token | varchar | 200 | 密码 |
addtime | timestamp | 新增时间 | |
expiratedtime | timestamp | 过期时间 |
表名:jiaoshi
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
addtime | timestamp | 创建时间 | |
gonghao | varchar | 200 | 工号 |
mima | varchar | 200 | 密码 |
xingming | varchar | 200 | 姓名 |
xingbie | longtext | 4294967295 | 性别 |
dianhua | date | 电话 | |
youxiang | varchar | 200 | 邮箱 |
zhaopian | varchar | 200 | 照片 |
表名:xiaoyuangaikuang
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
addtime | timestamp | 创建时间 | |
biaoti | varchar | 200 | 标题 |
tupian | varchar | 200 | 图片 |
neirong | longtext | 4294967295 | 内容 |
fabushijian | varchar | 200 | 发布时间 |
表名:xiaoyuangonggao
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
addtime | timestamp | 创建时间 | |
gonggaobiaoti | varchar | 200 | 公告标题 |
gonggaoleixing | varchar | 200 | 公告类型 |
tupian | varchar | 200 | 图片 |
neirong | varchar | 200 | 内容 |
faburiqi | varchar | 200 | 发布日期 |
功能:用户表
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
username | varchar | 100 | 用户名 |
password | varchar | 100 | 密码 |
role | varchar | 100 | 角色 |
addtime | timestamp | 新增时间 |
表名:config
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
name | varchar | 100 | 配置参数名称 |
value | varchar | 100 | 配置参数值 |
表名:xuesheng
字段名称 | 类型 | 长度 | 字段说明 |
id | bigint | 主键 | |
addtime | timestamp | 创建时间 | |
xuehao | varchar | 200 | 学号 |
xueshengxingming | varchar | 200 | 学生姓名 |
mima | varchar | 200 | 密码 |
nianji | varchar | 200 | 年级 |
banji | longtext | 4294967295 | 班级 |
xingbie | date | 性别 | |
lianxidianhua | varchar | 200 | 联系电话 |
youxiang | varchar | 200 | 邮箱 |
shenfenzheng | varchar | 200 | 身份证 |
七、论文报告:
八、源码获取:
大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻微信公众号获取联系方式👇🏻👇🏻👇🏻
打卡 文章 更新 201/ 365天
精彩专栏推荐订阅:在下方专栏👇🏻👇🏻👇🏻👇🏻
Java项目精品实战案例《100套》
web前端期末大作业网页实战《100套》