Java Springboot+vue毕业项目实战--党建信息管理系统

文章详细描述了一个基于SpringBoot的系统登录控制器,涉及验证码验证、用户登录逻辑以及Shiro权限配置。同时提到前端使用Vue进行登录界面设计,并提及了数据库表设计和前端开发的学习资源包。
摘要由CSDN通过智能技术生成
  • @author lyy

*/

@RestController

public class SysLoginController extends AbstractController {

@Autowired

private SysUserService sysUserService;

@Autowired

private SysUserTokenService sysUserTokenService;

@Autowired

private SysCaptchaService sysCaptchaService;

/**

  • 验证码

*/

@GetMapping(“captcha.jpg”)

public void captcha(HttpServletResponse response, String uuid)throws IOException {

response.setHeader(“Cache-Control”, “no-store, no-cache”);

response.setContentType(“image/jpeg”);

//获取图片验证码

BufferedImage image = sysCaptchaService.getCaptcha(uuid);

ServletOutputStream out = response.getOutputStream();

ImageIO.write(image, “jpg”, out);

IOUtils.closeQuietly(out);

}

/**

  • 退出

*/

@PostMapping(“/sys/logout”)

public R logout() {

sysUserTokenService.logout(getUserId());

return R.ok();

}

/**

  • 登录

*/

@PostMapping(“/sys/login”)

public Map<String, Object> login(@RequestBody SysLoginForm form)throws IOException {

boolean captcha = sysCaptchaService.validate(form.getUuid(), form.getCaptcha());

// if(!captcha){

// return R.error(“验证码不正确”);

// }

//用户信息

SysUserEntity user = sysUserService.queryByUserName(form.getUsername());

//账号不存在、密码错误

if(user == null || !user.getPassword().equals(new Sha256Hash(form.getPassword(), user.getSalt()).toHex())) {

return R.error(“账号或密码不正确”);

}

//账号锁定

if(user.getStatus() == 0){

return R.error(“账号已被锁定,请联系管理员”);

}

//生成token,并保存到数据库

R r = sysUserTokenService.createToken(user.getUserId());

return r;

}

shiro权限拦截放行:

/**

  • Shiro配置

  • @author lyy

*/

@Configuration

public class ShiroConfig {

@Bean(“securityManager”)

public SecurityManager securityManager(OAuth2Realm oAuth2Realm) {

DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();

securityManager.setRealm(oAuth2Realm);

securityManager.setRememberMeManager(null);

return securityManager;

}

@Bean(“shiroFilter”)

public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {

ShiroFilterFactoryBean shiroFilter = new ShiroFilterFactoryBean();

shiroFilter.setSecurityManager(securityManager);

//oauth过滤

Map<String, Filter> filters = new HashMap<>();

filters.put(“oauth2”, new OAuth2Filter());

shiroFilter.setFilters(filters);

Map<String, String> filterMap = new LinkedHashMap<>();

filterMap.put(“/webjars/**”, “anon”);

filterMap.put(“/druid/**”, “anon”);

filterMap.put(“/app/**”, “anon”);

filterMap.put(“/sys/login”, “anon”);

filterMap.put(“/swagger/**”, “anon”);

filterMap.put(“/v2/api-docs”, “anon”);

filterMap.put(“/swagger-ui.html”, “anon”);

filterMap.put(“/swagger-resources/**”, “anon”);

filterMap.put(“/captcha.jpg”, “anon”);

filterMap.put(“/aaa.txt”, “anon”);

filterMap.put(“/virtuel/**”, “anon”);

filterMap.put(“/image/**”, “anon”);

filterMap.put(“/**”, “oauth2”);

shiroFilter.setFilterChainDefinitionMap(filterMap);

return shiroFilter;

}

@Bean

public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager) {

AuthorizationAttributeSourceAdvisor advisor = new AuthorizationAttributeSourceAdvisor();

advisor.setSecurityManager(securityManager);

return advisor;

}

@Bean(“lifecycleBeanPostProcessor”)

public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {

return new LifecycleBeanPostProcessor();

}

前端vue element登录:

信息管理系统

<el-form :model=“dataForm” :rules=“dataRule” ref=“dataForm” @keyup.enter.native=“dataFormSubmit()” status-icon>

<img :src=“captchaPath” @click=“getCaptcha()” alt=“”>

<el-button class=“login-btn-submit” type=“danger” @click=“dataFormSubmit()”>登录

主要数据表设计:


数据库表结构文档

============

****数据库名:****renren-dangyuan

****文档版本:****V1.0.0

****文档描述:****数据库表设计描述

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

分享

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

5285)]
[外链图片转存中…(img-nBzXZGAN-1711909175286)]
[外链图片转存中…(img-MImiGRyx-1711909175287)]
[外链图片转存中…(img-gmMeQiLf-1711909175287)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-9FS2cwiX-1711909175287)]

分享

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 13
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
springbootvue是现代web开发中最常用的后端和前端框架之一。前后端分离是一种架构模式,将前端和后端的开发分离,通过接口来进行数据传输和交互。 在线教育系统作为一个实战项目,可以基于springbootvue来开发。首先,我们可以使用springboot来构建后端的RESTful API,处理用户请求、数据持久化等功能。通过使用springboot的优秀特性,可以快速搭建项目的基础框架,并集成常用的开发组件,如Spring MVC、Spring Data JPA等。 而在前端方面,可以使用vue来开发用户界面。vue是一个轻量级的JavaScript框架,可以帮助我们构建交互式的用户界面。通过vue的组件化开发和数据绑定机制,可以提高前端开发效率,并实现良好的用户体验。 在实现前后端分离的时候,可以通过定义RESTful API接口来进行数据的传输和交互。后端使用springboot提供的@RestController注解来处理HTTP请求,并返回JSON格式的数据。前端通过vue的axios库来进行异步请求和交互,获取后端提供的数据并展示在页面上。 在线教育系统常见的功能包括用户登录、课程管理、视频播放等。用户登录可以通过JWT来实现身份认证和授权。课程管理可以包括课程的发布、编辑、删除等功能,通过操作数据库来实现数据的增删改查。视频播放可以通过集成第三方视频播放器,如video.js来实现。 总结来说,使用springbootvue进行前后端分离的在线教育系统的实战项目,可以通过定义RESTful API接口、使用axios进行数据交互和展示、集成第三方插件实现各种功能。通过这种方式,可以提高项目的开发效率、降低耦合性,并实现良好的用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值