• 基于SSM的智慧城市实验室主页系统的设计与实现


    末尾获取源码
    开发语言:Java
    Java开发工具:JDK1.8
    后端框架:SSM
    前端:采用Vue技术开发
    数据库:MySQL5.7和Navicat管理工具结合
    服务器:Tomcat8.5
    开发软件:IDEA / Eclipse
    是否Maven项目:是


    目录

    一、项目简介

    二、数据库设计

    数据库概念设计

    数据库物理设计

    三、系统项目截图

    教师管理

    学生管理

    设备信息管理

    奖项信息管理

    国际会议管理

    电子期刊管理

    科研报告管理

    科研成果管理

    电子期刊

    国际会议

    科研成果

    学术交流

    四、核心代码

    4.1登录相关

    4.2文件上传

    4.3封装


    一、项目简介

    互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对实验室信息管理混乱,出错率高,信息安全性差,劳动强度大,费时费力等问题,采用智慧城市实验室主页系统可以有效管理,使信息管理能够更加科学和规范。

    智慧城市实验室主页系统在Eclipse环境中,使用Java语言进行编码,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,本系统管理员管理电子期刊,国际会议,学术团队以及实验动态,管理奖项和活动以及设备信息。教师管理科研报告,管理科研成果,下载国际会议资源,参与学术交流。学生下载科研成果,会议资源,电子期刊文件,查看学术交流里面的帖子并发布评论,查看学术团队,实验动态等信息。

    总之,智慧城市实验室主页系统集中管理信息,有着保密性强,效率高,存储空间大,成本低等诸多优点。它可以降低信息管理成本,实现信息管理计算机化。


    二、数据库设计

    开发一个系统也需要提前设计数据库。这里的数据库是相关数据的集合,存储在一起的这些数据也是按照一定的组织方式进行的。目前,数据库能够服务于多种应用程序,则是源于它存储方式最佳,具备数据冗余率低的优势。虽然数据库为程序提供信息存储服务,但它与程序之间也可以保持较高的独立性。总而言之,数据库经历了很长一段时间的发展,从最初的不为人知,到现在的人尽皆知,其相关技术也越发成熟,同时也拥有着坚实的理论基础。

    数据库概念设计

    这部分内容需要借助数据库关系图来完成,也需要使用专门绘制数据库关系图的工具,比如Visio工具就可以设计E-R图(数据库关系图)。设计数据库,也需要按照设计的流程进行,首先还是要根据需求完成实体的确定,分析实体具有的特征,还有对实体间的关联关系进行确定。最后才是使用E-R模型的表示方法,绘制本系统的E-R图。不管是使用亿图软件,还是Visio工具,对于E-R模型的表示符号都一样,通常矩形代表实体,实体间存在的关系用菱形符号表示,实体的属性也就是实体的特征用符号椭圆表示。最后使用直线将矩形,菱形和椭圆等符号连接起来。接下来就开始对本系统的E-R图进行绘制。

    (1)下图是教师实体和其具备的属性。

    (2)下图是电子期刊实体和其具备的属性。

     (3)下图是科研成果实体和其具备的属性。

    数据库物理设计

    本数据库是关系型数据库,因此对二维表的结构设计也比较关键。毕竟二维表格模型就是关系型数据库中的关系模型。而一些常用的关系模型中的概念也需要了解,才可以对关系模型进行设计。下面就简单介绍关系,元组,属性,域,关键字等常用概念的含义。

    关系:关系就是数据库中的一张数据表,每张数据表都有命名,也就是每个关系也有名字,那就是数据表名;

    元组:元组就是数据表中的一行记录;

    属性:属性就是数据表中的字段,也就是数据表中的一列;

    域:域就是对数据表中属性的取值进行限定;

    关键字:关键字就是数据表中的主键;

    在了解了表结构设计的常用概念后,接下来就需要使用前面绘制的E-R模型完成表结构的设计工作,并在数据库中创建数据表,并为各个数据表进行命名。以下就对设计的结果通过表格形式进行展示。

     电子期刊信息表

    字段

    类型

    默认

    注释

    id (主键)

    bigint(20)

    主键

    addtime

    timestamp

    CURRENT_TIMESTAMP

    创建时间

    bianhao

    varchar(200)

    NULL

    编号

    zazhimingcheng

    varchar(200)

    NULL

    杂志名称

    suoshufenlei

    varchar(200)

    NULL

    所属分类

    jianjie

    longtext

    NULL

    简介

    fujianxiazai

    varchar(200)

    NULL

    附件下载

    faxingdanwei

    varchar(200)

    NULL

    发行单位

    faburiqi

    date

    NULL

    发布日期

    tupian

    varchar(200)

    NULL

    图片

    thumbsupnum

    int(11)

    0

    crazilynum

    int(11)

    0

    学术交流信息表

    字段

    类型

    默认

    注释

    id (主键)

    bigint(20)

    主键

    addtime

    timestamp

    CURRENT_TIMESTAMP

    创建时间

    title

    varchar(200)

    NULL

    帖子标题

    content

    longtext

    帖子内容

    parentid

    bigint(20)

    NULL

    父节点id

    userid

    bigint(20)

    用户id

    username

    varchar(200)

    NULL

    用户名

    isdone

    varchar(200)

    NULL

    状态

     国际会议信息表

    字段

    类型

    默认

    注释

    id (主键)

    bigint(20)

    主键

    addtime

    timestamp

    CURRENT_TIMESTAMP

    创建时间

    huiyibianhao

    varchar(200)

    NULL

    会议编号

    huiyizhuti

    varchar(200)

    NULL

    会议主题

    huiyigaishu

    longtext

    NULL

    会议概述

    huiyichengyuan

    varchar(200)

    NULL

    会议成员

    ziyuanxiazai

    varchar(200)

    NULL

    资源下载

    zhubanfang

    varchar(200)

    NULL

    主办方

    tupian

    varchar(200)

    NULL

    图片

    奖项信息表

    字段

    类型

    默认

    注释

    id (主键)

    bigint(20)

    主键

    addtime

    timestamp

    CURRENT_TIMESTAMP

    创建时间

    xuhao

    varchar(200)

    NULL

    序号

    jiangxiangmingcheng

    varchar(200)

    NULL

    奖项名称

    leibie

    varchar(200)

    NULL

    类别

    jiangxiangshuoming

    varchar(200)

    NULL

    奖项说明

    pingbishijian

    varchar(200)

    NULL

    评比时间

    beizhu

    varchar(200)

    NULL

    备注

    fengmian

    varchar(200)

    NULL

    封面

     



    三、系统项目截图

    教师管理

    管理员进入指定功能操作区之后可以管理教师。其页面见下图。管理员可以增删改查教师资料。

    学生管理

    管理员进入指定功能操作区之后可以管理学生。其页面见下图。管理员增删改查学生资料。

     

    设备信息管理

    管理员进入指定功能操作区之后可以管理设备信息。其页面见下图。管理员登记设备信息,包括所在位置,使用情况,设备名称等资料需要登记并管理。

     

    奖项信息管理

    管理员进入指定功能操作区之后可以管理奖项信息。其页面见下图。管理员新增奖项信息,包括奖项名称,评比时间以及封面等资料都需要登记并在后期管理。

     

    国际会议管理

    管理员进入指定功能操作区之后可以管理国际会议。其页面见下图。管理员登记国际会议信息,下载会议资源,查询国际会议信息。

     

    电子期刊管理

    管理员进入指定功能操作区之后可以管理电子期刊。其页面见下图。管理员增删改查电子期刊信息,可以下载电子期刊附件。

     

    科研报告管理

    教师进入指定功能操作区之后可以管理科研报告。其页面见下图。教师上传科研报告,提交报告名称查询报告,修改科研报告。

     

    科研成果管理

    教师进入指定功能操作区之后可以管理科研成果。其页面见下图。教师增删改查科研成果信息。

     

    电子期刊

    学生进入指定功能操作区之后可以查看电子期刊。其页面见下图。学生收藏电子期刊,下载附件,评论期刊。

     

    国际会议

    学生进入指定功能操作区之后可以查看国际会议。其页面见下图。学生查看国际会议内容,下载资源文件。

     

    科研成果

    学生进入指定功能操作区之后可以查看科研成果。其页面见下图。学生查看科研成果,下载科研成果文件。

     

    学术交流

    学生进入指定功能操作区之后可以参与学术交流。其页面见下图。学生查看学术交流里面的帖子,可以评论帖子。

     


    四、核心代码

    4.1登录相关

    1. package com.controller;
    2. import java.util.Arrays;
    3. import java.util.Calendar;
    4. import java.util.Date;
    5. import java.util.Map;
    6. import javax.servlet.http.HttpServletRequest;
    7. import org.springframework.beans.factory.annotation.Autowired;
    8. import org.springframework.stereotype.Controller;
    9. import org.springframework.web.bind.annotation.GetMapping;
    10. import org.springframework.web.bind.annotation.PathVariable;
    11. import org.springframework.web.bind.annotation.PostMapping;
    12. import org.springframework.web.bind.annotation.RequestBody;
    13. import org.springframework.web.bind.annotation.RequestMapping;
    14. import org.springframework.web.bind.annotation.RequestParam;
    15. import org.springframework.web.bind.annotation.ResponseBody;
    16. import org.springframework.web.bind.annotation.RestController;
    17. import com.annotation.IgnoreAuth;
    18. import com.baomidou.mybatisplus.mapper.EntityWrapper;
    19. import com.entity.TokenEntity;
    20. import com.entity.UserEntity;
    21. import com.service.TokenService;
    22. import com.service.UserService;
    23. import com.utils.CommonUtil;
    24. import com.utils.MD5Util;
    25. import com.utils.MPUtil;
    26. import com.utils.PageUtils;
    27. import com.utils.R;
    28. import com.utils.ValidatorUtils;
    29. /**
    30. * 登录相关
    31. */
    32. @RequestMapping("users")
    33. @RestController
    34. public class UserController{
    35. @Autowired
    36. private UserService userService;
    37. @Autowired
    38. private TokenService tokenService;
    39. /**
    40. * 登录
    41. */
    42. @IgnoreAuth
    43. @PostMapping(value = "/login")
    44. public R login(String username, String password, String captcha, HttpServletRequest request) {
    45. UserEntity user = userService.selectOne(new EntityWrapper().eq("username", username));
    46. if(user==null || !user.getPassword().equals(password)) {
    47. return R.error("账号或密码不正确");
    48. }
    49. String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
    50. return R.ok().put("token", token);
    51. }
    52. /**
    53. * 注册
    54. */
    55. @IgnoreAuth
    56. @PostMapping(value = "/register")
    57. public R register(@RequestBody UserEntity user){
    58. // ValidatorUtils.validateEntity(user);
    59. if(userService.selectOne(new EntityWrapper().eq("username", user.getUsername())) !=null) {
    60. return R.error("用户已存在");
    61. }
    62. userService.insert(user);
    63. return R.ok();
    64. }
    65. /**
    66. * 退出
    67. */
    68. @GetMapping(value = "logout")
    69. public R logout(HttpServletRequest request) {
    70. request.getSession().invalidate();
    71. return R.ok("退出成功");
    72. }
    73. /**
    74. * 密码重置
    75. */
    76. @IgnoreAuth
    77. @RequestMapping(value = "/resetPass")
    78. public R resetPass(String username, HttpServletRequest request){
    79. UserEntity user = userService.selectOne(new EntityWrapper().eq("username", username));
    80. if(user==null) {
    81. return R.error("账号不存在");
    82. }
    83. user.setPassword("123456");
    84. userService.update(user,null);
    85. return R.ok("密码已重置为:123456");
    86. }
    87. /**
    88. * 列表
    89. */
    90. @RequestMapping("/page")
    91. public R page(@RequestParam Map params,UserEntity user){
    92. EntityWrapper ew = new EntityWrapper();
    93. PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
    94. return R.ok().put("data", page);
    95. }
    96. /**
    97. * 列表
    98. */
    99. @RequestMapping("/list")
    100. public R list( UserEntity user){
    101. EntityWrapper ew = new EntityWrapper();
    102. ew.allEq(MPUtil.allEQMapPre( user, "user"));
    103. return R.ok().put("data", userService.selectListView(ew));
    104. }
    105. /**
    106. * 信息
    107. */
    108. @RequestMapping("/info/{id}")
    109. public R info(@PathVariable("id") String id){
    110. UserEntity user = userService.selectById(id);
    111. return R.ok().put("data", user);
    112. }
    113. /**
    114. * 获取用户的session用户信息
    115. */
    116. @RequestMapping("/session")
    117. public R getCurrUser(HttpServletRequest request){
    118. Long id = (Long)request.getSession().getAttribute("userId");
    119. UserEntity user = userService.selectById(id);
    120. return R.ok().put("data", user);
    121. }
    122. /**
    123. * 保存
    124. */
    125. @PostMapping("/save")
    126. public R save(@RequestBody UserEntity user){
    127. // ValidatorUtils.validateEntity(user);
    128. if(userService.selectOne(new EntityWrapper().eq("username", user.getUsername())) !=null) {
    129. return R.error("用户已存在");
    130. }
    131. userService.insert(user);
    132. return R.ok();
    133. }
    134. /**
    135. * 修改
    136. */
    137. @RequestMapping("/update")
    138. public R update(@RequestBody UserEntity user){
    139. // ValidatorUtils.validateEntity(user);
    140. userService.updateById(user);//全部更新
    141. return R.ok();
    142. }
    143. /**
    144. * 删除
    145. */
    146. @RequestMapping("/delete")
    147. public R delete(@RequestBody Long[] ids){
    148. userService.deleteBatchIds(Arrays.asList(ids));
    149. return R.ok();
    150. }
    151. }

    4.2文件上传

    1. package com.controller;
    2. import java.io.File;
    3. import java.io.FileNotFoundException;
    4. import java.io.IOException;
    5. import java.util.Arrays;
    6. import java.util.Date;
    7. import java.util.HashMap;
    8. import java.util.List;
    9. import java.util.Map;
    10. import java.util.Random;
    11. import java.util.UUID;
    12. import org.apache.commons.io.FileUtils;
    13. import org.apache.commons.lang3.StringUtils;
    14. import org.springframework.beans.factory.annotation.Autowired;
    15. import org.springframework.http.HttpHeaders;
    16. import org.springframework.http.HttpStatus;
    17. import org.springframework.http.MediaType;
    18. import org.springframework.http.ResponseEntity;
    19. import org.springframework.util.ResourceUtils;
    20. import org.springframework.web.bind.annotation.PathVariable;
    21. import org.springframework.web.bind.annotation.RequestBody;
    22. import org.springframework.web.bind.annotation.RequestMapping;
    23. import org.springframework.web.bind.annotation.RequestParam;
    24. import org.springframework.web.bind.annotation.RestController;
    25. import org.springframework.web.multipart.MultipartFile;
    26. import com.annotation.IgnoreAuth;
    27. import com.baomidou.mybatisplus.mapper.EntityWrapper;
    28. import com.entity.ConfigEntity;
    29. import com.entity.EIException;
    30. import com.service.ConfigService;
    31. import com.utils.R;
    32. /**
    33. * 上传文件映射表
    34. */
    35. @RestController
    36. @RequestMapping("file")
    37. @SuppressWarnings({"unchecked","rawtypes"})
    38. public class FileController{
    39. @Autowired
    40. private ConfigService configService;
    41. /**
    42. * 上传文件
    43. */
    44. @RequestMapping("/upload")
    45. public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
    46. if (file.isEmpty()) {
    47. throw new EIException("上传文件不能为空");
    48. }
    49. String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
    50. File path = new File(ResourceUtils.getURL("classpath:static").getPath());
    51. if(!path.exists()) {
    52. path = new File("");
    53. }
    54. File upload = new File(path.getAbsolutePath(),"/upload/");
    55. if(!upload.exists()) {
    56. upload.mkdirs();
    57. }
    58. String fileName = new Date().getTime()+"."+fileExt;
    59. File dest = new File(upload.getAbsolutePath()+"/"+fileName);
    60. file.transferTo(dest);
    61. FileUtils.copyFile(dest, new File("C:\\Users\\Desktop\\jiadian\\springbootl7own\\src\\main\\resources\\static\\upload"+"/"+fileName));
    62. if(StringUtils.isNotBlank(type) && type.equals("1")) {
    63. ConfigEntity configEntity = configService.selectOne(new EntityWrapper().eq("name", "faceFile"));
    64. if(configEntity==null) {
    65. configEntity = new ConfigEntity();
    66. configEntity.setName("faceFile");
    67. configEntity.setValue(fileName);
    68. } else {
    69. configEntity.setValue(fileName);
    70. }
    71. configService.insertOrUpdate(configEntity);
    72. }
    73. return R.ok().put("file", fileName);
    74. }
    75. /**
    76. * 下载文件
    77. */
    78. @IgnoreAuth
    79. @RequestMapping("/download")
    80. public ResponseEntity<byte[]> download(@RequestParam String fileName) {
    81. try {
    82. File path = new File(ResourceUtils.getURL("classpath:static").getPath());
    83. if(!path.exists()) {
    84. path = new File("");
    85. }
    86. File upload = new File(path.getAbsolutePath(),"/upload/");
    87. if(!upload.exists()) {
    88. upload.mkdirs();
    89. }
    90. File file = new File(upload.getAbsolutePath()+"/"+fileName);
    91. if(file.exists()){
    92. /*if(!fileService.canRead(file, SessionManager.getSessionUser())){
    93. getResponse().sendError(403);
    94. }*/
    95. HttpHeaders headers = new HttpHeaders();
    96. headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
    97. headers.setContentDispositionFormData("attachment", fileName);
    98. return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED);
    99. }
    100. } catch (IOException e) {
    101. e.printStackTrace();
    102. }
    103. return new ResponseEntity<byte[]>(HttpStatus.INTERNAL_SERVER_ERROR);
    104. }
    105. }

    4.3封装

    1. package com.utils;
    2. import java.util.HashMap;
    3. import java.util.Map;
    4. /**
    5. * 返回数据
    6. */
    7. public class R extends HashMap {
    8. private static final long serialVersionUID = 1L;
    9. public R() {
    10. put("code", 0);
    11. }
    12. public static R error() {
    13. return error(500, "未知异常,请联系管理员");
    14. }
    15. public static R error(String msg) {
    16. return error(500, msg);
    17. }
    18. public static R error(int code, String msg) {
    19. R r = new R();
    20. r.put("code", code);
    21. r.put("msg", msg);
    22. return r;
    23. }
    24. public static R ok(String msg) {
    25. R r = new R();
    26. r.put("msg", msg);
    27. return r;
    28. }
    29. public static R ok(Map map) {
    30. R r = new R();
    31. r.putAll(map);
    32. return r;
    33. }
    34. public static R ok() {
    35. return new R();
    36. }
    37. public R put(String key, Object value) {
    38. super.put(key, value);
    39. return this;
    40. }
    41. }

  • 相关阅读:
    卡尔曼滤波C++代码
    将docker镜像打成tar包
    C语言:数组指针
    动态规划课堂2-----路径问题
    一生一芯14——chisel环境搭建
    qcc51xx --- 规则(rules)机制详解
    Centos7 Docker&Docker-Compose安装教程
    docker+nginx 安装部署修改资源目录配置文件和容器端口信息
    案例题--信息系统架构设计
    【Vue】vuex getters 配置项
  • 原文地址:https://blog.csdn.net/weixin_52721608/article/details/132819735