Spring boot集成shiro

shiro为apache旗下一个权限框架,Apache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理.有三个核心组件:Subject,SecurityManager 和 Realms。

第一步:引入jar包,我这里使用的是gradle
implementation 'org.apache.shiro:shiro-spring:1.3.2'
第二步:配置shiro
package com.sansence.redwine.config;

import com.sansence.redwine.shiro.MyAuthenticationFilter;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.servlet.Filter;
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * @program: shiro03
 * @description: 权限配置
 * @author: jiang wei
 * @create: 2019-04-24 14:13
 */
@Configuration
public class ShiroConfig {

    /**
     * 配置接口权限
     * @param securityManager
     * @return
     */
    @Bean
    public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager){
        ShiroFilterFactoryBean shiroFilterFactoryBean=new ShiroFilterFactoryBean();
        shiroFilterFactoryBean.setSecurityManager(securityManager);
        shiroFilterFactoryBean.setLoginUrl("/admin-info/401");//设置登录界面
        shiroFilterFactoryBean.setUnauthorizedUrl("/manager/login.html");//设置无权限界面

        Map<String, Filter> filter = new LinkedHashMap<>();
        filter.put("authc",new ShiroLoginFilter());
        shiroFilterFactoryBean.setFilters(filter);
        Map<String,String> filterMap=new LinkedHashMap<>();
        filterMap.put("/logs/**","authc");
        filterMap.put("/product/**","authc");
        filterMap.put("/admin-info/login","anon");
        filterMap.put("/admin-info/401","anon");
        filterMap.put("/admin-info/**","authc");
        filterMap.put("/adminware/**","authc");
        filterMap.put("/unit/**","authc");
        filterMap.put("/customer/**","authc");
        filterMap.put("/repertory/**","authc");
        filterMap.put("/role/**","authc");
        filterMap.put("/permission/**","authc");
        filterMap.put("/species/**","authc");
        filterMap.put("/user/**","authc");
        filterMap.put("/userrecord/**","authc");
        filterMap.put("/ware/**","authc");
        filterMap.put("/warerecord/**","authc");
        filterMap.put("/**","anon");
        shiroFilterFactoryBean.setFilterChainDefinitionMap(filterMap);
        return shiroFilterFactoryBean;
    }

    /**
     * 注入权限管理
     * @return
     */
    @Bean
    public SecurityManager securityManager(){
        DefaultWebSecurityManager securityManager=new DefaultWebSecurityManager();
        securityManager.setRealm(customRealm());
        return securityManager;
    }

    @Bean
    public CustomRealm customRealm(){
        return new CustomRealm();
    }
}

以上的权限配置,常用的有以下几种
anon:公开
authc:需认证才可访问
perms:需要哪些权限才能访问例如perms[admin:update,admin:select]
role:要什么角色才可以访问例如role[admin]

登录,授权类

package com.sansence.redwine.config;

import com.sansence.redwine.entity.Admin;
import com.sansence.redwine.service.IAdminService;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.*;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.authz.SimpleAuthorizationInfo;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
import org.springframework.beans.factory.annotation.Autowired;

import java.util.HashSet;
import java.util.Set;

/**
 * @program: shiro03
 * @description: 权限认证
 * @author: jiang wei
 * @create: 2019-04-24 14:04
 */
public class CustomRealm extends AuthorizingRealm {

    @Autowired
    private IAdminService iAdminService;

    /**
     * 获取用户所拥有权限
     * @param principals
     * @return
     */
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
        //String username= (String) SecurityUtils.getSubject().getPrincipal();
        SimpleAuthorizationInfo info=new SimpleAuthorizationInfo();
        String role="admin";
        Set<String> set=new HashSet<>();
        set.add(role);
        info.setRoles(set);
        return info;
    }

    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
        UsernamePasswordToken token= (UsernamePasswordToken) authenticationToken;
        Admin admin=iAdminService.selectAdminByAccount(token.getPrincipal().toString());
        if (admin==null){
            throw new AccountException("该账号不存在");
        }
        if (!admin.getAdminPassword().equals(new String((char[]) token.getCredentials()))){
            throw new AccountException("密码不正确");
        }
        return new SimpleAuthenticationInfo(token.getPrincipal(),admin.getAdminPassword(),getName());
    }
}

第三步:登录与退出登录

package com.sansence.redwine.controller;


import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.sansence.redwine.config.BaseErrorException;
import com.sansence.redwine.entity.Admin;
import com.sansence.redwine.entity.Permission;
import com.sansence.redwine.entity.Role;
import com.sansence.redwine.intercoptor.LogWeb;
import com.sansence.redwine.service.IAdminService;
import com.sansence.redwine.service.IPermissionService;
import com.sansence.redwine.service.IRoleService;
import com.sansence.redwine.util.ResultData;
import com.sansence.redwine.util.Utils;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.session.Session;
import org.apache.shiro.subject.Subject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.*;

import javax.validation.Valid;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * <p>
 *  管理员接口
 * </p>
 * @author wocus
 * @since 2019-05-16
 */
@RestController
@Api(tags = "管理员接口")
@RequestMapping("/admin-info")
public class AdminController {


    @Autowired
    private IAdminService iAdminServic;



    @PostMapping("/login")
    @LogWeb("管理员登录")
    @ApiOperation("管理员登录")
    public ResultData login(@RequestBody Admin admin){
        if (admin.getAdminAccount()==null){
            throw new BaseErrorException(-101,"请输入账号");
        }else if(admin.getAdminPassword()==null){
            throw new BaseErrorException(-101,"请输入密码");
        }
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.eq("adminAccount",admin.getAdminAccount());
        queryWrapper.eq("adminPassword",admin.getAdminPassword());
        Subject subject=SecurityUtils.getSubject();

        UsernamePasswordToken token=new UsernamePasswordToken(admin.getAdminAccount(),admin.getAdminPassword());
        try {
            subject.login(token);
            Session session=subject.getSession();
            session.setAttribute("account",admin.getAdminAccount());
            Admin admin1=iAdminServic.getOne(queryWrapper);
            admin1.setAdminEndLoginTime(Utils.getDateTime());
            iAdminServic.updateById(admin1);
            return ResultData.success(admin1,"登录成功");
        }catch (Exception e){
            e.printStackTrace();
            return ResultData.errorParam("账号与密码不匹配");
        }
    }

    @PostMapping("/logout")
    @LogWeb("管理员退出登录")
    @ApiOperation("管理员退出登录")
    public ResultData logout(){
        Subject subject= SecurityUtils.getSubject();
        subject.logout();
        return ResultData.result(1);
    }
}

到这里就完成了,下一文章讲在ajax中如何实现权限验证

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容