《权限系列shiro+cas》----配置各个应用程序

2024-08-27 20:38

本文主要是介绍《权限系列shiro+cas》----配置各个应用程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

  • shiro-cas-authority已经大体的介绍完毕,现在我们需要在各个应用程序之间来引用它实现权限管理。

Cas客户端与服务端的配置

  • cas的客户端在shiro-cas-authority已经配置完成,我们配置cas的服务端时,可以将在源码上下载下来的cas文件夹放在tomcat的webapps目录下,然后启动tomcat,这样cas的服务端就生效了。

源码地址

点击这里,去小编的GitHub上下载源码

应用程序配置

配置shiro.properties

  • 每个应用程序都有自己的shiro.properties配置文件,在每个shiro.properties中配置的是用户登录成功后的默认访问地址,登录失败后默认访问地址,以及casServer的地址等等,正是因为用户在正确登录每个应用程序的时候访问的默认地址不一样,所以讲shiro.properties单独抽出来放在各个应用程序中。

应用程序的核心spring.xml文件

<context:component-scan base-package="com.spring.app1.service"/><context:component-scan base-package="com.spring.app1.dao"/><bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="order" value="1"/><property name="ignoreUnresolvablePlaceholders" value="true"/><property name="locations"><list><value>classpath:jdbc.properties</value><value>classpath:shiro.properties</value></list></property>
</bean><import resource="spring-mybatis.xml"/><!-- 引入shiro-cas-authority中的spring核心配置文件 -->
<import resource="classpath*:conf/spring-context-authority.xml"/>

应用程序的springmvc.xml文件

<!-- 注解扫描 --><mvc:annotation-driven /><context:component-scan base-package="com.spring.app1.controller"></context:component-scan><!-- 配置视图解析器 --><bean
        class="org.springframework.web.servlet.view.InternalResourceViewResolver"><!-- 前缀 --><property name="prefix" value="/WEB-INF/jsp/"></property><!-- 后缀 --><property name="suffix" value=".jsp"></property></bean><!-- 静态资源处理 --><!-- <mvc:default-servlet-handler /> --><mvc:resources location="/WEB-INF/js/" mapping="/js/**" /><!-- 支持Shiro对Controller的方法级AOP安全控制 begin --><bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor"><property name="proxyTargetClass" value="true" /></bean>
<!-- 支持Shiro对Controller的方法级AOP安全控制 end -->
  • 在springmvc的配置文件中,我们需要配置支持Shiro对Controller的方法级AOP安全控制,这样我们在Controller中的方法上加shiro的资源注解时,shiro就会自动判断用户是否拥有此权限。

后台Controller方法

@RequestMapping("/course")
@Controller
public class CourseController extends BaseController {@AutowiredCourseService courseService;@RequestMapping(value = {"/index"})public String index() {return "index";}@RequiresPermissions("query")@RequestMapping("queryAllCourse")@ResponseBodypublic List<Course> queryAllCourse() {List<Course> list =courseService.queryAllCourse();Course course=new Course();course.setComment("这是应用程序1查询出来的Course");course.setCourseName("这是应用程序1查询出来的Course");course.setId("1111111111111111111");course.setCreate_time(new Date());list.add(course);return list;}@RequiresPermissions("create")@RequestMapping("failureUrl")@ResponseBodypublic List<String> loninFailure() {List<String> list = Arrays.asList("这是登录失败的后返回的结果","失败结果1","失败结果2");return list;}/*** 此方法admin没有权限访问,因为资源授权中 没有 delete* @return*/@RequiresPermissions("delete")@RequestMapping("delete")@ResponseBodypublic List<String> deleteMethod() {List<String> list = Arrays.asList("这是登录失败的后返回的结果","失败结果1","失败结果2");return list;}@RequestMapping("queryByAjax")@ResponseBody@RequiresPermissions("delete")public List<String> queryByAjax(String username,String content) {List<String> list = Arrays.asList("刘德华","张学友","黎明","郭富城");System.out.println(username);System.out.println(content);return list;}
}

启动程序,访问应用程序一(applicationOne)

访问地址:http://localhost:8083/app1/course/index

  • 输入地址后,程序会自动跳转到cas的服务端,此时cas的登录页就显示出来了。
    这里写图片描述

    输入用户名:admin
    密 码:admin@2015
    登录成功后就会访问index.jsp

    这里写图片描述

  • 这个页面就是测试用的所有方法,由于小编不能将项目中的所有源码都展示出来,所以小编只是将项目的框架抽离出来,展示个demo,读者拿到这套框架后可以根据自己的业务来修改和扩展。

小结

  • 这一片博客只是贴出了源码中的applicationOne中的代码,读者可以将applicationTwo也启动起来,这样以来,当我们点击应用程序1中的跳往applicationTwo的时候,应用程序Two不会让我们登录了,至此,跨域的单点登录已经实现。

这篇关于《权限系列shiro+cas》----配置各个应用程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112722

相关文章

SpringBoot3.4配置校验新特性的用法详解

《SpringBoot3.4配置校验新特性的用法详解》SpringBoot3.4对配置校验支持进行了全面升级,这篇文章为大家详细介绍了一下它们的具体使用,文中的示例代码讲解详细,感兴趣的小伙伴可以参考... 目录基本用法示例定义配置类配置 application.yml注入使用嵌套对象与集合元素深度校验开发

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

CentOS7更改默认SSH端口与配置指南

《CentOS7更改默认SSH端口与配置指南》SSH是Linux服务器远程管理的核心工具,其默认监听端口为22,由于端口22众所周知,这也使得服务器容易受到自动化扫描和暴力破解攻击,本文将系统性地介绍... 目录引言为什么要更改 SSH 默认端口?步骤详解:如何更改 Centos 7 的 SSH 默认端口1

Spring Security+JWT如何实现前后端分离权限控制

《SpringSecurity+JWT如何实现前后端分离权限控制》本篇将手把手教你用SpringSecurity+JWT搭建一套完整的登录认证与权限控制体系,具有很好的参考价值,希望对大家... 目录Spring Security+JWT实现前后端分离权限控制实战一、为什么要用 JWT?二、JWT 基本结构

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

SpringBoot多数据源配置完整指南

《SpringBoot多数据源配置完整指南》在复杂的企业应用中,经常需要连接多个数据库,SpringBoot提供了灵活的多数据源配置方式,以下是详细的实现方案,需要的朋友可以参考下... 目录一、基础多数据源配置1. 添加依赖2. 配置多个数据源3. 配置数据源Bean二、JPA多数据源配置1. 配置主数据

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器