zoukankan      html  css  js  c++  java
  • WebAPI+Html跨域时对session的支持

    1、Global.asax中添加对Session的支持,重新Init方法:

    public override void Init()
            {
                this.PostAuthenticateRequest += (sender, e) 
                    => HttpContext.Current.SetSessionStateBehavior
                    (System.Web.SessionState.SessionStateBehavior.Required);
                base.Init();
            }

    2、WebConfig中添加跨域支持:

    <httpProtocol>
          <customHeaders>
            <clear />
            <add name="Access-Control-Allow-Origin" value="http://*.*.*.*:8088" />
            <add name="Access-Control-Allow-Credentials" value="true" />
            <add name="Access-Control-Allow-Headers" value="Content-Type" />
            <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />
          </customHeaders>
        </httpProtocol>

    3、写Session的Controller

    [RoutePrefix("Reg")]
        public class RegController : ApiController
        {
            [Route("RegUser")]
            [HttpGet]
            public bool RegUser(string userName)
            {
                System.Web.HttpContext.Current.Session["User"] = userName;
                return true;
            }
        }

    4、读Session的Controller

    [RoutePrefix("Login")]
        public class LoginController : ApiController
        {
            [Route("GetLogin")]
            [HttpGet]
            public string GetLogin()
            {
                string userName = string.Empty;
    
                if(System.Web.HttpContext.Current.Session["User"]!=null)
                {
                    userName = System.Web.HttpContext.Current.Session["User"].ToString();
                }
    
                return userName;
            }
        }

    5、前端jQuery调用时加上参数crossDomain: true 和 xhrFields: { withCredentials: true}。

    
    
    <script>
            
            var url = "http://*.*.*.*:8089/";
            var userId = "002";
            var userName = "xiaoming";
            var password = "123456";
            
            
            $(function () {
    
                btnRegClick();
                btnGetNameClick();
            });
    
           
            
            
            function btnRegClick(){
                $("#btnReg").click(function () {
                    
                    $.ajax({
                        type: "get",
                        url: url + "Reg/RegUser",
                         xhrFields: {
                         withCredentials: true
                         },
                        crossDomain: true,
                        data: {
                            userId: userId,
                            userName: userName,
                            password: password
                        },
                        success: function (result) {
                            $("#txtUserName").val(result)
                        }
                    });
                    
                });
            }
            
            
            function btnGetNameClick(){
                $("#btnGetName").click(function () {
                    
                    $.ajax({
                        type: "get",
                        url: url + "Login/GetLogin",
                         xhrFields: {
                         withCredentials: true
                         },
                        crossDomain: true,
                        data: {
                        },
                        success: function (result) {
                            $("#txtUserName").val(result)
                        }
                    });
                    
                });
            }
    
    <script>
            

    6、搞定。

  • 相关阅读:
    java多线程:并发包中ConcurrentHashMap和jdk的HashMap的对比
    java编程之:Unsafe类
    mave之:java的web项目必须要的三个jar的pom形式
    java多线程:并发包中ReentrantReadWriteLock读写锁的锁降级模板
    java多线程:并发包中ReentrantReadWriteLock读写锁的原理
    java编程之:按位与运算,等运算规则
    java多线程:jdk并发包的总结(转载)
    liunx之:wps for liunx的安装经验
    mysql中enum类型理解
    MySQL类型float double decimal的区别
  • 原文地址:https://www.cnblogs.com/microsoft-xin/p/9622153.html
Copyright © 2011-2022 走看看