从实例入手学习Shiro与Web的整合

场景

Shiro官网关于Web整合文档:

http://shiro.apache.org/web.html#Web-configuration

W3Cschool Shiro Web集成:

https://www.w3cschool.cn/shiro/c52r1iff.html

实现

项目搭建

1.打开Ecllipse-新建Maven项目--选择Webapp

从实例入手学习Shiro与Web的整合_第1张图片

2.输入项目信息

从实例入手学习Shiro与Web的整合_第2张图片

3.项目建成后默认是1.5,是没有src/main/java目录的。

从实例入手学习Shiro与Web的整合_第3张图片

4.右键项目-Properties--Java Build Path Libraties--将原来的remove掉。

从实例入手学习Shiro与Web的整合_第4张图片

5.然后再点击Add Library ..-JRE System Library

从实例入手学习Shiro与Web的整合_第5张图片

6.选择自己默认的,这里是1.8

从实例入手学习Shiro与Web的整合_第6张图片

7.修改完之后。

从实例入手学习Shiro与Web的整合_第7张图片

8.建成之后项目没有META-INF目录,这里新建一个Dynamic Web Project 将META-INF复制过来,

并且web.xml的结构也不是我们想要的,将其也复制过来。

从实例入手学习Shiro与Web的整合_第8张图片

9.复制过来可以将原来新建的删掉,将复制过来的web.xml中的display-name进行修改。

从实例入手学习Shiro与Web的整合_第9张图片

10.打开pom.xml添加依赖


  4.0.0
  com.badao.shiro
  ShiroWeb
  war
  0.0.1-SNAPSHOT
  ShiroWeb Maven Webapp
  http://maven.apache.org
  
    
      junit
      junit
      3.8.1
      test
    
   
      
    
  javax.servlet
  javax.servlet-api
  3.1.0
 
 
 
  javax.servlet.jsp
  javax.servlet.jsp-api
  2.3.1
 
 
 
 
  javax.servlet
  jstl
  1.2
 
 
 
    
  log4j
  log4j
  1.2.17
 
   
   
    
  commons-logging
  commons-logging
  1.2
 
 
 
    
  org.apache.shiro
  shiro-core
  1.2.4
 
   
    
  org.apache.shiro
  shiro-web
  1.2.4
 
   
    
  org.slf4j
  slf4j-api
  1.7.12
 
   
  
  
    ShiroWeb
  

11.修改Index.jsp,添加Hello Shiro,然后部署运行项目。

从实例入手学习Shiro与Web的整合_第10张图片

配置项目

1.打开web.xml


     org.apache.shiro.web.env.EnvironmentLoaderListener
  
  
 
 
     ShiroFilter
     org.apache.shiro.web.servlet.ShiroFilter
     
      configPath
      /WEB-INF/shiro.ini
     
 
 
 
     ShiroFilter
     /*
 

注:

通过 configPath 指定 ini 配置文件位置,默认是先从 /WEB-INF/shiro.ini 加载,如果没有就默认加载 classpath:shiro.ini,即默认相对于 web 应用上下文根路径;

2.在WEB-INF下新建shiro.ini配置文件。

[main]
authc.loginUrl=/login
roles.unauthorizedUrl=/unauthorized.jsp
perms.unauthorizedUrl=/unauthorized.jsp

[users]
badao=123,admin
liumang=123,teacher
qizhi=123

[roles]
admin=user:*
teacher=student:*

[urls]
/login=anon
/admin=authc
/student=roles[teacher]
/teacher=perms["user:create"]

然后配置用户、角色、权限等。

注:

[main]
authc.loginUrl=/login
roles.unauthorizedUrl=/unauthorized.jsp
perms.unauthorizedUrl=/unauthorized.jsp

以上表示:

authc.loginUrl=/login  验证不通过时的跳转url

roles.unauthorizedUrl=/unauthorized.jsp  角色验证不通过时的跳转页面

perms.unauthorizedUrl=/unauthorized.jsp  权限验证不通过时的跳转页面

[users]
badao=123,admin
liumang=123,teacher
qizhi=123

以上表示有三个用户:

badao用户密码为123,拥有admin角色。

liumang用户密码为123,拥有teacher角色。

qizhi用户密码为123,没有角色。

[roles]
admin=user:*
teacher=student:*

以上表示admin角色拥有对uset的所有权限。

teacher角色拥有对student的所有权限。

[urls]
/login=anon
/admin=authc
/student=roles[teacher]
/teacher=perms["user:create"]

以上表示:

访问/login时不进行限制。具体参照官方API

从实例入手学习Shiro与Web的整合_第11张图片

 

访问/admin时需要进行验证,如果没有,则通过请求重定向到loginurl配置(authc.loginUrl=/login)体参照官方API

从实例入手学习Shiro与Web的整合_第12张图片

/student=roles[teacher]

表示拥有teacher角色的才能访问/student url

/teacher=perms["user:create"]

表示拥有对user有create权限的才能访问/teacher的url

其他配置具体参照官方文档。

编写业务代码

1.编写登录的servlet以及主页的servlet并在web.xml中配置

新建LoginServlet

从实例入手学习Shiro与Web的整合_第13张图片

代码:

package com.badao.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.subject.Subject;


public class LoginServlet extends HttpServlet{

 /**
  *
  */
 private static final long serialVersionUID = 1L;

 @Override
 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  // TODO Auto-generated method stub
  System.out.println("login doget");
  req.getRequestDispatcher("login.jsp").forward(req, resp);
 }

 @Override
 protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  System.out.println("login dopost");
  String userName=req.getParameter("userName");
  String password=req.getParameter("password");
  Subject subject=SecurityUtils.getSubject();
  UsernamePasswordToken token=new UsernamePasswordToken(userName, password);
  try{
   subject.login(token); 
   resp.sendRedirect("success.jsp");
  }catch(Exception e){
   e.printStackTrace();
   req.setAttribute("errorInfo", "用户名或者密码错误");
   req.getRequestDispatcher("login.jsp").forward(req, resp);
  }
 }


}

打开web.xml,添加:


  loginServlet
  com.badao.servlet.LoginServlet
 
 
 
  loginServlet
  /login
 

 

2.新建login.jsp,body中添加:

 userName:
 password:
 

3.新建success.jsp,body中添加:

登录成功,欢迎你!

4.新建unauthorized.jsp,body中添加:

认证未通过,或者权限不足

5.新建AdminServlet用于权限验证测试。

package com.badao.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class AdminServlet extends HttpServlet{

 private static final long serialVersionUID = 1L;

 @Override
 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  System.out.println("admin do get");
 }

 @Override
 protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  System.out.println("admin do post");
 }

}

6.打开web.xml,添加:


  adminServlet
  com.badao.servlet.AdminServlet
 
 
 
  adminServlet
  /admin
 

 

完整web.xml代码



  ShiroWeb
  
    index.html
    index.htm
    index.jsp
    default.html
    default.htm
    default.jsp
  
   
     org.apache.shiro.web.env.EnvironmentLoaderListener
  
  
 
 
     ShiroFilter
     org.apache.shiro.web.servlet.ShiroFilter
     
      configPath
      /WEB-INF/shiro.ini
     
 
 
 
     ShiroFilter
     /*
 
 
 
 
  loginServlet
  com.badao.servlet.LoginServlet
 
 
 
  loginServlet
  /login
 
 
 
  adminServlet
  com.badao.servlet.AdminServlet
 
 
 
  adminServlet
  /admin
 
 

项目结构目录

从实例入手学习Shiro与Web的整合_第14张图片

运行效果

不登录直接访问admin

从实例入手学习Shiro与Web的整合_第15张图片

登录成功

从实例入手学习Shiro与Web的整合_第16张图片

登录后访问admin

从实例入手学习Shiro与Web的整合_第17张图片

使用admin角色的badao用户访问/student

从实例入手学习Shiro与Web的整合_第18张图片

使用teacher角色的liumang用户访问/teacher

从实例入手学习Shiro与Web的整合_第19张图片

项目源码

https://download.csdn.net/download/badao_liumang_qizhi/11173797

你可能感兴趣的:(Shiro)