实现对特定角色和特定路径拦截

This commit is contained in:
fjy8018@qq.com
2018-07-06 15:44:45 +08:00
parent 14bdaf5989
commit 0be0ccf113
11 changed files with 226 additions and 173 deletions

92
sql.sql
View File

@@ -1,30 +1,39 @@
DROP DATABASE db_shiroTest;
GRANT ALL ON db_shiroTest.* TO trs@localhost IDENTIFIED BY 'shiro';
flush privileges;
CREATE DATABASE IF NOT EXISTS db_shiroTest DEFAULT CHARSET utf8mb4 COLLATE utf8mb4_general_ci;
GRANT ALL ON db_shiroTest.* TO trs@localhost
IDENTIFIED BY 'shiro';
FLUSH PRIVILEGES;
CREATE DATABASE IF NOT EXISTS db_shiroTest
DEFAULT CHARSET utf8mb4
COLLATE utf8mb4_general_ci;
USE db_shiroTest;
-- 权限表 --
CREATE TABLE permission (
pid INT(11) NOT NULL AUTO_INCREMENT,
pid INT(11) NOT NULL AUTO_INCREMENT,
name VARCHAR(255) NOT NULL DEFAULT '',
url VARCHAR(255) DEFAULT '',
url VARCHAR(255) DEFAULT '',
PRIMARY KEY (pid)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 用户表 --
CREATE TABLE user (
uid INT(11) NOT NULL AUTO_INCREMENT,
uid INT(11) NOT NULL AUTO_INCREMENT,
username VARCHAR(255) NOT NULL DEFAULT '',
password VARCHAR(255) NOT NULL DEFAULT '',
PRIMARY KEY (uid)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 角色表 --
CREATE TABLE role (
rid INT(11) NOT NULL AUTO_INCREMENT,
rid INT(11) NOT NULL AUTO_INCREMENT,
rname VARCHAR(255) NOT NULL DEFAULT '',
PRIMARY KEY (rid)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 权限角色关系表 --
CREATE TABLE permission_role (
@@ -32,7 +41,9 @@ CREATE TABLE permission_role (
pid INT(11) NOT NULL,
CONSTRAINT FK_prid FOREIGN KEY (rid) REFERENCES role (rid),
CONSTRAINT FK_pid FOREIGN KEY (pid) REFERENCES permission (pid)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 用户角色关系表 --
CREATE TABLE user_role (
@@ -40,38 +51,43 @@ CREATE TABLE user_role (
uid INT(11) NOT NULL,
CONSTRAINT FK_urid FOREIGN KEY (rid) REFERENCES role (rid),
CONSTRAINT FK_uid FOREIGN KEY (uid) REFERENCES user (uid)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 初始化数据 --
INSERT INTO permission (pid,name, url) VALUE ('1','add','');
INSERT INTO permission (pid,name, url) VALUE ('2','delete','');
INSERT INTO permission (pid,name, url) VALUE ('3','edit','');
INSERT INTO permission (pid,name, url) VALUE ('4','query','');
INSERT INTO permission (pid, name, url) VALUE ('1', 'add', '');
INSERT INTO permission (pid, name, url) VALUE ('2', 'delete', '');
INSERT INTO permission (pid, name, url) VALUE ('3', 'edit', '');
INSERT INTO permission (pid, name, url) VALUE ('4', 'query', '');
INSERT INTO user (uid,username, password) VALUE ('1','admin','0000');
INSERT INTO user (uid,username, password) VALUE ('2','trs','trs');
INSERT INTO user (uid, username, password) VALUE ('1', 'admin', '0000');
INSERT INTO user (uid, username, password) VALUE ('2', 'trs', 'trs');
INSERT INTO role (rid,rname) VALUE ('1','admin');
INSERT INTO role (rid,rname) VALUE ('2','customer');
INSERT INTO role (rid,rname) VALUE ('3','guest');
INSERT INTO role (rid, rname) VALUE ('1', 'admin');
INSERT INTO role (rid, rname) VALUE ('2', 'customer');
INSERT INTO role (rid, rname) VALUE ('3', 'guest');
INSERT INTO permission_role (rid, pid) VALUE ('1','1');
INSERT INTO permission_role (rid, pid) VALUE ('1','2');
INSERT INTO permission_role (rid, pid) VALUE ('1','3');
INSERT INTO permission_role (rid, pid) VALUE ('1','4');
INSERT INTO permission_role (rid, pid) VALUE ('1', '1');
INSERT INTO permission_role (rid, pid) VALUE ('1', '2');
INSERT INTO permission_role (rid, pid) VALUE ('1', '3');
INSERT INTO permission_role (rid, pid) VALUE ('1', '4');
INSERT INTO permission_role (rid, pid) VALUE ('2','1');
INSERT INTO permission_role (rid, pid) VALUE ('1','3');
INSERT INTO permission_role (rid, pid) VALUE ('1','4');
INSERT INTO permission_role (rid, pid) VALUE ('3','4');
INSERT INTO permission_role (rid, pid) VALUE ('2', '1');
INSERT INTO permission_role (rid, pid) VALUE ('1', '3');
INSERT INTO permission_role (rid, pid) VALUE ('1', '4');
INSERT INTO permission_role (rid, pid) VALUE ('3', '4');
INSERT INTO user_role (rid, uid) VALUE ('1','1');
INSERT INTO user_role (rid, uid) VALUE ('2','2');
INSERT INTO user_role (rid, uid) VALUE ('1', '1');
INSERT INTO user_role (rid, uid) VALUE ('2', '2');
SELECT u.*,r.*,p.*
FROM user u
INNER JOIN user_role ur ON ur.uid = u.uid
INNER JOIN role r ON ur.uid = r.rid
INNER JOIN permission_role pr ON r.rid = pr.rid
INNER JOIN permission p ON pr.pid = p.pid
WHERE u.username
SELECT
u.*,
r.*,
p.*
FROM user u
INNER JOIN user_role ur ON ur.uid = u.uid
INNER JOIN role r ON ur.uid = r.rid
INNER JOIN permission_role pr ON r.rid = pr.rid
INNER JOIN permission p ON pr.pid = p.pid
WHERE u.username