博主介绍:✌全网粉丝5W+,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战,博主也曾写过优秀论文,查重率极低,在这方面有丰富的经验✌
博主作品:《Java项目案例》主要基于SpringBoot+MyBatis/MyBatis-plus+MySQL+Vue等前后端分离项目,可以在左边的分类专栏找到更多项目。《Uniapp项目案例》有几个有uniapp教程,企业实战开发。《微服务实战》专栏是本人的实战经验总结,《Spring家族及微服务系列》专注Spring、SpringMVC、SpringBoot、SpringCloud系列、Nacos等源码解读、热门面试题、架构设计等。除此之外还有不少文章等你来细细品味,更多惊喜等着你哦
🍅uniapp微信小程序🍅面试题软考题免费使用,还可以使用微信支付,扫码加群。由于维护成本问题得不到解决,可能将停止线上维护。
抖音体验版
🍅文末获取联系🍅精彩专栏推荐订阅👇🏻👇🏻 不然下次找不到哟
Java项目案例《100套》
https://blog.csdn.net/qq_57756904/category_12173599.html
uniapp小程序《100套》https://blog.csdn.net/qq_57756904/category_12173599.html
有需求代码永远写不完,而方法才是破解之道,抖音有实战视频课程,某马某千等培训都是2万左右,甚至广东有本科院校单单一年就得3万4年就12万学费,而且还没有包括吃饭的钱。所以很划算了。另外博客左侧有源码阅读专栏,对于求职有很大帮助,当然对于工作也是有指导意义等。在大城市求职,你面试来回一趟多多少少都在12块左右,而且一般不会一次性就通过,还得面试几家。而如果你对源码以及微服务等有深度认识,这无疑给你的面试添砖加瓦更上一层楼。
最后再送一句:最好是学会了,而不是学废了!!
目录
前言
学生档案管理系统是一个用于整理、存储和查询学生档案信息的电子化系统。随着信息技术的不断发展,学生档案管理系统已成为学校信息化管理的重要组成部分。
首先,学生档案管理系统的出现极大地提高了学校档案管理工作的效率。通过该系统,学校可以方便地录入、存储、查询和更新学生的档案信息,避免了传统纸质档案管理方式中的繁琐和低效。同时,由于系统采用了数字化的存储方式,因此可以节省大量的物理存储空间,并且便于进行备份和恢复操作。
其次,学生档案管理系统还具有很高的安全性和保密性。系统可以采用加密技术对数据进行保护,防止数据泄露和非法访问。此外,系统还可以设置不同的访问权限,确保只有经过授权的人员才能够访问敏感的学生档案信息。
在功能上,学生档案管理系统通常包括学生基本信息管理、学生档案查阅管理、学生信息查询与修改、学生成绩录入与查询等模块。这些功能可以满足学校对学生档案信息的各种需求,如查看学生基本情况、查询学生成绩、了解学生奖惩情况等。
此外,学生档案管理系统还可以根据学校的实际需求进行定制开发,以满足特定的管理要求。例如,系统可以支持多种查询方式,如按姓名、学号、班级等进行查询,方便用户快速找到所需的学生档案信息。同时,系统还可以提供数据统计和分析功能,帮助学校更好地了解学生的整体情况和发展趋势。
总之,学生档案管理系统是一个功能强大、安全可靠的电子化管理系统,可以有效地提高学校档案管理工作的效率和质量。随着信息技术的不断发展,该系统将会在未来发挥更加重要的作用。
二、系统设计
1、系统运行环境
开发系统:Windows10/11
架构模式:MVC/前后端分离
JDK版本:Java JDK8
开发工具:IDEA
数据库版本: mysql5.7/8
数据库可视化工具: SQL yog或Navicat for MySQL
服务器:SpringBoot自带 apache tomcat
主要技术:Java、SpringBoot、MyBatis-plus、MySQL、Html、vue、elementui等
三、非功能性与可行性分析
2.5非功能性需求分析
非功能性需求:用户对软件质量属性、运行环境、资源约束、外部接口等方面的要求或期望,包括:
2.5.1性能需求:
用户在软件响应速度、结果精度、运行时资源消耗量等方面的要求。
2.5.2可行性需求:
用户在软件失效的频率、严重程度、易恢复性,以及故障可预测性等方面的要求。
2.5.3易用性需求:
用户在界面的易用性、美观性,以及对面向用户的文档和培训资料等方面的要求。
2.5.4安全性需求:
用户在身份证、授权控制、私密性等方面的要求。
2.5.5运行环境约束:
用户对软件系统运行环境的要求。
2.5.6外部接口:
用户对待开发软件系统与其它软件系统或设备之间的接口要求
2.6可行性分析
可行性分析是从不同的角度,对可能影响系统的各方面因素进行分析,确认系统在实际生活上是可行的。本系统只是单纯地从经济、法律、技术、操作可行性四个方面来分析说明。
2.6.1技术可行性
技术上的可行性分析主要分析技术条件能否顺利完成开发工作,软、硬件能否满足需要。本系统采用Vue+Elementui开发出友好美观的人机界面,便于用户理解、操作。数据库管理系统采用MySQL,它能够处理大量数据,同时保持数据的完整性、安全性和持久性。后端技术使用SpringBoot、MyBatis,这些技术在许多公司已经被商用了,因此本系统的开发平台已成熟可行。硬件方面,在科技飞速发展的今天,硬件更新速度越来越快,容量越来越大,可靠性越来越高,价格越来越便宜,因此硬件平台也能够满足本系统所需。
2.6.2经济可行性
项目放在阿里学生服务器或者本地虚拟机的linux环境,故可行。
2.6.3法律可行性
可行,自己写的项目,目的明确,没有违法违规。
2.6.4操作可行性
操作较为简单,而且当下信息科技发达,界面的设计也着实考虑到用户的体验,系统也是为用户而生。故操作是可行的,不存在难度大的操作。
四、功能截图
1、登录与首页
1.1、登录
1.2、首页
2、基本信息
3、课程学业信息
3.1、课业成绩
3.2、科研项目
4、活动竞赛
5、健康体检
6、违纪信息
7、档案管理
7.1、档案借阅管理
7.2、档案管理
8、档案借阅
8.1、可借
8.2、借阅记录
9、系统管理
9.1、用户管理
9.2、角色管理
9.3、权限管理
五、实现代码
1、角色控制器
/**
* <p>
* 角色表 前端控制器
* </p>
*
* @author CeaM
* @since 2023-01-28
*/
@RestController
@AllArgsConstructor
@RequestMapping("/api/roles/v1")
public class CeamSysRoleController {
private final ICeamSysRoleService ceamSysRoleService;
private final ICeamSysUserService ceamSysUserService;
@GetMapping
public R<IPage<CeaMSysRoleVO>> getRoles(CeaMSysRoleDTO data) {
IPage<CeaMSysRoleVO> mapIPage = ceamSysRoleService.pageCeaMSysRoleVO(data);
return R.ok(mapIPage);
}
@GetMapping("all")
public R<Object> getAll() {
List<CeamSysRole> list = ceamSysRoleService.list();
return R.ok(list);
}
@GetMapping(value = "/level")
public R<Object> getLevel() {
return R.ok(Dict.create().set("level", getLevels(null)));
}
@PutMapping(value = "/menu")
public R<Object> updateMenu(@RequestBody CeaMSysRoleDTO roleDTO) {
CeamSysRole role = ceamSysRoleService.getById(roleDTO.getId());
getLevels(role.getLevel());
ceamSysRoleService.updateMenu(roleDTO, role);
return R.ok(HttpStatus.NO_CONTENT);
}
@PostMapping("/add")
public R<Object> add(@RequestBody CeaMSysRoleDTO data) {
boolean edit = ceamSysRoleService.add(data);
return R.ok(edit);
}
@PutMapping("/edit")
public R<Object> edit(@RequestBody CeaMSysRoleDTO data) {
boolean edit = ceamSysRoleService.edit(data);
return R.ok(edit);
}
@DeleteMapping("/del")
public R<Object> remove(@RequestBody Set<Long> ids) {
ceamSysRoleService.remove(ids);
return R.ok("成功");
}
/**
* 获取用户的角色级别
* @return /
*/
private int getLevels(Integer level) {
CeaMSysUserDTO user = ceamSysUserService.loadUserInfo(SecurityUtils.getUsername());
List<RoleDTO> roleDTOS = ceamSysRoleService.listByUserId(user.getId());
List<Integer> levels = roleDTOS.stream().map(RoleDTO::getLevel).collect(Collectors.toList());
int min = Collections.min(levels);
if (level != null) {
if (level < min) {
throw new ServiceException("权限不足,你的角色级别:" + min + ",低于操作的角色级别:" + level);
}
}
return min;
}
}
2、服务接口
/**
* <p>
* 角色表 服务类
* </p>
*
* @author CeaM
* @since 2023-01-28
*/
public interface ICeamSysRoleService extends IService<CeamSysRole> {
IPage<CeaMSysRoleVO> pageCeaMSysRoleVO(PageableDTO pageable);
/**
* 获取用户权限信息
* @param userId 用户信息
* @return 权限信息
*/
Collection<SimpleGrantedAuthority> grantedAuthorities(Long userId);
/**
*
* @param userId 用户ID
* @return RoleItemVOs
*/
List<RoleDTO> listByUserId(Long userId);
void updateMenu(CeaMSysRoleDTO roleDTO, CeamSysRole role);
}
3、实现类
/**
* <p>
* 角色表 服务实现类
* </p>
*
* @author CeaM
* @since 2023-01-28
*/
@Slf4j
@Service
@AllArgsConstructor
public class CeamSysRoleServiceImpl extends ServiceImpl<CeamSysRoleMapper, CeamSysRole> implements ICeamSysRoleService {
private ICeamSysMenuService ceamSysMenuService;
private ICeamRoleMenuService ceamRoleMenuService;
@Override
public IPage<CeaMSysRoleVO> pageCeaMSysRoleVO(PageableDTO pageable) {
LambdaQueryWrapper<CeamSysRole> queryWrapper = Wrappers.<CeamSysRole>lambdaQuery()
.eq(CeamSysRole::getDeleted, GlobalConstants.FALSE);
Page<CeamSysRole> page = new Page<>(pageable.getPage(), pageable.getSize());
// 手动设置当前页,不然分页失效
page.setCurrent((long)pageable.getPage() + GlobalConstants.ONE);
Page<CeamSysRole> ceamSysRolePage = page(page, queryWrapper);
IPage<CeaMSysRoleVO> ceaMSysRoleVOIPage = PageVOUtil.copyToPageVO(ceamSysRolePage, CeaMSysRoleVO.class);
for (CeaMSysRoleVO role : ceaMSysRoleVOIPage.getRecords()) {
List<MenuDTO> menuDTOS = ceamSysMenuService.findByRoleId(role.getId(), GlobalConstants.ZERO);
role.setMenus(menuDTOS);
}
return ceaMSysRoleVOIPage;
}
@Override
public Collection<SimpleGrantedAuthority> grantedAuthorities(Long userId) {
List<RoleDTO> roleItemDTOS = this.baseMapper.listByUserId(userId);
if (CollectionUtils.isEmpty(roleItemDTOS)) {
throw new ServiceException("没有分配角色");
}
List<MenuDTO> menuDTOS = ceamSysMenuService.findByRoles(roleItemDTOS, GlobalConstants.ZERO);
// 角色
Set<String> permissions = roleItemDTOS.stream()
.filter(role -> StringUtils.isNotBlank(role.getName()))
.map(RoleDTO::getName).collect(Collectors.toSet());
permissions.addAll(
menuDTOS.stream()
.filter(menu -> StringUtils.isNotBlank(menu.getPermission()))
.map(MenuDTO::getPermission).collect(Collectors.toSet())
);
return permissions.stream().map(SimpleGrantedAuthority::new)
.collect(Collectors.toList());
}
@Override
public List<RoleDTO> listByUserId(Long userId) {
return this.baseMapper.listByUserId(userId);
}
@Override
public void updateMenu(CeaMSysRoleDTO roleDTO, CeamSysRole role) {
if (roleDTO.getMenus().size() > 0) {
List<CeamRoleMenu> rolesMenusList = roleDTO.getMenus().stream().map(i -> {
CeamRoleMenu rolesMenus = new CeamRoleMenu();
rolesMenus.setRoleId(roleDTO.getId());
rolesMenus.setMenuId(i.getId());
return rolesMenus;
}).collect(Collectors.toList());
ceamRoleMenuService.remove(new LambdaQueryWrapper<CeamRoleMenu>()
.eq(CeamRoleMenu::getRoleId, roleDTO.getId()));
ceamRoleMenuService.saveBatch(rolesMenusList);
}
}
}
六、获取源码
点赞、收藏、关注 、天下没有免费的午餐关注下方公众号获取联系方式👇🏻👇🏻