Laravel/Lumen中使用跨域功能

   2016-10-13 0
核心提示:目前我所知道的两种跨域方式,一种是JSONP,一种是CORS。本篇文章会简单的介绍一下JSONP的原理,会介绍JSONP在Laravel/Lumen中的实现方式,由于CORS在Github上已经有Laravel/Lumen的扩展包了,这里就不再实现了。 JSONPJSONP原理 JSONP,也就是JSON with Padd

Laravel/Lumen中使用跨域功能

目前我所知道的两种跨域方式,一种是JSONP,一种是CORS。

本篇文章会简单的介绍一下JSONP的原理,会介绍JSONP在Laravel/Lumen中的实现方式,由于CORS在Github上已经有Laravel/Lumen的扩展包了,这里就不再实现了。

JSONP

JSONP原理

JSONP,也就是JSON with Padding的意思,这是一种利用<script>标签可以跨域的漏洞实现的数据交互协议,但是这种协议是非官方的,下面先看看实际上是怎么实现数据交互的。

首先,我们先在html中预定义一个回调函数:

function sayhello(data){
   alert(data.message);
}

之后,操作dom元素,动态添加一个script元素,这也是我们实现跨域的最重要的部分。

var scriptElement= document.createElement("script");
scriptElement.src = "http://www.example.com/test?callback=sayhello";
document.getElementsByTagName("HEAD")[0].appendChild(scriptElement);

在html中动态添加一个script元素后,浏览器会发起一个GET请求,地址是 http://www. example.com/test? callback=sayhello

服务器收到请求后,将需要返回的JSON数据使用回调方法的形式包裹成一个js脚本,方法名也就是上面传入callback查询参数值,这里是sayhello。

sayhello({message:'hello'});

所以,返回如上的js脚本给浏览器,浏览器会立即执行这段代码,我们也就可以通过回调函数回去到数据了,果然程序员们的智慧是无穷的: )。

JSONP的缺点就是只支持GET请求,不支持诸如POST,PATCH,DELETE等请求。

在Lumen中实现JSONP

其实Larave/Lumen已经提供了返回一个JSONP响应的方法了,下面来看看如何使用:

...
//判断是不是一个jsonp请求,可以从callback参数是否存在,并且是否是get请求进行判断

//返回一个jsonp响应。
return response()->json(['name' => 'Mike', 'age' => '12'])
    ->setCallback($request->input('callback'));

在中间件中实现JSONP

为了不用每次都setCallback,我们可以在中间件中来处理JSONP。

class JSONPMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request $request
     * @param  \Closure $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {

        $response = $next($request);

        //不是jsonp请求,不作处理,放行
        if (!$request->isMethod('GET') || 
            !$request->has('callback') || 
            !$response instanceof JsonResponse) {
            return $next($request);
        }

        //处理后返回
        return $response->setCallback($request->input('callback'));
    }
}

CORS

简单的说就是服务端通过对HTTP响应增加响应头来实现,需要服务器和浏览器都支持才行。

推荐看一下这篇文章《 阮一峰-跨域资源共享 CORS 详解 》这里就不做过多的深入。

最后推荐一个Lumen/Laravel扩展包,通过Middleware的形式实现的CORS跨域。作者是写laravel-ide-helpers的那个人。

点击前往 barryvdh/laravel-cors: cors for laravel and lumen

 
标签: Laravel JSONP
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • nginx 各类网站设置 (laravel , thinkphp , nod
    基础部分设置[root@centos ~]# vim /opt/nginx/conf/nginx.confuser www www;worker_processes auto;pid logs/nginx.pid;worker_rlimit_nofile 100000;events {use epoll;multi_accept on;worker_connections 65535 ;}http {include mime.types;default_type
    02-09
  • PHP trait 特性在 Laravel 中的使用个人心得
    trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?我曾在 Laravel 中大型项目面向
    02-09
  • 让我们用 laravel-mix 为 TypeScript 和 Sass
    介绍前端编译TypeScript、Sass、模板引擎等时经常用到Gulp和webpack。这是我个人的印象,但它们似乎都难以管理,因为它们的描述往往复杂而冗长。我不想积极进行,因为我要担心加载器的顺序并且有很多配置选项,我必须花时间去了解它们。我想推荐那里laravel
  • PHP Laravel软删除的实现方法介绍
    用Laravel 自带的 Eloquent ORM 来实现软删除。首先在数据迁移文件中添加删除时间字段./database/migrations/2014_10_12_000000_create_users_table.php?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illu
  • Laravel中如何使用PHP的装饰器模式 php laravel
    本文小编为大家详细介绍“Laravel中如何使用PHP的装饰器模式”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel中如何使用PHP的装饰器模式”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。装饰器模式定义:它可以帮助您在
    02-08 laravelphp
  • PHP laravel使用自定义邮件类实现发送邮件
    PHP laravel使用自定义邮件类实现发送邮件
    当登录邮箱为腾讯企业邮箱的时候。Phpmailer发送邮件就不好用了,具体哪里不好用,我没真没找到。但是,邮件得发啊,怎么办呢?我这里搞了一个自定义的发送邮件类,腾讯企业邮箱也可用。但是,邮件发送失败,不会返回报错信息,这个可能是有点坑。源码如下:?
  • 详解PHP laravel中的加密与解密函数
    目录一:简介二:配置三:使用加密/解密1:加密2:不使用序列化进行加密3:解密Laravel为我们提供了完整的加密方法及加密模式。我之前一般在加密的时候使用的是我自己写的加密函数,但是这个玩意,有的位置还是不太使用,当然,破解的话,基本上也是不可能的
  • PHP laravel缓存cache机制详解
    目录一、访问多个缓存存储二、从缓存中获取数据1.获取数据并设置默认值2.检查缓存项是否存在3.数值增加/减少4.获取存储5.获取删除三、缓存中存储数据1.获取存储数据2.缓存不存在时存储数据3.永久存储数据四、从缓存中移除数据Laravel中的cache为我们提供了三
  • PHP laravel实现导出PDF功能
    PHP laravel实现导出PDF功能
    目录一、laravel-tcpdf二、tcpdf三、TCPDF解决保存中文文件名的方法补充一、laravel-tcpdf导出PDF文件Laravel框架为我们集成了一个插件tcpdf。下载地址:https://github.com/elibyy/tcpdf-laravel然后使用composer进行安装就可以了。具体安装过程,请查看文末
  • PHP laravel缓存cache机制怎么实现
    今天小编给大家分享一下PHP laravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为我们
点击排行