若依框架使用shrio实现用户的权限管理的大体思路:
1. 控制层处理
在控制层 controller 中的方案中设置@RequiresPermissions(" "),默认有view(页面展示),list(查询),add(新增),update(修改),delete(删除),exprort(导出)
package com.ruoyi.web.controller.psi;
import java.util.List;
import org.apache.shiro.authz.annotation.Logical;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.apache.shiro.authz.annotation.RequiresRoles;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.psi.domain.PsiUnit;
import com.ruoyi.psi.service.IPsiUnitService;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.common.core.page.TableDataInfo;
/**
* psiunitController
*
* @author ruoyi
* @date 2024-03-20
*/
@Controller
@RequestMapping("/psi/psiunit")
public class PsiUnitController extends BaseController {
private String prefix = "psi/psiunit";
@Autowired
private IPsiUnitService psiUnitService;
@RequiresPermissions("psi:psiunit:view")
@GetMapping()
public String psiunit() {
return prefix + "/psiunit";
}
/**
* 查询psiunit列表
*/
@RequiresPermissions("psi:psiunit:list")
@PostMapping("/list")
@ResponseBody
public TableDataInfo list(PsiUnit psiUnit) {
startPage();
List<PsiUnit> list = psiUnitService.selectPsiUnitList(psiUnit);
return getDataTable(list);
}
/**
* 导出psiunit列表
*/
@RequiresPermissions("psi:psiunit:export")
@Log(title = "psiunit", businessType = BusinessType.EXPORT)
@PostMapping("/export")
@ResponseBody
public AjaxResult export(PsiUnit psiUnit) {
List<PsiUnit> list = psiUnitService.selectPsiUnitList(psiUnit);
ExcelUtil<PsiUnit> util = new ExcelUtil<PsiUnit>(PsiUnit.class);
return util.exportExcel(list, "计量单位数据");
}
/**
* 新增psiunit
*/
@GetMapping("/add")
public String add() {
return prefix + "/add";
}
/**
* 新增保存psiunit
*/
@RequiresPermissions("psi:psiunit:add")
@Log(title = "psiunit", businessType = BusinessType.INSERT)
@PostMapping("/add")
@ResponseBody
public AjaxResult addSave(PsiUnit psiUnit) {
System.out.println(psiUnit.getCCODE());
System.out.println(psiUnit.getCNAME());
return toAjax(psiUnitService.insertPsiUnit(psiUnit));
}
/**
* 修改psiunit
*/
@RequiresPermissions("psi:psiunit:edit")
@GetMapping("/edit/{CCODE}")
public String edit(@PathVariable("CCODE") String CCODE, ModelMap mmap) {
PsiUnit psiUnit = psiUnitService.selectPsiUnitByCCODE(CCODE);
mmap.put("psiUnit", psiUnit);
return prefix + "/edit";
}
/**
* 修改保存psiunit
*/
@RequiresPermissions("psi:psiunit:edit")
@Log(title = "psiunit", businessType = BusinessType.UPDATE)
@PostMapping("/edit")
@ResponseBody
public AjaxResult editSave(PsiUnit psiUnit) {
return toAjax(psiUnitService.updatePsiUnit(psiUnit));
}
/**
* 删除psiunit
*/
@RequiresPermissions("psi:psiunit:remove")
@Log(title = "psiunit", businessType = BusinessType.DELETE)
@PostMapping("/remove")
@ResponseBody
public AjaxResult remove(String ids) {
return toAjax(psiUnitService.deletePsiUnitByCCODEs(ids));
}
}
2. 菜单管理
建立菜单,分两个层级建立:第一个层级根据业务名称建立菜单,权限赋值为 view;第二个层级建立类型为按钮,把具体的增删改查业务按钮列出来,方便后期分配权限
3. 角色权限管理
新增加角色或者对已有角色进行权限分配,如下图,根据业务需求选择需要的权限进行分配
4. 其他用法
也可以新建独立的菜单,分配固定权限:如下单独建立的台账查询的菜单:只有view和list权限,则给角色分配改菜单时不需要在另行配置其他权限