博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java笔记:SpringSecurity应用(二)
阅读量:6539 次
发布时间:2019-06-24

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

这里我首先对我上一篇博文的第三个实例做一下讲解,下面是applicationContext-security.xml内容如下:

该配置文件的注解如下:

  1. <http auto-config="true">,这一部分是配置如何拦截用户请求,auto-config="true"将自动配置几个常用的权限机制,包括form,anonymous,rememberMe.(这几种机制我也不太不明白) 。
  2.  我们利用intercept-url来判断用户需要何种权限才能访问对应的url资源,可以在pattern中指定一个特定的url资源,也可以使用通配符来指定一组类似的url资源。例子中定义的两个intercepter-url,第一个用来控制对/admin.jsp的访问,第二个使用了通配符/**,说明它将控制对系统中所有url资源的访问。在实际使用中,Spring Security采用的是一种就近原则,就是说当用户访问的url资源满足多个intercepter-url时,系统将使用第一个符合条件的intercept-url进行权限控制。在我们这个例子中就是,当用户访问/admin.jsp时,虽然两个intercept-url都满足要求,但因为第一个intercept-url排在上面,所以Spring Security会使用第一个intercept-url中的配置处理对/admin.jsp的请求,也就是说,只有那些拥有了ROLE_ADMIN权限的用户才能访问/admin.jspaccess指定的权限部分比较有趣,大家可以注意到这些权限标示符都是以ROLE_开头的,实际上这与Spring Security中的Voter机制有着千丝万缕的联系,只有包含了特定前缀的字符串才会被Spring Security处理。目前来说我们只需要记住这一点就可以了,在我文章以后的部分中我们会详细讲解Voter的内容。(这里就解释了我在上面一个文章里,sharp拥有/**所有页面权限,为什么sharp用户却不能访问admin.jsp的原因)
  3. user-service中定义了两个用户,adminuser。为了简便起见,我们使用明文定义了两个用户对应的密码,这只是为了当前演示的方便,之后的例子中我们会使用Spring Security提供的加密方式,避免用户密码被他人窃取。最最重要的部分是authorities,这里定义了这个用户登陆之后将会拥有的权限,它与上面intercept-url中定义的权限内容一一对应。每个用户可以同时拥有多个权限,例子中的admin用户就拥有ROLE_ADMINROLE_USER两种权限,这使得admin用户在登陆之后可以访问ROLE_ADMINROLE_USER允许访问的所有资源。与之对应的是,user用户就只拥有ROLE_USER权限,所以他只能访问ROLE_USER允许访问的资源,而不能访问ROLE_ADMIN允许访问的资源。

第四个实例:

这个实例里面用户信息存入到数据库里,我使用的是数据库是

create table USERS (   USERNAME VARCHAR2(64) not null,   PASSWORD VARCHAR2(64),   ENABLED  NUMBER ) comment on column USERS.USERNAME is '用户名'; comment on column USERS.PASSWORD is '密码'; comment on column USERS.ENABLED is '0--不可用;1--可用'; alter table USERS add constraint PK_USERS primary key (USERNAME) create table AUTHORITIES (   USERNAME  VARCHAR2(64) not null,   AUTHORITY VARCHAR2(64) not null ) tablespace ANDROIDXIAJUN   pctfree 10   initrans 1   maxtrans 255   storage   (     initial 64K     minextents 1     maxextents unlimited   ); alter table AUTHORITIES add constraint INDEX_USER_AUTH unique (USERNAME, AUTHORITY) alter table AUTHORITIES add constraint USER_AUTHORITIES_FK foreign key (USERNAME) references USERS (USERNAME);

数据库表创建好后,我们插入一些测试数据:

insert into users(username,password,enabled) values('admin','admin',1); insert into users(username,password,enabled) values('sharp','sharp',1); insert into authorities(username,authority) values('admin','ROLE_ADMIN'); insert into authorities(username,authority) values('admin','ROLE_USER'); insert into authorities(username,authority) values('sharp','ROLE_USER');

数据库的表建好,里面数据也有了,接下来就是修改我们原来的程序了。前面的三个实例都是在配置文件里配置好用户信息,而且还是明文的,如果换成数据库我们只要把这个部分的内容更改下:

修改的新内容是:

另外我们还要增加一个数据源

dataSource,下面是我修改后完整的applicationContext-security.xml

classpath:constants.properties

按照我以前开发的习惯的,我会把spring里面很多配置信息放置到constants.properties里面,便于统一管理,constants.properties内容如下:

db.driverClass = oracle.jdbc.driver.OracleDriver db.user        = sharpxiajun db.password    = sharpxiajun db.jdbcUrl     = jdbc:oracle:thin:@127.0.0.1:1521:orcl

为了和数据库链接我又增加了一些jar包

至于测试和前面三个实例一样,这里不做过多表述了。

上一篇文章里,我们做的第二个实例是“自定义登录界面”,对里面一些特别的配置没有进行讲解,下面的内容就是对这个功能的具体讲解了:

 

1.<intercept-url pattern="/login.jsp"  access="IS_AUTHENTICATED_ANONYMOUSLY" />让没登陆的用户也可以访问login.jsp这是因为配置文件中的“/**”配置,要求用户访问任意一个系统资源时,必须拥有ROLE_USER角色,/login.jsp也不例外,如果我们不为/login.jsp单独设置访问权限,会造成用户连登录权限都没有,这个是不正确的

2. <form-login login-page="/login.jsp" authentication-failure-url="/login.jsp?login_error=1" default-target-url="/index.jsp"/>login-page表示用户登陆时显示我们自定义的login.jsp。这时我们访问系统显示的登陆页面将是我们上面创建的login.jspauthentication-failure-url表示用户登陆失败时,跳转到哪个页面。当用户输入的登录名和密码不正确时,系统将再次跳转到/login.jsp,并添加一个error=true参数作为登陆失败的标示。default-target-url表示登陆成功时,跳转到哪个页面。

自制的登录页面里也有很多没有做注解的地方,现在补上页面里的注解,页面内容如下:

 
登录失败,请重试.
原因:
用户名:
密 码:
两周内自动登录
  

注解如下:

1.<body οnlοad='document.f.j_username.focus();'>

表示在页面装载时onload调用函数'document.f.j_username.focus();该函数的意思是让表单中的j_username获得焦点,即把光标移动到该控件上;

2. action="<c:url value='j_spring_security_check'/>" /j_spring_security_check,提交登陆信息的URL地址。自定义form时,要把formaction设置为/j_spring_security_check。注意这里要使用绝对路径,避免登陆页面存放的页面可能带来的问题。

3. j_username,输入登陆名的参数名称。

4. j_password,输入密码的参数名称

5. _spring_security_remember_me,选择是否允许自动登录的参数名称。

可以直接把这个参数设置为一个checkbox,无需设置valueSpring Security

总结下了:Springsecurity应用讲解暂时告一段落,这个系列主要是为了应付实际工作,并不是我的研究重点,不过我很想在项目里面使用到它,到那时我一定会更加什么的讲解。另外我手头上springsecurity的资料并不太好,没有做深入研究的,如果哪位童鞋有更好的相关资料,希望能跟我分享下。

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

你可能感兴趣的文章
记一次mapreduce读取不到输入文件的问题
查看>>
OC之继承
查看>>
Mac远程控制Mac和Windows
查看>>
我的友情链接
查看>>
MariaDB集群Galera Cluster的研究与测试
查看>>
SONY控制键盘JX-11,EVI-D70P控制方案
查看>>
项目经理必备 - 项目绩效测量工具EVM详解(上)
查看>>
Spring AOP 之二:Pointcut注解表达式
查看>>
在普通台式机上搭建服务器虚拟化架构Esxi平台
查看>>
电话线路 30B+D 名词解释
查看>>
python字典嵌套字典实例
查看>>
吉炬消费系统软件输入密码后无法打开软件界面故障处理
查看>>
Hibernate学习系列————注解一对多双向实例
查看>>
3月21日学习笔记-用户和组管理
查看>>
2014阿里巴巴9月14北京校园招聘笔试及参考答案
查看>>
WIFI环境搭建
查看>>
Spring shell 的HelloWorld
查看>>
用perl获取可用的代理服务器地址
查看>>
python 数据库初始
查看>>
LAMP平台部署及应用(一)
查看>>