• SSO 单点登录


    Client:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Web;
    using System.Web.Mvc;
    
    namespace SiteA.Controllers
    {
    
    
        public class Info
        {
    
            public string UserName { get; set; }
    
            public  string Passward { get; set; }
    
        }
        public class ControllerBasic : Controller
        {
            protected override void OnActionExecuting(ActionExecutingContext filterContext)
            {
    
                if (Session["Info"] != null)
                {
                    // 拿seesion中的token  验证登录状态,如果已经登录,直接返回
                    //  Do:  调用sso 的webservice
    
                    var url = Request.Url.AbsoluteUri;
                    //filterContext.Result =  new RedirectResult(url.Contains("?") ? url.Substring(0, url.LastIndexOf("?")) : url); ;
                    //Response.Redirect(url.Contains("?")?url.Substring(0,url.LastIndexOf("?")):url);
                    // 如果验证成功
                    return;
                    // 验证失败
                   // Response.Redirect($"https://localhost:44325/home/Login?backUrl=" + $"{ System.Web.HttpUtility.UrlEncode(Request.Url.AbsoluteUri)}");
                }
                if (Request["token"] != null)
                {
                    var token = Request["Token"];
                    //  去主站获取凭证
                    Info Info = new Info { UserName="hnzheng",Passward="123"}; // 包含用户名、姓名、过期时间等
                    if (Info == null)
                    {
                        // 跳转到单点登录页面
                        Response.Redirect($"https://localhost:44325/home/Login?backUrl=" + $"{ System.Web.HttpUtility.UrlEncode(Request.Url.AbsoluteUri)}");
                    }
                    else
                    {
                        // 保存凭证
                        Session["Info"] = new
                        {
                            UserName = Info.UserName,
                            Passward = Info.Passward,
                            Token = token
                            // 等等其他信息
                        };
    
                    }             
                }
                else
                {
                   
                    Response.Redirect( $"https://localhost:44325/home/Login?backUrl=" + $"{ System.Web.HttpUtility.UrlEncode(Request.Url.AbsoluteUri)}");
                }
    
    
    
    
    
    
            }
    
        }
    }
    

    SSo:

    public ActionResult Login() { var userName = Request.Form["UserName"]; var passard = Request.Form["Paassward"]; var returnUrl = Request.Url.AbsoluteUri; //Do:验证用户名和密码 // 模拟验证 if (userName == "hnzheng" && passard == "123") { var token = GetToken(); // 保存用户名和密码,可用其他方式替代 { System.Runtime.Caching.MemoryCache memeryCache = MemoryCache.Default; CacheItemPolicy cacheItemPolicy = new CacheItemPolicy(); cacheItemPolicy.AbsoluteExpiration = DateTime.Now.AddDays(1); // Session["UserInfo"]=$"{userName}|{passard}"; memeryCache.Add(new CacheItem(token, "hnzheng|123"), cacheItemPolicy); } // 跳转到主站的首页 { // 解析url string url = Request.Url.AbsoluteUri; if (!string.IsNullOrEmpty(url)) { GoForward(url,token); } } RedirectToAction("Home", "index"); } else ViewBag.Message = "用户名或密码不正确!"; return View(); }

      

  • 相关阅读:
    [leetcode] Palindrome Number
    [leetcode] Find Minimum in Rotated Sorted Array
    [leetcode] Word Search
    [leetcode] Construct Binary Tree from Preorder and Inorder Traversal
    [leetcode] Flatten Binary Tree to Linked List
    [leetcode] Recover Binary Search Tree
    [leetcode] Unique Binary Search Trees II
    [leetcode summary] Dynamic Programming
    [leetcode] Generate Parentheses
    [leetcode summary] Backtracing
  • 原文地址:https://www.cnblogs.com/hnzheng/p/12747165.html
Copyright © 2020-2023  润新知