mysql 存储过程 跨域_Laravel API接口跨域访问 “Access-Control-Allow-Origin”

在通过ajax在页面上调用laravel框架的API接口时,如果不做任何设置一般会出现如下错误:

No ‘Access-Control-Allow-Origin’ header is present on the requested resource.

Origin ‘http://localhost:8080′ is therefore not allowed access。

主要的意思就是服务器响应不允许跨域访问。为了解决这个问题,我们需要设置允许laravel框架支持跨域访问。

在laravel框架中,让服务器支持跨域访问, 需要在响应头部中添加’Access-Control-Allow-Origin: *’ ,主要方法如下:

1、创建中间件

创建"app/Http/Middleware/CORS.php"的中间件类文件,把"Access-Control-Allow-Origin: *"

写入头部。

代码如下:

namespace App\Http\Middleware;

use Closure;

class CORS

{

public function handle($request, Closure $next)

{

return $next($request)->header('Access-Control-Allow-Origin', '*')

->header('Access-Control-Allow-Methods', 'POST, GET, OPTIONS, PUT, DELETE')

->header('Access-Control-Allow-Headers', 'Content-Type, Accept, Authorization,

X-Requested-With');

}

}

2、注册中间件路由

注册跨域访问中间件CORS.php到kernel中。

分别在 protected $middleware 数组中添加跨域访问中间件的class文件路径。

代码如下:

protected $middleware = [

\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,

\App\Http\Middleware\CORS::class, //跨域访问中间件

];

a42df0e0d5ea35fb9097ba220c794961.png

本项目经过以上设置之后,API接口即可跨域访问。

待项目上线之后,如果需要指定某域名才允许跨域访问,

只需把Access-Control-Allow-Origin:*改为Access-Control-Allow-Origin:允许的域名即可。

例如:header('Access-Control-Allow-Origin: http://www.xxxxx.com');

最后编辑:2018-06-09作者:admin

e92b12f03770d2314124ea8f3c578f20?s=96&d=mm&r=g

这个作者貌似有点懒,什么都没有留下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值