webapi 跨站session_webapi 跨controller 调用session - CSDN
精华内容
参与话题
  • 跨域解决 1、使用Nuget添加Cors包 2、全局跨域 ...3、部分方法允许跨域 ...如果不想所有方法都能被跨域访问,可以使用[EnableCors]属性指定,具体实现...1、Web Api默认关闭Session。开启方法如下: 在Global.as...
    • 跨域解决

    1、使用Nuget添加Cors包

    2、全局跨域

    3、部分方法允许跨域

    如果不想所有方法都能被跨域访问,可以使用[EnableCors]属性指定,具体实现如下:

    a)  WebApiConfig.cs文件保持开启跨域支持

    b)  在方法或控制器上配置属性

    • 跨域Session问题

    1、Web Api默认关闭Session。开启方法如下:

    在Global.asax文件中添加方法如下:

    //初始化开启Session
            public override void Init()
            {
                this.PostAuthenticateRequest += (sender, e) =>
                {
                    HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.Required);
                };
                base.Init();
            }

    2、由于跨域时默认是不允许操纵cookie的,这会导致每次跨域调用方法都是使用的不同的sessionId,开启session的意义就不存在了,需要进行如下设置进行解决:

        a)  WebApiConfig文件配置跨域的语句改为如下所示:

     // 开启全局跨域
                var cor = new EnableCorsAttribute("http://127.0.0.1:5500", "*", "*");
                cor.SupportsCredentials = true;// 允许cookie发送,否则session不可用
                config.EnableCors(cor);

        b)   前端js配置全局ajax

    // ajax全局设置
    $.ajaxSetup({
        xhrFields: {
            withCredentials: true // 跨域允许存取cookie
        }
    });
    • 参考文档

    实现参考:https://www.cnblogs.com/landeanfen/p/5177176.html

    方法跨域提示:https://yq.aliyun.com/wenzhang/show_56581

    跨域session:https://www.cnblogs.com/zhaoshang/p/9378928.html

    jquery ajax 设置全局(常量和变量):https://www.cnblogs.com/007sx/p/7048373.html

    cors详解:https://blog.csdn.net/java_green_hand0909/article/details/78740765

    展开全文
  • laravel获取不到session的三种解决办法

    万次阅读 2018-05-02 23:18:24
    问题:引用第三方类库时,使用全局函数session()可以保存session,但是获取不到1、路由置于 web 中间件下,修改app/Http/Kernel.php文件,如下protected $middlewareGroups = [ //中间件web 'web' => [ \...

    问题:引用第三方类库时,使用全局函数session()可以保存session,但是获取不到

    1、路由置于 web 中间件下,修改app/Http/Kernel.php文件,如下

    protected $middlewareGroups = [
            //中间件web
            'web' => [
                \App\Http\Middleware\EncryptCookies::class,
                \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
                //看到这里了吗!StartSession!!!!要把路由放在这个中间件了才会启动Session!!
                \Illuminate\Session\Middleware\StartSession::class,
                \Illuminate\View\Middleware\ShareErrorsFromSession::class,
                \App\Http\Middleware\VerifyCsrfToken::class,
            ],
    
            'api' => [
                'throttle:60,1',
            ],
        ];

    2、修改路由写法,如下

    两种路由中间件写法各人喜好!
    Route::get('/', function () {
        //路由放在这里
    })->middleware('web');
    
    Route::group(['middleware' => ['web']], function () {
        //路由放在这里
    });
    
    routes.php

    3、Laravel不用php原生的session,那么在controller之后应该做了一些事情,将session写入到文件中,而不是每次put操作都写操作,这样会IO操作太频繁的,影响性能的。

    查看调用相关的代码。laravel编译后,在bootstrap/compiled.php

    class Middleware implements HttpKernelInterface
    {
        ...
        public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
        {
            $this->checkRequestForArraySessions($request);
            if ($this->sessionConfigured()) {
                $session = $this->startSession($request); // 启动session
                $request->setSession($session);
            }
            $response = $this->app->handle($request, $type, $catch); // 调用controller的method
            if ($this->sessionConfigured()) {
                $this->closeSession($session);         //关闭session
                $this->addCookieToResponse($response, $session);
            }
            return $response;
        }
        ...
    
        protected function closeSession(SessionInterface $session)
        {
            $session->save();    // 保存session
            $this->collectGarbage($session);
        }
    }
    
    可以看见,在调用完controller之后,调用了session->save()的方法,来主动的保存session。这样session才能落地保存起来,如果在controller或者view里面写了exit;,那么session是不会被保存的,除非主动的写Session::save()才能手工的保存起来。或者把die();exit();换成return


    展开全文
  • token详解

    万次阅读 多人点赞 2016-08-30 17:47:23
    在大多数使用Web API的互联网公司中,tokens 是多用户下处理认证的最佳方式。 以下几点特性会让你在程序中使用基于Token的身份验证 1.无状态、可扩展  2.支持移动设备  3.程序调用  4.安全 ...

    简介

    在Web领域基于Token的身份验证随处可见。在大多数使用Web API的互联网公司中,tokens 是多用户下处理认证的最佳方式。

    以下几点特性会让你在程序中使用基于Token的身份验证

    1.无状态、可扩展

     2.支持移动设备

     3.跨程序调用

     4.安全

     

    那些使用基于Token的身份验证的大佬们

    大部分你见到过的API和Web应用都使用tokens。例如Facebook, Twitter, Google+, GitHub等。

     

    Token的起源

    在介绍基于Token的身份验证的原理与优势之前,不妨先看看之前的认证都是怎么做的。

      基于服务器的验证

       我们都是知道HTTP协议是无状态的,这种无状态意味着程序需要验证每一次请求,从而辨别客户端的身份。

    在这之前,程序都是通过在服务端存储的登录信息来辨别请求的。这种方式一般都是通过存储Session来完成。

    下图展示了基于服务器验证的原理

    tokens-traditional

    随着Web,应用程序,已经移动端的兴起,这种验证的方式逐渐暴露出了问题。尤其是在可扩展性方面。

     

    基于服务器验证方式暴露的一些问题

    1.Seesion:每次认证用户发起请求时,服务器需要去创建一个记录来存储信息。当越来越多的用户发请求时,内存的开销也会不断增加。

    2.可扩展性:在服务端的内存中使用Seesion存储登录信息,伴随而来的是可扩展性问题。

    3.CORS(跨域资源共享):当我们需要让数据跨多台移动设备上使用时,跨域资源的共享会是一个让人头疼的问题。在使用Ajax抓取另一个域的资源,就可以会出现禁止请求的情况。

    4.CSRF(跨站请求伪造):用户在访问银行网站时,他们很容易受到跨站请求伪造的攻击,并且能够被利用其访问其他的网站。

    在这些问题中,可扩展行是最突出的。因此我们有必要去寻求一种更有行之有效的方法。

     

    基于Token的验证原理

    基于Token的身份验证是无状态的,我们不将用户信息存在服务器或Session中。

    这种概念解决了在服务端存储信息时的许多问题

      NoSession意味着你的程序可以根据需要去增减机器,而不用去担心用户是否登录。

    基于Token的身份验证的过程如下:

    1.用户通过用户名和密码发送请求。

    2.程序验证。

    3.程序返回一个签名的token 给客户端。

    4.客户端储存token,并且每次用于每次发送请求。

    5.服务端验证token并返回数据。

     每一次请求都需要token。token应该在HTTP的头部发送从而保证了Http请求无状态。我们同样通过设置服务器属性Access-Control-Allow-Origin:* ,让服务器能接受到来自所有域的请求。需要主要的是,在ACAO头部标明(designating)*时,不得带有像HTTP认证,客户端SSL证书和cookies的证书。

     

    下面的图片解释了过程:

    tokens-new

     

    当我们在程序中认证了信息并取得token之后,我们便能通过这个Token做许多的事情。

    我们甚至能基于创建一个基于权限的token传给第三方应用程序,这些第三方程序能够获取到我们的数据(当然只有在我们允许的特定的token)

     

    Tokens的优势

    无状态、可扩展

    在客户端存储的Tokens是无状态的,并且能够被扩展。基于这种无状态和不存储Session信息,负载负载均衡器能够将用户信息从一个服务传到其他服务器上。

    如果我们将已验证的用户的信息保存在Session中,则每次请求都需要用户向已验证的服务器发送验证信息(称为Session亲和性)。用户量大时,可能会造成

     一些拥堵。

    但是不要着急。使用tokens之后这些问题都迎刃而解,因为tokens自己hold住了用户的验证信息。

    安全性

    请求中发送token而不再是发送cookie能够防止CSRF(跨站请求伪造)。即使在客户端使用cookie存储token,cookie也仅仅是一个存储机制而不是用于认证。不将信息存储在Session中,让我们少了对session操作。 

    token是有时效的,一段时间之后用户需要重新验证。我们也不一定需要等到token自动失效,token有撤回的操作,通过token revocataion可以使一个特定的token或是一组有相同认证的token无效。

    可扩展性()

    Tokens能够创建与其它程序共享权限的程序。例如,能将一个随便的社交帐号和自己的大号(Fackbook或是Twitter)联系起来。当通过服务登录Twitter(我们将这个过程Buffer)时,我们可以将这些Buffer附到Twitter的数据流上(we are allowing Buffer to post to our Twitter stream)。

    使用tokens时,可以提供可选的权限给第三方应用程序。当用户想让另一个应用程序访问它们的数据,我们可以通过建立自己的API,得出特殊权限的tokens。

    多平台跨域

    我们提前先来谈论一下CORS(跨域资源共享),对应用程序和服务进行扩展的时候,需要介入各种各种的设备和应用程序。

    Having our API just serve data, we can also make the design choice to serve assets from a CDN. This eliminates the issues that CORS brings up after we set a quick header configuration for our application.

    只要用户有一个通过了验证的token,数据和资源就能够在任何域上被请求到。

              Access-Control-Allow-Origin: *       

    基于标准

    创建token的时候,你可以设定一些选项。我们在后续的文章中会进行更加详尽的描述,但是标准的用法会在JSON Web Tokens体现。

    最近的程序和文档是供给JSON Web Tokens的。它支持众多的语言。这意味在未来的使用中你可以真正的转换你的认证机制。

    总结

    这篇文章仅仅是介绍了为什么选择基于Token的身份验证,并且怎样使用它。

    下篇文章《剖析JSON Web Tokens》,我们将会用详细代码的例子来描述如何使用JSON Web Tokens认证Node API

    展开全文
  • laravel session 获取不到

    千次阅读 2017-08-18 10:10:12
    网上查到的,但是并未解决我的问题,先...通常 这种问题都是 未将路由置于 web 中间件下protected $middlewareGroups = [ //中间件web 'web' => [ \App\Http\Middleware\EncryptCookies::class, \Illuminate\Cookie

    网上查到的,但是并未解决我的问题,先贴上来!底部是我的解决方案

    通常 这种问题都是 未将路由置于 web 中间件下

    protected $middlewareGroups = [
            //中间件web
            'web' => [
                \App\Http\Middleware\EncryptCookies::class,
                \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
                //看到这里了吗!StartSession!!!!要把路由放在这个中间件了才会启动Session!!
                \Illuminate\Session\Middleware\StartSession::class,
                \Illuminate\View\Middleware\ShareErrorsFromSession::class,
                \App\Http\Middleware\VerifyCsrfToken::class,
            ],
    
            'api' => [
                'throttle:60,1',
            ],
        ];
    
    
    Kernel.php
    ----------
    两种路由中间件写法各人喜好!
    Route::get('/', function () {
        //路由放在这里
    })->middleware('web');
    
    Route::group(['middleware' => ['web']], function () {
        //路由放在这里
    });
    
    routes.php

    下面开始说我的解决办法!
    因为laravel框架原因,session写入是在程序执行完毕后开始保存的,虽然在同一个方法成功调用了,但是跨方法就获取不到了!
    如果写入session的程序中执行了die();exit();会导致session无法保存成功!换成return解决!

    展开全文
  • 关于mvc中的session在controller中传递

    万次阅读 2012-08-25 11:16:14
    在用mvc开发新项目的时候,不久就遇到一个头大的问题,session在controller中传递居然出现空值,但明明一开始就赋值... 暂时不明白mvc中为什么传递session会出现空值,我们引用session时默认引用的是System.Web.Mvc.Co
  • Appium简介

    万次阅读 2018-03-25 14:25:00
    Appium是一个平台工具,它允许测试人员使用同样的接口、基于不同的平台写自动化测试代码,大大增加了测试套件间代码的复用性。 - 移动原生应用:是指那些用iOS或者android sdk写的应用; - 移动web应用:是指...
  • session、cookie、token 详解

    万次阅读 2019-06-19 17:17:09
    1、很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应, 尤其是我不用记住是谁刚刚发了HTTP...
  • 继续这一个系列,WEB后台--基于Token的WEB后台登录认证机制(并讲解其他认证机制以及cookie和session机制)。每个后端不得不解决的认证问题。这篇博客会顺带讲解session和cookie机制,希望大家有所收获!!!
  • 基于Token的身份验证的原理

    万次阅读 多人点赞 2019-05-06 13:41:32
    目录 1 发展史 2 Cookie 3 Session 3.1cookie和session的区别 ...4.1 传统方式——基于服务器的验证 ...1、很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某...
  • Token验证详解

    万次阅读 2017-06-23 14:43:31
    在大多数使用Web API的互联网公司中,tokens 是多用户下处理认证的最佳方式。  以下几点特性会让你在程序中使用基于Token的身份验证  1.无状态、可扩展  2.支持移动设备  3.程序调用  4.安全 ...
  • 彻底理解cookie,session,token的区别

    万次阅读 多人点赞 2019-07-03 16:55:53
    1、很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应,  尤其是我不用记住是谁刚刚发了...
  • Apache Shiro 会话管理

    千次阅读 2012-11-16 15:29:47
    在安全框领域,Apache Shiro 提供了一个独一无二的东西:一个完整的企业级Session 解决方案,从最简单的命令行及智能手机应用到最大的集群企业Web 应用程序。如果你需要session 支持,你可以使用Shiro的Session...
  • http协议是无状态协议,请求之间是没有联系的,cookie、session、token可以帮助服务器区分到底是谁在访问
  • 了解基于Token的身份验证的来龙去脉

    千次阅读 2016-03-29 09:37:10
    在大多数使用Web API的互联网公司中,tokens 是多用户下处理认证的最佳方式。 以下几点特性会让你在程序中使用基于Token的身份验证 1.无状态、可扩展  2.支持移动设备  3.程序调用  4.安全 ...
  • springboot整合shiro-session管理(六)

    万次阅读 多人点赞 2018-09-11 10:27:19
    原文地址,转载请注明出处: https://blog.csdn.net/qq_34021712/article/details/80418112 &...a
  • 精选(5) 彻底理解cookie,session,token

    万次阅读 2019-05-02 22:14:24
    1、很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应, 尤其是我不用记住是谁刚刚发了HTTP...
  • laravel api模块session无法方法获取的问题 原文参考 因前后端分离,用户登录后,用session保存用户登录信息。 在开发过程中,session保存成功,但无法在其他方法内获取session信息。 因为laravel用的自己封装的...
  • webapi鉴权使用token令牌

    千次阅读 2018-07-08 22:51:14
    一为什么使用Token验证:在app开放接口api的设计中,避免不了的就是安全性问题,因为大多数接口涉及到用户的个人信息以及一些敏感的数据,所以对这些接口需要进行身份的认 证,那么这就需要用户提供一些信息,比如...
  • HttpSession工作原理简介

    万次阅读 2012-05-08 11:08:17
    HTTP协议(http://www.w3.org/Protocols/)是“一次性单向”协议。  服务端不能主动连接客户端,只能被动等待并答复客户端请求。客户端连接服务端,发出一个HTTP Request,服务端处理请求,并且返回一个...  ...
1 2 3 4 5 ... 20
收藏数 27,452
精华内容 10,980
关键字:

webapi 跨站session