shiro相关

public PaginationInnerInterceptor paginationInnerInterceptor()

public PaginationInnerInterceptor paginationInnerInterceptor(){
PaginationInnerInterceptor page = new PaginationInnerInterceptor();
page.setDbType(DbType.MYSQL);
return page;
}中,PaginationInnerInterceptor和paginationInnerInterceptor分别代表什么?是要返回一个PaginationInnerInterceptor 类型的对象吗?

答:在这段代码中,PaginationInnerInterceptor是一个类型,而paginationInnerInterceptor是一个方法名。

PaginationInnerInterceptor是一个分页插件,用于在 MyBatis Plus 中实现分页功能。它可以拦截 SQL 执行,自动进行分页处理。通常情况下,你需要创建一个 PaginationInnerInterceptor 的实例,并进行一些配置,如设置数据库类型(例如,MySQL)等。

paginationInnerInterceptor 则是一个方法,返回一个 PaginationInnerInterceptor 类型的对象。通过调用该方法,你可以获取一个已经配置好的 PaginationInnerInterceptor 实例,以便在 MyBatis Plus 中使用分页功能。

shiroFilterFactoryBean.setSecurityManager(securityManager());

shiroFilterFactoryBean.setSecurityManager(securityManager()); 其中securityManager为什么要加()?
答:在这段代码中,securityManager 是一个方法名,通过加上 () 可以调用该方法并获取返回的对象。

通常情况下,当你想要使用某个方法的返回值时,需要在方法名后面加上 () 来执行该方法并获取返回值。在这里,securityManager() 方法应该是返回了一个 SecurityManager 对象,然后将该对象设置给了 shiroFilterFactoryBean 的 securityManager 属性。

所以,加上 () 是为了调用方法并获取 securityManager 方法的返回值,将其设置给 shiroFilterFactoryBean 对象的 securityManager 属性。这样就可以正确地配置 Shiro 的安全管理器。

@Autowired private IUserService userService爆红

public class UserRealm extends AuthorizingRealm {
@Autowired
private IUserService userService;
@Override
protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
return null;
}在@Autowired处爆红Autowired members must be defined in valid Spring bean (@Component|@Service|…)
答:这个错误提示是因为你使用了 @Autowired 注解注入了一个 IUserService 的实例,但是该实例没有被 Spring 容器管理,所以无法进行自动装配。

解决这个问题,你需要在 IUserService 的实现类上添加一个 Spring 的组件注解,如 @Service 或 @Component。这样,Spring 就会自动扫描该类,并将其实例化并加入到容器中。然后,你就可以在 UserRealm 中通过 @Autowired 注解来自动装配该实例了。

例如,如果 IUserService 的实现类为 UserServiceImpl,你可以在其类声明上添加 @Service 注解:

public interface IUserService extends IService

public interface IUserService extends IService {
/*
* 根据用户名查询用户对象
* */

public User queryUserByUsername(User user);

}IUserService 是一个接口,可以加@Service注释吗?
答:对于接口来说,通常不会直接在接口上使用 @Service 注解。因为 @Service 注解通常用于标识服务层的具体实现类,而不是接口本身。

通常情况下,你会在 IUserService 接口的实现类上添加 @Service 注解,以标识该实现类是一个服务层的组件,需要被 Spring 容器管理和注入到其他组件中。

例如,假设你有一个名为 UserServiceImpl 的 IUserService 接口的实现类,你可以在其类声明上添加 @Service 注解:

@Service
public class UserServiceImpl implements IUserService {
    // implementation details...
}

你可能感兴趣的:(java学习,java)