cas单点登录循环重定向问题

本文介绍了在ASP.NET客户端配置单点登录(SSO)时遇到的HTTPS循环重定向问题及解决方法,通过调整证书验证机制确保了客户端与CAS服务器间的安全连接。

 首先需要说明的是这里所有客户端都是指的asp.net程序。


 最开始配置的时候没注意使用的是https,浏览器一直出现

循环重定向问题,后来改为http方式就好了。网上有一些

解决办法,其中说的最多的就是建议用户直接增加配置:

<sessionState mode="StateServer" cookieless="UseCookies" timeout="36000"></sessionState>

其目的为:1、启用会话状态;2、开始asp.net状态服务

但是试了之后不起作用,后来看了博客园吕震宇Yale CAS + .net Client 实现SSO

问题得到了解决,原因是未能为 SSL/TLS 安全通道建立信任关系。

我的理解是.net客户端没有安装证书,不能和cas服务器建立安全链接,

而在java中可以使用keytool 生成证书,所以没有此问题。

感谢牛人的研究,解决方法如下:

(1)在Visual Studio中打开“CASDotNetClient”项目中的“\Utils\HttpUtil.cs”文件,如果打不开请选择较高版本的vs,我使用的是vs2017,添加如下命名空间:

using System.Net.Security; 
using System.Security.Authentication; 
using System.Security.Cryptography.X509Certificates;

(2)在HttpUtil类中增加如下方法:

internal static bool CheckValidationResult(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors errors) 
{    
    return true; 
}

(3)在PerformHttpGet方法中添加验证服务器证书回调自动验证代码,添加代码后的PerformHttpGet方法如下:

internal static string PerformHttpGet(string url, bool requireHttp200) 
{ 
  string responseBody = null; 

  //-- 以下新添加的代码:验证服务器证书回调自动验证 
  ServicePointManager.ServerCertificateValidationCallback = new System.Net.Security.RemoteCertificateValidationCallback(CheckValidationResult); 
  //-- 以上为新添加的代码 

  HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); 
  using (HttpWebResponse response = (HttpWebResponse)request.GetResponse()) 
  { 
    if (!requireHttp200 || response.StatusCode == HttpStatusCode.OK) 
    { 
      using (Stream responseStream = response.GetResponseStream())  
      { 
        if (responseStream != null) 
        { 
          using (StreamReader responseReader = new StreamReader(responseStream)) 
          { 
            responseBody = responseReader.ReadToEnd(); 
          } 
        } 
      } 
    } 
  } 

  return responseBody; 
}


(4)保存修改并重新生成解决方案,并替换客户端的DotNetClient.dll,重新运行测试。


使用https时客户端配置和使用http差不多,只要将web.config中的服务器url中的http改为https即可,

而在cas服务的tomcat需要配置https相关的内容,以后再总结。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值