Debugbar ,如此一来,对于开发的进行更是方便友好 框架:Laravel5.5 (其他版本多数也可支持此操作) ♪ 简介 Laravel Debugbar 在 Laravel 5 中集成了...该扩展包包含了一个 ServiceProvider 用于注册调试条及开发过程中数据集合显示,你可以发布其前端资源和配置,还可以配置显示重定向及 Ajax 请求 【注意】:只能在开发过程中使用该 Laravel...使用 Composer 安装该扩展包 composer require barryvdh/laravel-debugbar ②....Barryvdh\Debugbar\ServiceProvider::class, 如果你想使用门面,在配置文件 config/app.php 中添加如下门面别名到 aliases 数组: 'Debugbar...参考文章 Laravel 调试利器 —— Laravel Debugbar 扩展包安装及使用教程
一、知识要点 1、ajax对象(XMLHttpRequest和ActiveXObject) 2、如何兼容IE6浏览器 二、源码参考 未封装请求 ...= document.getElementById('div1'); oBtn.onclick = function () { //1.创建Ajax...(方法, 文件名, 异步传输) oAjax.open('GET', 'a.txt', true); // 读取a.txt //3.发送请求
访问频率限制中间件throttle的使用 1、访问频率限制概述 频率限制经常用在API中,用于限制独立请求者对特定API的请求频率。...X-RateLimit-Limit告诉我们在指定时间内允许的最大请求次数, X-RateLimit-Remaining指的是在指定时间段内剩下的请求次数, Retry-After指的是距离下次重试请求需要等待的时间...注意:每个API都会选择一个自己的频率限制时间跨度,GitHub选择的是1小时,Twitter选择的是15分钟,Laravel中间件选择的是1分钟。...2、如何使用Laravel的访问频率限制中间件 在Laravel 5.2的新特性中,你可以使用一个新的中间件 throttle,让我们先来看看这个中间件的用法,首先我们定义一个路由规则如下: Route...原因如下: laravel框架api路由默认加载 throttle中间件,该中间件限制了一分钟内访问api的次数: 注释掉这行之后就取消了访问的限制 第一个参数 60 代表每分钟限制 60 次请求
Laravel-debugbar 可以打印出每个请求执行的sql 安装 composer require barryvdh/laravel-debugbar 执行完即可,打开任一html页面(返回json...的不行) 更详细的说明请参考:https://github.com/barryvdh/laravel-debugbar Artisan tail 实时显示系统日志 安装 composer require...spatie/laravel-tail 执行完即可,常用命令 php artisan help tail php artisan tail 更详细的说明请参考:https://github.com/...spatie/laravel-tail
从今天起phalcon开发者们再也不用羡慕Zf,Laravel,Ci等集成了php debug bar的框架,因为phalcon已经正式成为了其中一员。...目前版本主要以Laravel debugbar的具有功能为蓝本开发,并针对phalcon的功能特征进行了小幅更改,未来版本还将针对phalcon的功能进行进一步扩展丰富。...再执行如下命令,创建“Runtime/debugbar”目录。...cd vendor mkdir -p Runtime/debugbar chmod -R 0777 Runtime 此举是为了支持ajax调试和重定向调试功能,debugbar是默认开启了调试数据持久化功能...debugbar.php是phalcon-debugbar的配置文件,复制到项目的配置文件存放目录的主要目的,一方面是可以为每个项目中的应用模块进行差异化的配置;另一方面也是方便phalcon-debugbar
前言 之前介绍过 Laravel调试利器:Laravel Debugbar 但是我每张页面都要在底部显示有点碍眼。...Telescope 可深入了解进入应用程序的请求、异常、日志条目、数据库查询、排队作业、邮件、通知、缓存操作、计划任务、变量转储等。Telescope 是您本地 Laravel 开发环境的绝佳伴侣。...安装 官网: https://laravel.com/docs/5.8/telescope composer安装 composer require laravel/telescope ?...更多文档:https://learnku.com/docs/laravel/5.8/telescope/3948 界面介绍 ? 一进来便是请求监听。...如上图所示,监听了很多请求,并且在后面显示有时多久前发生的。 其他监听 ? 如图所示,可以监听: 命令行 ? 命令选项列出已运行的所有命令及其退出代码。
推荐Laravel开发插件三件套,提高开发效率,可以参考之前写的Laravel5.2之Seeder填充数据小技巧: composer require barryvdh/laravel-debugbar...--dev //config/app.php /** *Develop Plugin */ Barryvdh\Debugbar\ServiceProvider...MySQL中请求到最新的view_count, //当然,100秒内view_count还是缓存的旧数据,极端情况300秒内都是旧数据,而缓存里已经有了29个新增访问量...还推荐一个Redis客户端:Redis Desktop Manager,可以在客户端里看下各个键值: 页面视图中可以利用上面推荐的barryvdh/laravel-debugbar插件观察下请求过程产生的数据...第一次请求时会有一次query,然后从缓存里取值没有query了,直到把缓存中view_count刷到MySQL里再有一次query: It is working!!!
如果配置并开启了Debugbar,可能会得到如下的报错信息 ... return $this->addCookieToResponse($request,$next($request)); } throw...原因 Laravel 推荐在全局注册 VerifyCsrfToken 的 Middleware ,对所有 Post、Put、Delete 请求自动校验是否带合法的 _csrf token ♫....parent::handle($request, $next); // 禁用CSRF return $next($request); } 方法 ⑤ [适用于 Laravel5.5...,取消请求的 csrf_token验证,不是取消全部] 跟上述的方法4 类似,打开 app\Http\Middleware\VerifyCsrfToken.php 文件,找到 protected $except...Laravel 5.3 文档 - CSRF攻击原理及其防护 2. Laravel 5.3 文档 - HTTP层 CSRF保护
它的回调函数有两个参数,第一个是异常对象,第二个是请求信息。通过这个请求信息,我们就可以构造不同的响应返回页面。...比如说在这里我通过判断请求是否是 ajax 请求来返回不同的响应的内容,如果是 ajax 请求,那么就返回 json 格式的错误信息。如果不是的话,就返回一个我自己定义的错误页面。...{{$msg}} 聪明的你一定想到了,对于我们很多的业务开发来说,前后端分离已经是现行的标准规范,只要是 ajax 请求,默认的响应处理器就会返回 json 格式的错误信息...HTTP异常 HTTP 异常主要的体现其实就是我们返回的 HTTP 状态码,比如说 404 找不到页面,401 未授权,500 错误,502 服务不可用之类的。...现在主要的疑问是在于 Laravel 框架中是如何去捕获这些全局的异常和错误信息的,是使用我们熟悉的 set_error_handler()、set_exception_handler() 这些函数吗?
性能一直是 Laravel 框架为人诟病的一个点,所以调优 Laravel 程序算是一个必学的技能。 接下来分享一些开发的最佳实践,还有调优技巧,大家有别的建议也欢迎留言讨论。...性能一直是 Laravel 框架为人诟病的一个点,所以调优 Laravel 程序算是一个必学的技能。 接下来分享一些开发的最佳实践,还有调优技巧,大家有别的建议也欢迎留言讨论。...optimize 自动加载优化 composer dumpautoload 使用 Memcached 来存储会话 config/session.php 使用专业缓存驱动器 config/cache.php 数据库请求优化...使用 Memcached 来存储会话 每一个 Laravel 的请求,都会产生会话,修改会话的存储方式能有效提高程序效率,会话的配置信息是 config/session.php,建议修改为 Memcached...数据库请求优化 数据关联模型读取时使用 延迟预加载 和 预加载 ; 使用 Laravel Debugbar 或者 Clockwork 留意每一个页面的总数据库请求数量; 这里的篇幅只写到与 Laravel
Stars: 14.9k+ 网址:https://github.com/composer/composer 6、Guzzle Guzzle是一个PHP的HTTP客户端,它使得在PHP代码中发送HTTP请求变得极其简单...GitHub Stars: 7k+ 网址:https://github.com/filp/whoops 15、Laravel Debugbar Laravel Debugbar是一个用于Laravel...可以使用laravel发布资产并进行配置。...GitHub Stars: 7k+ 网址:https://github.com/barryvdh/laravel-debugbar 16、Intervention Image Intervention...你可以轻松地配置一个OAuth 2.0服务器来使用访问token保护你的API,或者允许客户端来请求新的访问token。
overtrue/laravel-wechat Symfony lilocon/WechatBundle 我这里使用的是laravel,安装好后路径是这样的 ?...php -i | grep 'OpenSSL support' OpenSSL support => enabled OpenSSL support => enabled 这是由于微信支付授权目录未正确配置引起的...所有实际调起微信支付请求的页面都必须要所配置的支付授权目录之下。...使用在线调试工具的消息接口,http://mp.weixin.qq.com/debug/, 只要返回绿色的“请求成功”,就代表你的代码没有问题,请重复上面第4项再测试。...另外有的朋友的 Laravel 里使用了 laravel-debugbar,这个组件的原理是在页面输出时在后面添加 HTML 来实现的,所以它会改变我们返回给微信的内容,此时要么卸载,要么禁用掉它。
跨源请求共享(CORS):当使用AJAX调用从另一个域(跨域,Cross-origin)获取资源时,我们可能会遇到禁止请求的问题,因为默认情况下,HTTP请求不包括跨域(Cross-origin)请求的...为了简洁起见,我将把我所有的代码放在route.php文件中,该文件负责Laravel路由和委托请求给控制器。...该中间件用于过滤请求并验证JWT token。如果token无效,不存在或过期,则中间件将抛出一个可以捕获的异常。...在Laravel 5中,我们可以使用app/Exceptions/Handler.php文件捕获异常。使用render函数,我们可以基于抛出的异常创建HTTP响应。...在进行AJAX调用时,要获得一些视觉反馈,我们将使用angular-loading-bar script来拦截XHR请求并创建一个加载栏。
laravel实现翻页太简单了,几行代码就可以搞定,使用起来极其丝滑顺畅。但是由于laravel高度封装了翻页,要对其改造就显得比较尴尬了。...如有些场景下,我们需要异步翻页,看了laravel的文档,没找到相应的方法。如果要通过调用laravel关于翻页的相关方法,手工写一个分页,会很繁琐,对于这种操作,我是拒绝的。...接着截取分页的页码数字,再新增一个onclick事件,事件触发ajax请求,最后将服务器返回的数据替换现有分页 逻辑上是可行的,撸起袖子就干吧... ?...异步请求函数: let url = "{{ route('home.ajax-content') }}"; function AjaxPage(page) {...前者需要在前端用js进行组装;后者需要新建一个ajax视图文件 综上,就能实现ajax分页了,虽然看下来这种实现方式有点怪,至少需要改动的代码并不多,适合懒人
\App\Exceptions\Handler::render方法可以捕获到很多有用的异常,例如,我的代码是这样写的: ? UnauthorizedHttpException这个是捕获 jwt异常。...ValidationException这个是表单异常,捕获之后,表单错误消息可以很好的格式化。...ModelNotFoundException这个是模型找不到的异常,捕获之后,可以直接在控制器直接这样。...// 未捕获之前的写法 public function show($id) { $user = User::find($id); if (!...只是方便开发中查看错误消息 NotFoundHttpException404路由找不到的异常,没什么好说的了 MethodNotAllowedHttpException这个是方法不对应,比如你是get路由,却post请求
CSRF问题 csrf也就是laravel默认在表单提交中都会验证csrf字串,没有的话就不会予以通过。 当然,你在普通的表单中加一个@csrf,系统就会自动增加一个hidden隐藏域。...或者你用laravel自带的axios,laravel也做过处理: resources/js/bootstrap.js ? 那么如果我使用jquery封装的ajax,如何处理呢?...') } }); 但是,就要求在meta中有一个_token的值,也即需要: 那么,也就可以请求...ajax了。...$.ajax({ headers: { 'X-XSRF-TOKEN': $.cookie('XSRF-TOKEN') } }); Laravel默认也会在Cookies
CSRF是”cross site request forgery”的意思,简单来说就是防止恶意页面中一个简单的form提交,就向你保持了登陆状态了网站里请求做一些你不想做的事情……言尽于此,我们之间看Laravel...Laravel(5以后)有个默认的CSRF middleWare,所有POST,PUT请求都会经过这个middleWare,看有没有csrf的token存在并且匹配,不存在的话就会抛出错误页面。...在Laravel的表单中,埋入一个就可以在表单请求的时候发出正确的token,这样就不会有问题了,而在ajax请求的时候呢,方法多多~ 1....因为你总是要在页面的什么地方调用csrf_token()输出这个值,然后用js脚本获得这个值~ 我看Laravel源码的时候发现,Laravel默认会把CSRF_TOKEN的值写在一个叫XCRF-TOKEN...补充: You have to add data in your ajax request.
\App\Exceptions\Handler::render方法可以捕获到很多有用的异常,例如,我的代码是这样写的: 异常处理 UnauthorizedHttpException这个是捕获jwt异常...ValidationException这个是表单异常,捕获之后,表单错误消息可以很好的格式化, ModelNotFoundException这个是模型找不到的异常,捕获之后,可以直接在控制器直接这样...// 未捕获之前的写法 public function show($id) { $user = User::find($id); if (!...User::findOrFail($id); } // 甚至这样 public function show(User $user) { // do something } 下面这两个异常可以不捕获...只是方便开发中查看错误消息 NotFoundHttpException404路由找不到的异常,没什么好说的了 MethodNotAllowedHttpException这个是方法不对应,比如你是get路由,却post请求
后端分页分为页面有刷新请求及无刷新请求(Ajax请求),就是前台采用按钮事件或者Ajax请求的方式,告知后台进行分页,同时后台进行计算偏移量及当前页码,进行对应页码数据的请求,之后后台查询好数据进行向前台数据进行传递...Laravel分页 Laravel分页是典型的后台分页,不过它将分页进行了封装,只需要调用它封装好的数据就可以实现分页。 数据分页有几种方法。...默认情况下,HTTP 请求中的 page 查询参数值被当作当前页的页码。Lavarel 自动侦测该值,并自动将其插入到分页器生成的链接中。 在其它框架中,分页可能非常痛苦。...Laravel 的分页器将 查询构造器 和 Eloquent ORM 结合起来,提供了方便、易用的数据库结果集分页。通过分页器生成的 HTML 兼容 Bootstrap CSS 框架。...laravel文档介绍 Laravel分页只需要两个步骤: (1)控制器初始化方法增加paginate方法,向前台渲染数据即可; (2)前台将添加一个Laravel自带的语法{{ $data->links
Laravel 提供了几种不同的方法来验证传入应用程序的数据。...默认情况下,Laravel 的控制器基类使用 ValidatesRequests trait,它提供了一种方便的方法去使用各种强大的验证规则来验证传入的 HTTP 请求。...正如前面所提到的,Laravel 会自动把用户重定向到之前的位置。另外,所有的验证错误信息会被自动 存储到 session。 重申一次,我们不必在 GET 路由中将错误消息显式绑定到视图。...AJAX 请求 & 验证 在这个例子中,我们使用传统的表单将数据发送到应用程序。但实际情况中,很多程序都会使用 AJAX 来发送请求。...当我们对 AJAX 的请求中使用 validate 方法时,Laravel 并不会生成一个重定向响应,而是会生成一个包含所有验证错误信息的 JSON 响应。