首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

完善你的Laravel异常处理

这篇文章我们来简单梳理一下Laravel中提供的异常处理能力,然后讲一些在开发中使用异常处理的实践,如何使用自定义异常、如何扩展Laravel的异常处理能力。...这里的ExceptionHandler就是 \App\Exceptions\Handler类的实例,它是在项目最开始注册到服务容器中的: // bootstrap/app.php /* |------...,异常处理器只能处理Exception不能处理Error,所以为了能够兼容老类库通常都会使用 set_error_handler注册全局的错误处理器方法,在方法中捕获到错误后将错误转化成异常再重新抛出,...Laravel的处理HTTP请求不成功时抛出此异常 扩展Laravel的异常处理器 上面说了Laravel把 \App\Exceptions\Handler 注册成功了全局的异常处理器,代码中没有被...catch到的异常,最后都会被 \App\Exceptions\Handler捕获到,处理器先上报异常记录到日志文件里然后渲染异常响应再发送响应给客户端。

2.8K20

Laravel5.3之Errors Tracking神器——Sentry

,毕竟这些Exceptions是有很多敏感数据,而这些数据是放在别人家的云服务器上,谁知道会发生什么呢;Sentry Server是Python写的,可以部署在自己的云服务器上如AWS或Aliyun,如我司是部署在...Sentry提供针对几乎每种语言的平台Sentry Platform,这里介绍下如何在Laravel程序中集成Sentry。...Laravel中异常处理类\App\Exceptions\Handler主要包含两个方法report()和sender(),其中report()就是主要用来向第三方service发送异常报告,这里选择向...当然有时由于业务需求,如根据不同模块报异常level不一样,需要定制下Sentry类,这里只是简单捕获异常,并默认为都是error level。 OK,所有的工作就这么简单的完成了。...试一下,如在浏览器中输入一个不存在的路由如http://sentry.app:8888/sentry,然后报NotFoundHttpException,查看Sentry有没有捕获到: 然后查看HipChat

3.7K71
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Laravel5.3之bootstrap源码解析

    异常处理 异常处理是十分重要的,Laravel中异常处理类\App\Exception\Handler中有一个方法report(),该方法可以用来向第三方服务(如Sentry)发送程序异常堆栈(以后在一起聊聊这个...\Exceptions\Handler对象 // 在boostrap/app.php中做过singleton()绑定 return $this->app->make('Illuminate...()->render($this->app['request'], $e)->send(); } 从源码中知道,重点是使用App\Exceptions\Handler的report()方法报告异常情况...,如向Sentry报告异常堆栈和其他有用信息;App\Exceptions\Handler的render()方法通过Request发送到浏览器。...这个过程主要使用了两个技术:一个是外观类的别名;一个是PHP的重载,可看这篇:Laravel5.2之PHP重载(overloading)。 6.

    7K51

    Laravel学习笔记之bootstrap源码解析

    异常处理 异常处理是十分重要的,Laravel中异常处理类\App\Exception\Handler中有一个方法report(),该方法可以用来向第三方服务(如Sentry)发送程序异常堆栈(以后在一起聊聊这个...\Exceptions\Handler对象 // 在boostrap/app.php中做过singleton()绑定 return $this->app->make('Illuminate...()->render($this->app['request'], $e)->send(); } 从源码中知道,重点是使用App\Exceptions\Handler的report()方法报告异常情况...,如向Sentry报告异常堆栈和其他有用信息;App\Exceptions\Handler的render()方法通过Request发送到浏览器。...这个过程主要使用了两个技术:一个是外观类的别名;一个是PHP的重载,可看这篇:Laravel学习笔记之PHP重载(overloading)。 6.

    3.9K00

    Laravel 开发 RESTful API 的一些心得

    // more }); 如果前端想跨域,请使用这个很方便的包barryvdh/laravel-cors 一个简单的接口示例 接口代码 验证 API 开发总会离不开验证,这里推荐使用jwt-auth...,1.0 快要来了,新版本的文档也很清晰 刚用jwt-auth时有疑问,Laravel自带的token验证使用的是数据库api_token字段验证,而不见jwt-auth需要这个 然后想自己看源码,结果...laravel用的是中划线(-),因为谷歌收录时,按中划线划分关键字,国内的是按下划线(_)收录,具体看自己了,我是喜欢下划线 >_< 更多看这里: 路由命名规范 表单验证 可以使用控制器自带的表单验证...在有不确定是否输出关联数据时,这是一个很有用的功能!!! 响应输出 当时在 laravel-china 看到的这个帖子,然后觉得这个方式不错,所以自己也这样子,使用基类的方法统一响应输出。...\App\Exceptions\Handler::render方法可以捕获到很多有用的异常,例如,我的代码是这样写的: 异常处理 UnauthorizedHttpException这个是捕获jwt异常

    43210

    Laravel 开发 RESTful API 的一些心得

    验证 API 开发总会离不开验证,这里推荐使用jwt-auth,1.0 快要来了,新版本的文档也很清晰 刚用 jwt-auth时有疑问,Laravel自带的token验证使用的是数据库apitoken字段验证...laravel用的是中划线(-),因为谷歌收录时,按中划线划分关键字,国内的是按下划线(_)收录,具体看自己了,我是喜欢下划线 >_< 更多看这里: 路由命名规范(https://laravel-china.org.../courses/laravel-specification/502/router) 表单验证 可以使用控制器自带的表单验证,更推荐使用表单类(https://laravel-china.org/docs...响应输出 当时在 laravel-china 看到的这个帖子,然后觉得这个方式不错,所以自己也这样子,使用基类的方法统一响应输出。 异常 异常算是一大手笔了,处理好异常,可以让你的代码优雅很多。...\App\Exceptions\Handler::render方法可以捕获到很多有用的异常,例如,我的代码是这样写的: ? UnauthorizedHttpException这个是捕获 jwt异常。

    3.9K90

    Laravel源码解析之从入口开始

    前言 提升能力的方法并非使用更多工具,而是解刨自己所使用的工具。今天我们从Laravel启动的第一步开始讲起。.../bootstrap/app.php'; 获取$app是laravel启动的关键,也可以说$app是用于启动laravel内核的钥匙?。..., 这其中包括了很多基础性的方法和类,例如 – db [\Illuminate\Database\DatabaseManager::class] – auth [\Illuminate\Auth...而$app这个在服务提供者的核心变量则就是Application实例化所得,而你在服务提供者内使用的make,bind,singleton来自他的父类Container,都说容器是laravel的核心概念...::class, App\Exceptions\Handler::class ); App\Http\Kernel 核心类了所有的 – 系统中间件 – 群组中间件 – 路由中间件 当然你需要使用中间件也是在这个类中加载

    83710

    Laravel 如何优雅的实现输出结构统一的功能?

    假设这么一种场景,应用做api开发,使用抛异常的方式(自定义异常类ApiException)返回无效非法请求的情况。...Laravel的调用链使得控制器里的异常在正常情况下,还没有抛到中间件就被系统注册的ExceptionHandler类拦截处理了。...\Exceptions\Handler 中render方法处理,格式化,处理逻辑如下: public function render($request, Exception $e) { if($e...其实需要改动的内容非常上,只需要在ExceptionHandler中的handle方法中,对于自定义异常类ApiException继续向上抛出去就可以在middleware捕获到异常,进而对异常放回进行格式化...修改之后App\Exceptions\Handler 中render的代码如下: public function render($request, Exception $e) { if($e instanceof

    2.1K20

    Laravel API教程:如何构建和测试RESTful API

    关于一致性的说明 使用一组约定(如REST)的最大优点是您的API将更容易消费和开发。...我们可以通过编辑在app/Exceptions/Handler.php中我们的异常处理程序类来修复它,以返回JSON响应: public function render($request, Exception...使用中间件限制访问 通过api_token创建,我们可以切换路由文件中的身份验证中间件: Route::middleware('auth:api') ->get('/user', function...这是因为我们需要在我们的Handler类上编辑当前的 unauthenticated方法。...绝对有改进的空间 - 您可以使用Passport软件包实现OAuth2 ,集成分页和转换层(我推荐使用Fractal),但是我想通过在Laravel中创建和测试API的基础知识外部包装。

    20.4K20

    通过修改Laravel Auth使用salt和password进行认证用户详解

    加密字符串的方式来记录用户的密码的,这就给使用Laravel框架来重构之前的项目带来了很大的阻力,不过最近自己通过在网上找资料、看社区论坛、看源码等方式完成了对Laravel Auth的修改,在这里分享出来希望能对其他人有所帮助...MYSQL建议使用5.7以上的版本】/改用户登录 修改登录前我们需要先通过路由规则看一下登录请求的具体控制器和方法,在上文提到的auth方法定义里可以看到 $this->get('login', 'AuthAuthController...打开AuthController发现Auth相关的方法都是通过性状(traits)引入到类内的,在类内use 要引入的traits,在编译时PHP就会把traits里的代码copy到类中,这是PHP5.5...Auth使用,好了做完这些修改后Laravel的Auth在做用户登录验证的时候采用的就是自定义的salt + password的方式了。...注:使用的Laravel版本为5.2

    3K30

    Laravel源码解析之HTTP Kernel

    内核绑定 既然Http Kernel是Laravel中用来串联框架的各个部分处理网络请求的,我们来看一下内核是怎么加载到Laravel中应用实例中来的,在 public/index.php中我们就会看见首先就会通过...\Handler::class ); return $app; HTTP 内核继承自 Illuminate\Foundation\Http\Kernel类,在 HTTP 内核中 内它定义了中间件相关数组...应用解析内核 在将应用初始化阶段将Http内核绑定至应用的服务容器后,紧接着在 public/index.php中我们可以看到使用了服务容器的 make方法将Http内核实例解析了出来: $kernel...,它会加载在内核中定义的引导程序来引导启动应用然后会将使用 Pipeline对象传输HTTP请求对象流经框架中定义的HTTP中间件们和路由中间件们来完成过滤请求最终将请求传递给处理程序(控制器方法或者路由中的闭包...send()方法完成父类其定义在父类 Symfony\Component\HttpFoundation\Response中。

    1.4K30

    DRF JWT认证(二)

    定制签发token返回格式 JWT源码分析 签发源码分析 认证源码分析 签发源码内的其他两个类 自定义User表,签发token 普通写法,视图类写 序列化类中写逻辑 自定义认证类 补充:HttpRequest.META...JSONWebTokenSerializer序列化类中全局钩子中获取当前登录用户和签发token ··· payload = jwt_payload_handler(user)...直接返回None,也不会报错,所以必须搭配权限类使用 ··· return auth[1] # 一切符合判断条件,通过split切分的列表索引到token串 ''...',views.UserView,'user') 序列化类中写逻辑 源码中签发校验都在序列化类中完成,这种写法确实比较常用,我们来使用这种方式自定义,将上面视图的校验逻辑写到序列化类中,这个序列化类只用来做反序列化...,context只是我们定义的字典,比如上面写到的实例化序列化类中指定的context,那么就可以从序列化类打印出请求的方法,context是序列化类和视图类沟通的桥梁 自定义认证类 auth.py import

    1.1K20
    领券