使用IDEA搭建一个Spring + AOP (权限管理 ) + Spring MVC

简介: 使用IDEA搭建一个Spring + AOP (权限管理 ) + Spring MVC
53 //@Autowired
54 //xxxMapper xxmaper ;
55 //也可以在类上面 直接使用 @ComponentScan 扫描接口
56 @Bean
57 public MapperScannerConfigurer mapperScannerConfigurer() {
58 MapperScannerConfigurer configurer = new MapperScannerConfigurer();
59 configurer.setBasePackage(“com.oukele.dao”);//扫描接口
60 configurer.setSqlSessionFactoryBeanName(“sqlSessionFactoryBean”);
61 return configurer;
62 }
63
64 }

SpringServlet 类 (扫描 )


1 package com.oukele.config.spring;
2
3 import org.springframework.context.annotation.ComponentScan;
4 import org.springframework.context.annotation.Configuration;
5
6 @Configuration
7 @ComponentScan(basePackages = “com.oukele.servlet”)
8 public class SpringServlet {//服务层
9
10 }


WebConfig 类 (类似于 web.xml文件)


1 package com.oukele.config.web;
2
3 import com.oukele.config.mvc.SpringWebConfig;
4 import com.oukele.config.spring.RootConfig;
5 import org.springframework.web.filter.CharacterEncodingFilter;
6 import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
7
8 import javax.servlet.Filter;
9
10 public class WebConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
11
12 @Override
13 protected Class<?>[] getRootConfigClasses() {// (spring容器) 父容器
14 return new Class[]{RootConfig.class};
15 }
16
17 @Override
18 protected Class<?>[] getServletConfigClasses() {// (spring mvc容器) 子容器
19 return new Class[]{SpringWebConfig.class};
20 }
21
22 @Override
23 protected String[] getServletMappings() {//映射
24 return new String[]{“/”};
25 }
26
27 //设置编码 这里设置好像没有用。。。。。 有解决方案请告诉我,谢谢
28 @Override
29 protected Filter[] getServletFilters() {
30 CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
31 characterEncodingFilter.setEncoding(“UTF-8”);
32 return new Filter[]{characterEncodingFilter};
33 }
34 }


Controller 包 里面的类

1 package com.oukele.controller;
2
3 import com.oukele.entity.User;
4 import com.oukele.servlet.UserServlet;
5 import org.springframework.beans.factory.annotation.Autowired;
6 import org.springframework.web.bind.annotation.*;
7 import org.springframework.web.context.WebApplicationContext;
8
9 import javax.servlet.http.HttpSession;
10 import java.util.HashMap;
11 import java.util.Objects;
12
13 @RestController
14 public class LoginController {
15
16 @Autowired
17 private WebApplicationContext webApplicationContext;
18
19 @Autowired
20 private UserServlet userServlet;
21
22 @RequestMapping(path = “/login/{name}/{password}”, method = RequestMethod.GET,produces = “application/json;charset=utf-8”)
23 public String login(@PathVariable(“name”) String name, @PathVariable(“password”) String password, HttpSession session) {
24 User user = new User();
25 user.setUserName(name);
26 user.setPassword(password);
27 session.setAttribute(“username”,user);//存入session中
28 Boolean aBoolean = userServlet.checkUser(user);
29
30 if(aBoolean){
31 return “{“msg”:“登入成功”}”;
32 }
33
34 return “{“msg”:“登入失败”}”;
35 }
36
37 @GetMapping(path = “/Ioc”)
38 public HashMap<String, String[]> getAllInfo() {
39
40 return new HashMap<String, String[]>() {{
41 put(“子容器”, webApplicationContext.getBeanDefinitionNames());
42 put(“父容器”, Objects.requireNonNull(webApplicationContext.getParent().getBeanDefinitionNames()));
43 }};
44
45 }
46
47 }



dao包中的接口

1 package com.oukele.dao;
2
3 import com.oukele.entity.User;
4 import org.apache.ibatis.annotations.Select;
5 import org.springframework.stereotype.Repository;
6
7 @Repository
8 public interface UserMapper {
9
10 //使用xml配置文件
11 int check(User user);
12 //使用注解
13 @Select(“select count(*) from user where userName = #{userName} and password = #{password}”)
14 int check1(User user);
15
16 }



entity包中的类

1 package com.oukele.entity;
2
3 public class User {
4 private String userName;
5 private String password;
6
7 public String getUserName() {
8 return userName;
9 }
10
11 public void setUserName(String userName) {
12 this.userName = userName;
13 }
14
15 public String getPassword() {
16 return password;
17 }
18
19 public void setPassword(String password) {
20 this.password = password;
21 }
22
23 @Override
24 public String toString() {
25 return “User{” +
26 “userName='” + userName + ‘’’ +
27 “, password='” + password + ‘’’ +
28 ‘}’;
29 }
30 }



servlet包中的类

1 package com.oukele.servlet;
2
3 import com.oukele.dao.UserMapper;
4 import com.oukele.entity.User;
5 import org.springframework.beans.factory.annotation.Autowired;
6 import org.springframework.stereotype.Service;
7
8 @Service
9 public class UserServlet {
10
11 @Autowired
12 private UserMapper userMapper;
13
14 public Boolean checkUser(User user){
15 //根据传进来的参数,去数据库查找用户
16 int result = userMapper.check(user);
17 //如果查回来的结果不为零,说明数据库中有该用户,让他登陆,否则不让他登陆
18 if( result > 0 ){
19 return true;
20 }
21 return false;
22 }
23
24 }

resources 目录

jdbc.properties 资源文件

1 jdbc.driver=org.mariadb.jdbc.Driver

2 jdbc.url=jdbc:mariadb://localhost:3306/test

3 jdbc.user=oukele

4 jdbc.password=oukele

mybatis-config.xml 配置文件

<?xml version="1.0" encoding="UTF-8" ?>

mapper文件中的 UserMapper.xml 配置文件


1 <?xml version="1.0" encoding="UTF-8"?>


相关文章
|
5月前
|
缓存 安全 Java
Spring Security通用权限管理模型解析
Spring Security作为Spring生态的核心安全框架,结合RBAC与ACL权限模型,基于IoC与AOP构建灵活、可扩展的企业级权限控制体系,涵盖认证、授权流程及数据库设计、性能优化等实现策略。
398 0
|
5月前
|
缓存 安全 Java
Spring Security权限管理解析
Spring Security是Spring生态中的核心安全框架,采用认证与授权分离架构,提供高度可定制的权限管理方案。其基于过滤器链实现认证流程,通过SecurityContextHolder管理用户状态,并结合RBAC模型与动态权限决策,支持细粒度访问控制。通过扩展点如自定义投票器、注解式校验与前端标签,可灵活适配多租户、API网关等复杂场景。结合缓存优化与无状态设计,适用于高并发与前后端分离架构。
427 0
|
5月前
|
XML 安全 Java
使用 Spring 的 @Aspect 和 @Pointcut 注解简化面向方面的编程 (AOP)
面向方面编程(AOP)通过分离横切关注点,如日志、安全和事务,提升代码模块化与可维护性。Spring 提供了对 AOP 的强大支持,核心注解 `@Aspect` 和 `@Pointcut` 使得定义切面与切入点变得简洁直观。`@Aspect` 标记切面类,集中处理通用逻辑;`@Pointcut` 则通过表达式定义通知的应用位置,提高代码可读性与复用性。二者结合,使开发者能清晰划分业务逻辑与辅助功能,简化维护并提升系统灵活性。Spring AOP 借助代理机制实现运行时织入,与 Spring 容器无缝集成,支持依赖注入与声明式配置,是构建清晰、高内聚应用的理想选择。
610 0
|
9月前
|
监控 安全 Java
Spring AOP实现原理
本内容主要介绍了Spring AOP的核心概念、实现机制及代理生成流程。涵盖切面(Aspect)、连接点(Join Point)、通知(Advice)、切点(Pointcut)等关键概念,解析了JDK动态代理与CGLIB代理的原理及对比,并深入探讨了通知执行链路和责任链模式的应用。同时,详细分析了AspectJ注解驱动的AOP解析过程,包括切面识别、切点表达式匹配及通知适配为Advice的机制,帮助理解Spring AOP的工作原理与实现细节。
1359 13
|
4月前
|
XML Java 数据格式
《深入理解Spring》:AOP面向切面编程深度解析
Spring AOP通过代理模式实现面向切面编程,将日志、事务等横切关注点与业务逻辑分离。支持注解、XML和编程式配置,提供五种通知类型及丰富切点表达式,助力构建高内聚、低耦合的可维护系统。
|
4月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
9月前
|
人工智能 安全 Java
spring boot 权限管理的几种方式
Spring Boot 提供多种权限管理方式,包括基于角色的访问控制(RBAC)、基于属性的访问控制(ABAC)和基于访问控制列表(ACL)。RBAC 通过角色简化权限管理;ABAC 根据用户、资源和环境属性实现细粒度控制;ACL 则为每个资源定义访问控制列表。文中以 Spring Security 为例,详细展示了每种方法的配置与实现步骤,帮助开发者根据项目需求选择合适的权限管理方案。示例涵盖依赖添加、类配置及注解使用等关键环节。
1793 0
|
6月前
|
人工智能 监控 安全
如何快速上手【Spring AOP】?核心应用实战(上篇)
哈喽大家好吖~欢迎来到Spring AOP系列教程的上篇 - 应用篇。在本篇,我们将专注于Spring AOP的实际应用,通过具体的代码示例和场景分析,帮助大家掌握AOP的使用方法和技巧。而在后续的下篇中,我们将深入探讨Spring AOP的实现原理和底层机制。 AOP(Aspect-Oriented Programming,面向切面编程)是Spring框架中的核心特性之一,它能够帮助我们解决横切关注点(如日志记录、性能统计、安全控制、事务管理等)的问题,提高代码的模块化程度和复用性。
|
6月前
|
设计模式 Java 开发者
如何快速上手【Spring AOP】?从动态代理到源码剖析(下篇)
Spring AOP的实现本质上依赖于代理模式这一经典设计模式。代理模式通过引入代理对象作为目标对象的中间层,实现了对目标对象访问的控制与增强,其核心价值在于解耦核心业务逻辑与横切关注点。在框架设计中,这种模式广泛用于实现功能扩展(如远程调用、延迟加载)、行为拦截(如权限校验、异常处理)等场景,为系统提供了更高的灵活性和可维护性。