博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springboot mybatis redis shiro 权限控制(springboot模块化使用,后台代码已经完成)...
阅读量:6296 次
发布时间:2019-06-22

本文共 48454 字,大约阅读时间需要 161 分钟。

springboot mybatis redis shiro 权限控制(springboot模块化使用,后台代码已经完成)

配置文件 以及 module创建

1、新建parent maven项目,编写 pom.xml

4.0.0
com.vuix
vuixparent
pom
1.0-SNAPSHOT
service
bts
org.springframework.boot
spring-boot-starter-parent
1.5.9.RELEASE
org.springframework.boot
spring-boot-starter-web
org.mybatis.spring.boot
mybatis-spring-boot-starter
1.3.0
org.springframework.boot
spring-boot-starter-data-redis
org.springframework.boot
spring-boot-starter-test
test
org.quartz-scheduler
quartz
1.8.4
org.springframework.boot
spring-boot-starter-thymeleaf
net.sourceforge.nekohtml
nekohtml
1.9.22
org.springframework.session
spring-session-data-redis
mysql
mysql-connector-java
com.alibaba
druid-spring-boot-starter
1.1.0
com.alibaba
fastjson
1.2.44
org.apache.shiro
shiro-spring
1.2.4
org.apache.shiro
shiro-ehcache
1.2.4
org.apache.shiro
shiro-cas
1.2.4

2、新建service module maven项目,编写pom.xml

vuixparent
com.vuix
1.0-SNAPSHOT
4.0.0
service
org.springframework.boot
spring-boot-maven-plugin

3、新建bts module maven工程 pom.xml

vuixparent
com.vuix
1.0-SNAPSHOT
4.0.0
bts
com.vuix
service
1.0-SNAPSHOT

4、在应用 bts 下面resources 下面新建 application.yml

server:  port: 8888spring:  datasource:    driver-class-name: com.mysql.jdbc.Driver    url: jdbc:mysql://localhost:3306/db_vuix    username: root    password: root    type: com.alibaba.druid.pool.DruidDataSource  redis:    database: 0    password:    port: 6379    host: 127.0.0.1    pool:      max-active: 8      max-wait: 10      max-idle: 8      min-idle: 0  thymeleaf:      cache: false      mode: LEGACYHTML5mybatis:  config-location: classpath:mybatis-config.xml  type-aliases-package: com.vuix.dao.entity  mapper-locations: classpath:mapper/*.xml

下面是mapper.xml配合和应用代码

## mybatis-config.xml 代码如下 ##

业务代码的mapper.xml代码如下

下面是java类

## entity 类##package com.vuix.dao;import com.alibaba.fastjson.JSON;import java.io.Serializable;public class ABaseEntity implements Serializable{    private Long id;    public Long getId() {        return id;    }    public void setId(Long id) {        this.id = id;    }    @Override    public String toString() {        return JSON.toJSONString(this);    }}package com.vuix.dao.entity;import java.io.Serializable;import java.util.List;public class UserInfo implements Serializable{    private Long uid;    private String username;    private String name;    private String password;    private String salt;    private int state;    private List
roleList; public List
getRoleList() { return roleList; } public void setRoleList(List
roleList) { this.roleList = roleList; } public Long getUid() { return uid; } public void setUid(Long uid) { this.uid = uid; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getSalt() { return salt; } public void setSalt(String salt) { this.salt = salt; } public int getState() { return state; } public void setState(int state) { this.state = state; } /** * 密码盐. * @return */ public String getCredentialsSalt(){ return this.username+this.salt; }}package com.vuix.dao.entity;import com.vuix.dao.ABaseEntity;public class TeampleEntity extends ABaseEntity { private String userName; private String password; private String phone; public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; }}package com.vuix.dao.entity;import java.io.Serializable;public class SysUserRole implements Serializable { private Long roleId; private Long uid; public Long getRoleId() { return roleId; } public void setRoleId(Long roleId) { this.roleId = roleId; } public Long getUid() { return uid; } public void setUid(Long uid) { this.uid = uid; }}package com.vuix.dao.entity;import java.io.Serializable;public class SysRolePermission implements Serializable{ private Long permissionId; private Long roleId; public Long getPermissionId() { return permissionId; } public void setPermissionId(Long permissionId) { this.permissionId = permissionId; } public Long getRoleId() { return roleId; } public void setRoleId(Long roleId) { this.roleId = roleId; }}package com.vuix.dao.entity;import java.io.Serializable;import java.util.List;public class SysRole implements Serializable { private Long id; private Integer available; private String description; private String role; private List
permissions; public List
getPermissions() { return permissions; } public void setPermissions(List
permissions) { this.permissions = permissions; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public Integer getAvailable() { return available; } public void setAvailable(Integer available) { this.available = available; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public String getRole() { return role; } public void setRole(String role) { this.role = role; }}package com.vuix.dao.entity;import java.io.Serializable;import java.util.List;public class SysPermission implements Serializable { private Long id; private Integer available; private String name; private Long parentId; private String parentIds; private String permission; private String resourceType; private String url; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public Integer getAvailable() { return available; } public void setAvailable(Integer available) { this.available = available; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Long getParentId() { return parentId; } public void setParentId(Long parentId) { this.parentId = parentId; } public String getParentIds() { return parentIds; } public void setParentIds(String parentIds) { this.parentIds = parentIds; } public String getPermission() { return permission; } public void setPermission(String permission) { this.permission = permission; } public String getResourceType() { return resourceType; } public void setResourceType(String resourceType) { this.resourceType = resourceType; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; }}package com.vuix.dao.entity;import com.vuix.dao.ABaseEntity;import java.util.Date;import java.util.List;public class MenuEntity extends ABaseEntity { private String name; private String icon; private Long parentId; private Integer isDelete; private String url; private Date createdTime; private Date updateTime; private boolean isHasMenu = false; public boolean isHasMenu() { return isHasMenu; } public void setHasMenu(boolean hasMenu) { isHasMenu = hasMenu; } private List
list; public List
getList() { return list; } public void setList(List
list) { this.list = list; } public Integer getIsDelete() { return isDelete; } public void setIsDelete(Integer isDelete) { this.isDelete = isDelete; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getIcon() { return icon; } public void setIcon(String icon) { this.icon = icon; } public Long getParentId() { return parentId; } public void setParentId(Long parentId) { this.parentId = parentId; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public Date getCreatedTime() { return createdTime; } public void setCreatedTime(Date createdTime) { this.createdTime = createdTime; } public Date getUpdateTime() { return updateTime; } public void setUpdateTime(Date updateTime) { this.updateTime = updateTime; }}## mapper 类 ##package com.vuix.dao;import java.util.List;public interface IBaseMapper
{ // 增加 Long insert(T entity); // 修改 void update(T entity); // 删除 void deleteByPrimarykey(Long id); // 查询单个对象 T queryByPrimarykey(Long id); // 分页查询 List
queryByPager(APagerEntity
pagerEntity); // 查询所有的 List
queryAll();}package com.vuix.dao;public class APagerEntity
{ // 条件 private T entity; public APagerEntity(){ super(); } private int index; // 当前页码 private int isStart = 0; // 开始值 entity 下面不得有这些条件 private int isLength = 10; // 大小 entity 下面不得有这些条件 public T getEntity() { return entity; } public void setEntity(T entity) { this.entity = entity; } public int getIndex() { if (index <= 0) { index = 1; } return index; } public void setIndex(int index) { this.index = index; } public int getIsStart() { isStart = (getIndex() - 1 ) * getIsLength(); return isStart; } public void setIsStart(int isStart) { this.isStart = isStart; } public int getIsLength() { return isLength; } public void setIsLength(int isLength) { this.isLength = isLength; }}package com.vuix.dao.mapper;import com.vuix.dao.entity.UserInfo;import org.apache.ibatis.annotations.Param;public interface UserInfoMapper { // 用户名查询 userInfo UserInfo findByUsername(@Param("username") String username);}package com.vuix.dao.mapper;import com.vuix.dao.IBaseMapper;import com.vuix.dao.entity.TeampleEntity;public interface TeampleMapper extends IBaseMapper
{}package com.vuix.dao.mapper;import com.vuix.dao.entity.SysRole;import org.apache.ibatis.annotations.Param;import java.util.List;public interface SysRoleMapper { // 查询用户权限 List
findListByUid(@Param("uid") Long uid);}package com.vuix.dao.mapper;import com.vuix.dao.entity.SysPermission;import org.apache.ibatis.annotations.Param;import java.util.List;public interface SysPermissionMapper { List
findListByRoleId(@Param("roleId") Long roleId); List
queryAll(); }package com.vuix.dao.mapper;import com.vuix.dao.IBaseMapper;import com.vuix.dao.entity.MenuEntity;import org.apache.ibatis.annotations.Param;import java.util.List;public interface MenuMapper extends IBaseMapper
{ List
findListByParentId(@Param("parentId") Long parentId);}## util 类 ##package com.vuix.util;public class VuixUtil { public static boolean isNull(String value) { if (value == null || value.trim().equals("") || value.length() == 0){ return true; } return false; } public static boolean isNotNull(String value) { return !isNull(value); }}## service类##package com.vuix.service;import com.alibaba.fastjson.JSON;import com.vuix.util.VuixUtil;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.data.redis.core.StringRedisTemplate;import java.util.List;/** * @Cacheable 表明在Spring调用之前,首先应该在缓存中查找方法的返回值, * 如果这个值能够找到,就会返回缓存的值, * 否则这个方法会被调用,返回值会放到缓存中 * * @CachePut 表明Spring应该将该方法返回值放到缓存中,在方法调用前不会检查缓存,方法始终会被调用 * * @CacheEvict 表明Spring应该在缓存中清楚一个或多个条目 * * @Caching 分组注解,能够同时应用多个其他的缓存注解 * * @CacheConfig 可以在类层级配置一些共有的缓存配置 * * @Cacheable和@CachePut有一些共有的属性: * * 属性 类型 描述 * value String[] 缓存名称 * condition SpEL表达式,如果得到的值是false,则不会应用缓存在该方法 * key String SpEl表达式,用来计算自定义的缓存key * unless String SpEl表达式,如果得到的值为true,返回值不会放到缓存中 * */public abstract class ABaseService { protected final Logger logger = LoggerFactory.getLogger(this.getClass()); protected static final String root_symbol = ":"; // 默认保存时间 protected static final Long default_millisecond = 24 * 60 * 60 * 1000L; @Autowired private StringRedisTemplate stringRedisTemplate; protected String generalRedisKey(String... parameters) { StringBuffer stringBuffer = new StringBuffer(); if (parameters.length > 0) { for (String parameter : parameters) { stringBuffer.append(parameter).append(root_symbol); } } if (stringBuffer.length() > 0) { return stringBuffer.toString().substring(0,stringBuffer.length()-1); } return null; } protected void removeCache(String key) { if (VuixUtil.isNotNull(key)){ stringRedisTemplate.delete(key); } } protected
List
getListCache(String key,Class
targetClass) { if (VuixUtil.isNotNull(key)) { String value = stringRedisTemplate.opsForValue().get(key); logger.info("ABaseService getListCache:value:{}",value); if (VuixUtil.isNotNull(value)){ List
targets = JSON.parseArray(value,targetClass); return targets; } } return null; } // get缓存 protected
T getFormCache(String key,Class
targetClass) { if (VuixUtil.isNotNull(key)) { String value = stringRedisTemplate.opsForValue().get(key); if (VuixUtil.isNotNull(value)){ logger.info("ABaseService getFormCache:value:{}",value); T target = JSON.parseObject(value,targetClass); return target; } } return null; } // 放进缓存 protected void putCache(String key,Object object) { putCache(key,object,default_millisecond); } protected void putCache(String key,Object object,Long millisecond) { if (object != null) { String value = JSON.toJSONString(object); logger.info("ABaseService putCache:value:{}",value); stringRedisTemplate.opsForValue().set(key,value,millisecond); } }}package com.vuix.service;public interface RootNamespace { String root_namespace = "root"; String root_symbol = ":";}package com.vuix.service;import com.vuix.dao.entity.MenuEntity;import java.util.List;public interface MenuService extends RootNamespace { List
findList(Long parentId);}package com.vuix.service;import com.vuix.dao.entity.SysPermission;import java.util.List;public interface SysPermissionService extends RootNamespace{ String class_name = "sysPermission"; List
findListByRoleId(Long roleId); // 查询全部的权限 List
queryAll();}package com.vuix.service;import com.vuix.dao.entity.SysRole;import java.util.List;public interface SysRoleService extends RootNamespace { String class_name = "sysRole"; List
findListByUid(Long uid);}package com.vuix.service;import com.vuix.dao.entity.TeampleEntity;import java.util.List;public interface TeampleService extends RootNamespace { String class_name = "teample"; TeampleEntity queryByPrimarykey(Long id); List
queryAll(); void update(TeampleEntity entity); Long insert(TeampleEntity entity);}package com.vuix.service;import com.vuix.dao.entity.UserInfo;public interface UserInfoService extends RootNamespace{ String class_name = "userInfo"; UserInfo findByUsername(String username);}## service impl 类 ###package com.vuix.service.impl;import com.vuix.dao.entity.MenuEntity;import com.vuix.dao.mapper.MenuMapper;import com.vuix.service.ABaseService;import com.vuix.service.MenuService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class MenuServiceImpl extends ABaseService implements MenuService{ @Autowired private MenuMapper menuMapper; @Override public List
findList(Long parentId) { if (parentId == null) { parentId = 0L; } // 加入redis 缓存 做两级菜单 后期有的话 使用递归 List
list = menuMapper.findListByParentId(parentId); for (MenuEntity menu : list) { List
list2 = menuMapper.findListByParentId(menu.getId()); if ( list2 != null && list2.size() > 0) { menu.setHasMenu(true); menu.setList(list2); } } return list; }}package com.vuix.service.impl;import com.vuix.dao.entity.SysPermission;import com.vuix.dao.mapper.SysPermissionMapper;import com.vuix.service.ABaseService;import com.vuix.service.SysPermissionService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class SysPermissionServiceImpl extends ABaseService implements SysPermissionService { @Autowired private SysPermissionMapper sysPermissionMapper; @Override public List
findListByRoleId(Long roleId) {// String key = generalRedisKey(root_namespace,class_name,"roleId",roleId.toString());// List
list = getListCache(key,SysPermission.class);// if (list == null) {// list = sysPermissionMapper.findListByRoleId(roleId);// putCache(key,list);// } return sysPermissionMapper.findListByRoleId(roleId); } @Override public List
queryAll() { return sysPermissionMapper.queryAll(); }}package com.vuix.service.impl;import com.vuix.dao.entity.SysRole;import com.vuix.dao.mapper.SysRoleMapper;import com.vuix.service.ABaseService;import com.vuix.service.SysRoleService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class SysRoleServiceImpl extends ABaseService implements SysRoleService { @Autowired private SysRoleMapper sysRoleMapper; @Override public List
findListByUid(Long uid) {// String key = generalRedisKey(root_namespace,class_name,"uid",uid.toString());// List
list = getListCache(key,SysRole.class);// if (list == null) {// list = sysRoleMapper.findListByUid(uid);// putCache(key,list);// } return sysRoleMapper.findListByUid(uid); }}package com.vuix.service.impl;import com.vuix.dao.entity.TeampleEntity;import com.vuix.dao.mapper.TeampleMapper;import com.vuix.service.ABaseService;import com.vuix.service.TeampleService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.ArrayList;import java.util.List;@Servicepublic class TeampleServiceImpl extends ABaseService implements TeampleService { @Autowired private TeampleMapper teampleMapper; @Override public TeampleEntity queryByPrimarykey(Long id) { String key = generalRedisKey(root_namespace,class_name,id.toString()); TeampleEntity result = getFormCache(key,TeampleEntity.class); if (result == null) { result = teampleMapper.queryByPrimarykey(id); putCache(key,result); } return result; } @Override public List
queryAll() { List
list = teampleMapper.queryAll(); return list; } @Override public void update(TeampleEntity entity) { } @Override public Long insert(TeampleEntity entity) { return null; }}package com.vuix.service.impl;import com.vuix.dao.entity.SysPermission;import com.vuix.dao.entity.SysRole;import com.vuix.dao.entity.UserInfo;import com.vuix.dao.mapper.UserInfoMapper;import com.vuix.service.ABaseService;import com.vuix.service.SysPermissionService;import com.vuix.service.SysRoleService;import com.vuix.service.UserInfoService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class UserInfoServiceImpl extends ABaseService implements UserInfoService { @Autowired private UserInfoMapper userInfoMapper; @Autowired private SysRoleService sysRoleService; @Autowired private SysPermissionService sysPermissionService; @Override public UserInfo findByUsername(String username) { // 查询redis下面的值// String key = generalRedisKey(root_namespace,class_name,"username",username);// UserInfo userInfo = getFormCache(key,UserInfo.class);// if (userInfo == null) { // 数据库处理业务 UserInfo userInfo = userInfoMapper.findByUsername(username); // 放入缓存// putCache(key,userInfo);// } // 查询权限 List
sysRoles = sysRoleService.findListByUid(userInfo.getUid()); // 给sysRole对象 赋值权限 for (SysRole sysRole : sysRoles) { List
sysPermissions = sysPermissionService.findListByRoleId(sysRole.getId()); sysRole.setPermissions(sysPermissions); } userInfo.setRoleList(sysRoles); return userInfo; }}

下面是bts下面controller包下面的java类

package com.vuix.bts;import com.vuix.dao.entity.UserInfo;import org.apache.shiro.SecurityUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.web.context.ContextLoader;import org.springframework.web.context.WebApplicationContext;import org.springframework.web.context.request.RequestContextHolder;import org.springframework.web.context.request.ServletRequestAttributes;import org.springframework.web.servlet.ModelAndView;import javax.servlet.ServletContext;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;public abstract class ABaseController {    protected final Logger logger = LoggerFactory.getLogger(ABaseController.class);    protected UserInfo getCurrentUserInfo(){        UserInfo userInfo = (UserInfo) SecurityUtils.getSubject().getPrincipal();        return userInfo;    }    /**     * springMVC 获取requset     *     * @return     */    public HttpServletRequest getRequest() {        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes())                .getRequest();        return request;    }    /**     * 获取response     *     * @return     */    public HttpServletResponse getResponse() {        HttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes())                .getResponse();        return response;    }    /**     * 获取session     *     * @return     */    public HttpSession getSession() {        HttpSession session = this.getRequest().getSession();        return session;    }    /**     * 获取ServletContext     *     * @return     */    public ServletContext getServletContent() {        // ServletContext application= request.getServletContext();        WebApplicationContext webApplicationContext = ContextLoader.getCurrentWebApplicationContext();        ServletContext servletContext = webApplicationContext.getServletContext();        return servletContext;    }    /**     * 获取ModelAndView     *     * @return     */    public ModelAndView getModelAndView() {        return new ModelAndView();    }    public ModelAndView get404ModelAndView() {        ModelAndView view = new ModelAndView();        view.setViewName("404");        return view;    }    /**     * 获取ip     *     * @return     */    public String getRemortIP() {        HttpServletRequest request = this.getRequest();        String ip = "";        if (request.getHeader("x-forwarded-for") == null) {            ip = request.getRemoteAddr();        } else {            ip = request.getHeader("x-forwarded-for");        }        return ip;    }    /**     * 获取port     *     * @return     */    public int getPort() {        return this.getRequest().getServerPort();    }    /**     * 获取ip     *     * @return     */    public String getIpAddr() {        HttpServletRequest request = this.getRequest();        String ip = request.getHeader("x-forwarded-for");        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {            ip = request.getHeader("Proxy-Client-IP");        }        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {            ip = request.getHeader("WL-Proxy-Client-IP");        }        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {            ip = request.getRemoteAddr();        }        return ip;    }}package com.vuix.bts.controller;import com.alibaba.fastjson.JSON;import com.vuix.bts.ABaseController;import com.vuix.dao.entity.MenuEntity;import com.vuix.dao.entity.UserInfo;import com.vuix.service.MenuService;import org.apache.shiro.SecurityUtils;import org.apache.shiro.authc.IncorrectCredentialsException;import org.apache.shiro.authc.UnknownAccountException;import org.apache.shiro.subject.Subject;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.ui.Model;import org.springframework.web.bind.annotation.RequestMapping;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpSession;import java.util.List;import java.util.Map;@Controllerpublic class IndexController extends ABaseController{    @Autowired    private MenuService menuService;    @RequestMapping({"/","/index"})    public String index(Model model) {        // 加载菜单树        List
menuList = menuService.findList(null); // 获取登录用户的详细 UserInfo userInfo = getCurrentUserInfo(); logger.info("IndexController index: userInfo:{}", JSON.toJSONString(userInfo)); model.addAttribute("userInfo",userInfo); model.addAttribute("menuList",menuList); return"/index"; } @RequestMapping(value = "logout") public String logout(){ Subject subject = SecurityUtils.getSubject(); subject.logout(); //跳转登陆页面 return "login"; } @RequestMapping("/login") public String login(HttpServletRequest request, Map
map) throws Exception{ logger.info("HomeController.login()"); // 登录失败从request中获取shiro处理的异常信息。 // shiroLoginFailure:就是shiro异常类的全类名. String exception = (String) request.getAttribute("shiroLoginFailure"); logger.info("exception:{}",exception); String msg = ""; if (exception != null) { if (UnknownAccountException.class.getName().equals(exception)) { logger.error("UnknownAccountException -- > 账号不存在:"); msg = "UnknownAccountException -- > 账号不存在:"; } else if (IncorrectCredentialsException.class.getName().equals(exception)) { logger.error("IncorrectCredentialsException -- > 密码不正确:"); msg = "IncorrectCredentialsException -- > 密码不正确:"; } else if ("kaptchaValidateFailed".equals(exception)) { logger.error("kaptchaValidateFailed -- > 验证码错误"); msg = "kaptchaValidateFailed -- > 验证码错误"; } else { msg = "else >> "+exception; logger.error("else -- >" + exception); } } map.put("msg", msg); // 此方法不处理登录成功,由shiro进行处理 return "/login"; } @RequestMapping("/403") public String unauthorizedRole(){ logger.info("------没有权限-------"); return "403"; }}package com.vuix.bts.controller;import com.vuix.bts.ABaseController;import com.vuix.dao.entity.MenuEntity;import com.vuix.service.MenuService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.ui.Model;import org.springframework.web.bind.annotation.RequestMapping;import java.util.List;@Controller@RequestMapping(value = "menu")public class MenuController extends ABaseController{ @Autowired private MenuService menuService; @RequestMapping(value = "list") public String list(Model model) { List
list = menuService.findList(null); model.addAttribute("list",list); return "page/menu/list"; }}package com.vuix.bts.controller;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.PathVariable;import org.springframework.web.bind.annotation.RequestMapping;@Controllerpublic class PageController { private static final Logger logger = LoggerFactory.getLogger(PageController.class); @RequestMapping("/include/{pageName}") public String include(@PathVariable("pageName") String pageName){ logger.info("PageController include : /include/"+pageName); return "include/"+pageName; }}package com.vuix.bts.controller;import com.vuix.bts.ABaseController;import com.vuix.dao.entity.TeampleEntity;import com.vuix.service.TeampleService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.ui.Model;import org.springframework.web.bind.annotation.RequestMapping;import java.util.List;@Controller@RequestMapping(value = "teample")public class TeampleController extends ABaseController{ @Autowired private TeampleService teampleService; @RequestMapping(value = "list") public String list(Model model) { List
list = teampleService.queryAll(); model.addAttribute("list",list); return "page/teample/list"; }}package com.vuix.bts.controller;import org.apache.shiro.authz.annotation.RequiresPermissions;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;@Controller@RequestMapping("/userInfo")public class UserInfoController { /** * 用户查询. * @return */ @RequestMapping("/userList") @RequiresPermissions("userInfo:view")//权限管理; public String userInfo(){ return "userInfo"; } /** * 用户添加; * @return */ @RequestMapping("/userAdd") @RequiresPermissions("userInfo:add")//权限管理; public String userInfoAdd(){ return "userInfoAdd"; } /** * 用户删除; * @return */ @RequestMapping("/userDel") @RequiresPermissions("userInfo:del")//权限管理; public String userDel(){ return "userInfoDel"; } @RequestMapping("/userEdit") @RequiresPermissions("userInfo:edit")//权限管理; public String userEdit(){ return "userInfoEdit"; }}## bts Config类 ##package com.vuix.bts.config;import com.alibaba.fastjson.JSON;import com.vuix.dao.entity.SysPermission;import com.vuix.dao.entity.SysRole;import com.vuix.dao.entity.UserInfo;import com.vuix.service.UserInfoService;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.apache.shiro.util.ByteSource;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;public class LoginShiroRealm extends AuthorizingRealm { private static final Logger logger = LoggerFactory.getLogger(LoginShiroRealm.class); @Autowired private UserInfoService userInfoService; @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) { logger.info("权限配置-->MyShiroRealm.doGetAuthorizationInfo()"); SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo(); UserInfo userInfo = (UserInfo)principals.getPrimaryPrincipal(); for(SysRole role:userInfo.getRoleList()){ authorizationInfo.addRole(role.getRole()); for(SysPermission p:role.getPermissions()){ authorizationInfo.addStringPermission(p.getPermission()); } } return authorizationInfo; } /*主要是用来进行身份认证的,也就是说验证用户输入的账号和密码是否正确。*/ @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException { logger.info("LoginShiroRealm.doGetAuthenticationInfo()"); //获取用户的输入的账号. String username = (String)token.getPrincipal(); logger.info("token.getCredentials() : str:{}", JSON.toJSONString(token.getCredentials())); //通过username从数据库中查找 User对象,如果找到,没找到. //实际项目中,这里可以根据实际情况做缓存,如果不做,Shiro自己也是有时间间隔机制,2分钟内不会重复执行该方法 UserInfo userInfo = userInfoService.findByUsername(username); logger.info("----->>userInfo={}",JSON.toJSONString(userInfo)); if(userInfo == null){ return null; } SimpleAuthenticationInfo authenticationInfo = new SimpleAuthenticationInfo( userInfo, //用户名 userInfo.getPassword(), //密码 ByteSource.Util.bytes(userInfo.getCredentialsSalt()),//salt=username+salt getName() //realm name ); return authenticationInfo; }}package com.vuix.bts.config;import com.fasterxml.jackson.annotation.JsonAutoDetect;import com.fasterxml.jackson.annotation.PropertyAccessor;import com.fasterxml.jackson.databind.ObjectMapper;import org.springframework.cache.CacheManager;import org.springframework.cache.annotation.CachingConfigurerSupport;import org.springframework.cache.annotation.EnableCaching;import org.springframework.cache.interceptor.KeyGenerator;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.cache.RedisCacheManager;import org.springframework.data.redis.connection.RedisConnectionFactory;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.data.redis.core.StringRedisTemplate;import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;import java.lang.reflect.Method;@Configuration@EnableCachingpublic class RedisConfig extends CachingConfigurerSupport{// @Bean// public KeyGenerator keyGenerator() {// return new KeyGenerator() {// @Override// public Object generate(Object target, Method method, Object... params) {// StringBuilder sb = new StringBuilder();// sb.append(target.getClass().getSimpleName());// sb.append(method.getName());// for (Object obj : params) {// sb.append(obj.toString());// }// return sb.toString();// }// };// } @SuppressWarnings("rawtypes") @Bean public CacheManager cacheManager(RedisTemplate redisTemplate) { RedisCacheManager redisCacheManager = new RedisCacheManager(redisTemplate); //设置缓存过期时间 //rcm.setDefaultExpiration(60);//秒 return redisCacheManager; } @Bean public RedisTemplate
redisTemplate(RedisConnectionFactory redisConnectionFactory) { StringRedisTemplate stringRedisTemplate = new StringRedisTemplate(redisConnectionFactory); return stringRedisTemplate; }}package com.vuix.bts.config;import org.springframework.context.annotation.Configuration;import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;@Configuration@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 86400*30)public class SessionConfig {}package com.vuix.bts.config;import com.vuix.dao.entity.SysPermission;import com.vuix.service.SysPermissionService;import org.apache.shiro.authc.credential.HashedCredentialsMatcher;import org.apache.shiro.mgt.SecurityManager;import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;import org.apache.shiro.spring.web.ShiroFilterFactoryBean;import org.apache.shiro.web.mgt.DefaultWebSecurityManager;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.handler.SimpleMappingExceptionResolver;import java.util.LinkedHashMap;import java.util.List;import java.util.Map;import java.util.Properties;@Configurationpublic class ShiroConfig { private static final Logger logger = LoggerFactory.getLogger(ShiroConfig.class); @Autowired private SysPermissionService sysPermissionService; @Bean public ShiroFilterFactoryBean shirFilter(SecurityManager securityManager) { logger.info("ShiroConfiguration.shirFilter()"); ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); //拦截器. Map
filterChainDefinitionMap = new LinkedHashMap
(); // 配置不会被拦截的链接 顺序判断 filterChainDefinitionMap.put("/bower_components/**", "anon"); filterChainDefinitionMap.put("/dist/**", "anon"); filterChainDefinitionMap.put("/images/**", "anon"); filterChainDefinitionMap.put("/js/**", "anon"); filterChainDefinitionMap.put("/plugins/**", "anon"); filterChainDefinitionMap.put("/ztree/**", "anon"); //配置退出 过滤器,其中的具体的退出代码Shiro已经替我们实现了 filterChainDefinitionMap.put("/logout", "logout"); //
:这是一个坑呢,一不小心代码就不好使了; //
List
sysPermissions = sysPermissionService.queryAll(); for (SysPermission sysPermission : sysPermissions) { filterChainDefinitionMap.put("/" + sysPermission.getUrl(), "perms["+sysPermission.getPermission()+"]"); } filterChainDefinitionMap.put("/**", "authc"); // 如果不设置默认会自动寻找Web工程根目录下的"/login.jsp"页面 shiroFilterFactoryBean.setLoginUrl("/login"); // 登录成功后要跳转的链接 shiroFilterFactoryBean.setSuccessUrl("/index"); //未授权界面; shiroFilterFactoryBean.setUnauthorizedUrl("/403"); shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } /** * 凭证匹配器 * (由于我们的密码校验交给Shiro的SimpleAuthenticationInfo进行处理了 * ) * @return */ @Bean public HashedCredentialsMatcher hashedCredentialsMatcher(){ HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher(); hashedCredentialsMatcher.setHashAlgorithmName("md5");//散列算法:这里使用MD5算法; hashedCredentialsMatcher.setHashIterations(2);//散列的次数,比如散列两次,相当于 md5(md5("")); return hashedCredentialsMatcher; } @Bean public LoginShiroRealm loginShiroRealm(){ LoginShiroRealm loginShiroRealm = new LoginShiroRealm(); loginShiroRealm.setCredentialsMatcher(hashedCredentialsMatcher()); return loginShiroRealm; } @Bean public SecurityManager securityManager(){ DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); securityManager.setRealm(loginShiroRealm()); return securityManager; } /** * 开启shiro aop注解支持. * 使用代理方式;所以需要开启代码支持; * @param securityManager * @return */ @Bean public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager){ AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor(); authorizationAttributeSourceAdvisor.setSecurityManager(securityManager); return authorizationAttributeSourceAdvisor; } @Bean(name="simpleMappingExceptionResolver") public SimpleMappingExceptionResolver createSimpleMappingExceptionResolver() { SimpleMappingExceptionResolver r = new SimpleMappingExceptionResolver(); Properties mappings = new Properties(); mappings.setProperty("DatabaseException", "databaseError");//数据库异常处理 mappings.setProperty("UnauthorizedException","403"); r.setExceptionMappings(mappings); // None by default r.setDefaultErrorView("error"); // No default r.setExceptionAttribute("ex"); // Default is "exception" //r.setWarnLogCategory("example.MvcLogger"); // No default return r; }}

启动类 BtsMainApplication

package com.vuix;import org.mybatis.spring.annotation.MapperScan;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication@MapperScan("com.vuix.dao.mapper")public class BtsMainApplication {    private static final Logger logger = LoggerFactory.getLogger(BtsMainApplication.class);    public static void main(String[] args) {        SpringApplication.run(BtsMainApplication.class,args);        logger.info("BtsMainApplication main running...");    }}
下面附上对应的sql
/*Navicat MySQL Data TransferSource Server         : localhostSource Server Version : 50537Source Host           : localhost:3306Source Database       : db_vuixTarget Server Type    : MYSQLTarget Server Version : 50537File Encoding         : 65001Date: 2018-04-27 15:37:24*/SET FOREIGN_KEY_CHECKS=0;-- ------------------------------ Table structure for `sys_permission`-- ----------------------------DROP TABLE IF EXISTS `sys_permission`;CREATE TABLE `sys_permission` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `available` int(10) DEFAULT NULL,  `name` varchar(255) DEFAULT NULL,  `parent_id` int(11) DEFAULT NULL,  `parent_ids` varchar(255) DEFAULT NULL,  `permission` varchar(255) DEFAULT NULL,  `resource_type` varchar(255) DEFAULT NULL,  `url` varchar(255) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;-- ------------------------------ Records of sys_permission-- ----------------------------INSERT INTO `sys_permission` VALUES ('1', '0', '用户管理', '0', '0/', 'userInfo:view', 'menu', 'userInfo/userList');INSERT INTO `sys_permission` VALUES ('2', '0', '用户添加', '1', '0/1', 'userInfo:add', 'button', 'userInfo/userAdd');INSERT INTO `sys_permission` VALUES ('3', '0', '用户删除', '1', '0/1', 'userInfo:del', 'button', 'userInfo/userDel');-- ------------------------------ Table structure for `sys_role`-- ----------------------------DROP TABLE IF EXISTS `sys_role`;CREATE TABLE `sys_role` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `available` int(10) DEFAULT NULL,  `description` varchar(255) DEFAULT NULL,  `role` varchar(255) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;-- ------------------------------ Records of sys_role-- ----------------------------INSERT INTO `sys_role` VALUES ('1', '0', '管理员', 'admin');INSERT INTO `sys_role` VALUES ('2', '0', 'VIP会员', 'vip');INSERT INTO `sys_role` VALUES ('3', '1', 'test', 'test');-- ------------------------------ Table structure for `sys_role_permission`-- ----------------------------DROP TABLE IF EXISTS `sys_role_permission`;CREATE TABLE `sys_role_permission` (  `permission_id` int(11) NOT NULL,  `role_id` int(11) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- ------------------------------ Records of sys_role_permission-- ----------------------------INSERT INTO `sys_role_permission` VALUES ('1', '1');INSERT INTO `sys_role_permission` VALUES ('2', '1');INSERT INTO `sys_role_permission` VALUES ('3', '2');-- ------------------------------ Table structure for `sys_user_role`-- ----------------------------DROP TABLE IF EXISTS `sys_user_role`;CREATE TABLE `sys_user_role` (  `role_id` int(11) NOT NULL,  `uid` int(11) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- ------------------------------ Records of sys_user_role-- ----------------------------INSERT INTO `sys_user_role` VALUES ('1', '1');-- ------------------------------ Table structure for `user_info`-- ----------------------------DROP TABLE IF EXISTS `user_info`;CREATE TABLE `user_info` (  `uid` int(11) NOT NULL AUTO_INCREMENT,  `username` varchar(255) NOT NULL,  `name` varchar(255) DEFAULT NULL,  `password` varchar(255) NOT NULL,  `salt` varchar(255) DEFAULT NULL,  `state` tinyint(1) DEFAULT NULL,  PRIMARY KEY (`uid`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;-- ------------------------------ Records of user_info-- ----------------------------INSERT INTO `user_info` VALUES ('1', 'admin', '管理员', 'd3c59d25033dbf980d29554025c23a75', '8d78869f470951332959580424d4bf4f', '0');INSERT INTO `user_info` VALUES ('2', 'yang', 'VIP', 'd3c59d25033dbf980d29554025c23a75', '8d78869f470951332959580424d4bf4f', '0');-- ------------------------------ Table structure for `xx_menu`-- ----------------------------DROP TABLE IF EXISTS `xx_menu`;CREATE TABLE `xx_menu` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `name` varchar(255) DEFAULT NULL,  `icon` varchar(255) DEFAULT NULL,  `parent_id` int(11) DEFAULT NULL,  `is_delete` int(2) DEFAULT '0' COMMENT '是否删除  0:未删除 1:删除',  `url` varchar(255) DEFAULT NULL,  `created_time` datetime DEFAULT NULL,  `update_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;-- ------------------------------ Records of xx_menu-- ----------------------------INSERT INTO `xx_menu` VALUES ('1', '系统管理', 'fa fa-gears', '0', '0', '#', '2018-04-13 14:54:36', '2018-04-13 15:35:19');INSERT INTO `xx_menu` VALUES ('2', '菜单管理', 'fa fa-gears', '1', '0', 'menu/list', '2018-04-13 14:55:12', '2018-04-13 15:33:59');INSERT INTO `xx_menu` VALUES ('3', '模板自定义', 'fa fa-gears', '1', '0', 'teample/list', '2018-04-13 16:46:48', '2018-04-13 16:46:50');-- ------------------------------ Table structure for `xx_teample`-- ----------------------------DROP TABLE IF EXISTS `xx_teample`;CREATE TABLE `xx_teample` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `user_name` varchar(255) NOT NULL,  `password` varchar(255) NOT NULL,  `phone` varchar(255) NOT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;-- ------------------------------ Records of xx_teample-- ----------------------------INSERT INTO `xx_teample` VALUES ('1', 'yang_zhongren', '123456', '15261811115');INSERT INTO `xx_teample` VALUES ('2', '杨中仁', '21121', '18888888888');

做了好几年了 也不知道怎么写文章 多多包涵

案例下面的代码 直接复制粘贴过来的 如果有何不懂的 可以直接在下面提问。

转载地址:http://xpvta.baihongyu.com/

你可能感兴趣的文章
程鑫峰:1.26特朗.普力挺美元力挽狂澜,伦敦金行情分析
查看>>
safari下video标签无法播放视频的问题
查看>>
01 iOS中UISearchBar 如何更改背景颜色,如何去掉两条黑线
查看>>
对象的继承及对象相关内容探究
查看>>
Spring: IOC容器的实现
查看>>
Serverless五大优势,成本和规模不是最重要的,这点才是
查看>>
Nginx 极简入门教程!
查看>>
iOS BLE 开发小记[4] 如何实现 CoreBluetooth 后台运行模式
查看>>
Item 23 不要在代码中使用新的原生态类型(raw type)
查看>>
为网页添加留言功能
查看>>
JavaScript—数组(17)
查看>>
Android 密钥保护和 C/S 网络传输安全理论指南
查看>>
以太坊ERC20代币合约优化版
查看>>
Why I Began
查看>>
同一台电脑上Windows 7和Ubuntu 14.04的CPU温度和GPU温度对比
查看>>
js数组的操作
查看>>
springmvc Could not write content: No serializer
查看>>
Python系语言发展综述
查看>>
新手 开博
查看>>
借助开源工具高效完成Java应用的运行分析
查看>>