当前位置:首页 > 单点登录系统SSO
Java培训专家—传智播客http://java.itcast.cn }
}
}
id=new JdbcTemplate(getDataSource()).queryForObject(sql, String.class, name,pwd); if(id!=null){ }
e.printStackTrace();
Principal p = new SimplePrincipal(id);//封装成包含id的Principal对象 return p;
}catch(Exception e){
return null;
@Override
public boolean supports(Credentials credentials) { }
public DataSource getDataSource() { }
public void setDataSource(DataSource dataSource) { }
this.dataSource = dataSource; return dataSource;
boolean boo = //判断是否是用户和密码凭据 UsernamePasswordCredentials.class.isAssignableFrom(credentials.getClass()); return boo;
(在使用了ID的查询以后,应该只使用数据库进行验证。) 在配置文件中配置如下:
配置文件为:/WEB-INF/deployerConfigContext.xml
Java培训专家—传智播客http://java.itcast.cn Java培训专家—传智播客http://java.itcast.cn
class=\ /> 测试并运行,此时返回的应该是用户的id了。 2、返回更多用户的信息 服务器,在返回给客户端用户信息时,默认只返回用户名(我们已经修改成ID).但有时我们需要更多的属性信息,如用户名。 则应做如下修改: 用户登录成功以后,CAS使用一个credentialsToPrincipalResolvers将credentials转成Principal对象,此对象只有一个实现类如下: SimplePrincipal的构造方法接收两个参数,一个是用户的id,一个为用户的其他属性。用户的ID默认为用户登录时使用的用户名,前面第4点已经讲过如何将用户的name换成用户的id返回给客户端。为了给客户端返回更多的属性,我们必须要给Principal的构造方法传递第二个参数,它是一个Map Java培训专家—传智播客http://java.itcast.cn Java培训专家—传智播客http://java.itcast.cn 上图通过给SimplePrincipal传递第二个构造参数设置了更多的属性。 但,它并不会马上显示到客户端,如果要显示到客户端,因为服务器验证成功以后,是通过xml形式将结果传递给客户端的,xml的生成由casServiceValidationSuccess.jsp文件负责。它的具体构造应该是以下形式: xmlns:cas='http://www.yale.edu/tp/cas'> Java培训专家—传智播客http://java.itcast.cn Java培训专家—传智播客http://java.itcast.cn 在上面的代码中,cas:attributes元素是我自己添加的,客户端的的Filter在接收到上述的XML以后,会将css:attributes中的属性解析出来,放到AttirubtePrincipal的attributes属性中去(或是放到Asseration的attributes中去,两个只会放一个)。 默认情况下,将所有属性信息放到AttributePrincipal中去,所以在客户端的页面上可以通过以下方式获取值: 所以,组成上面的 以下是源代码: <%@ page session=\ contentType=\%><%@ taglib prefix=\ uri=\%><%@ taglib uri=\ prefix=\%> Java培训专家—传智播客http://java.itcast.cn
共分享92篇相关文档