定制 pccomponentes/apixception-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

pccomponentes/apixception-bundle

最新稳定版本:v2.1.0

Composer 安装命令:

composer require pccomponentes/apixception-bundle

包简介

Bundle to handle and render custom exceptions in API-Style projects using symfony kernel events.

README 文档

README

El objetivo de esta librería es ofrecer una pequeña ayuda al programador a la hora de renderizar las excepciones que llegan al controlador, como respuestas del API. Está integrado usando el evento Kernel.exception del Kernel de Symfony Framework v4. Las respuestas serán en formato JSON (Symfony\Component\HttpFoundation\JsonResponse).

Instalación

  1. Descarga e instala el vendor usando composer.

    $ composer require pccomponentes/apixception-bundle
  2. Añade el bundle en config\bundles.php. Por ejemplo:

    <?php
    
    return [
        Symfony\Bundle\FrameworkBundle\FrameworkBundle::class => ['all' => true],  
        PcComponentes\Apixception\ApixceptionBundle::class => ['all' => true]  
    ];
  3. Escribe el fichero de configuración del bundle indicando las excepciones que deseas capturar, y su transformación para generar la respuesta. Para ello, crea un archivo con nombre apixception.yaml en la ruta config/packages. Un ejemplo de su contenido es:

    apixception:
      - exception: PcComponentes\Ddd\Domain\Exception\NotFoundException
        transformer: PcComponentes\Apixception\Core\Transformer\JsonSerializableTransformer
        http_code: 404
      - exception: PcComponentes\Ddd\Domain\Exception\ExistsException
        transformer: PcComponentes\Apixception\Core\Transformer\JsonSerializableTransformer
        http_code: 409
      - exception: PcComponentes\Ddd\Domain\Exception\LogicException
        transformer: PcComponentes\Apixception\Core\Transformer\JsonSerializableTransformer
        http_code: 409
      - exception: \Throwable
        transformer: PcComponentes\Apixception\Core\Transformer\NoSerializableTransformer
        http_code: 500

    Este archivo se modificará para añadir o quitar las reglas que sean necesarias para el proyecto en el que se use.

Configuración

Este archivo debe contener un listado de reglas. Cada regla debe tener:

  • exception: Nombre de la clase o interface, namespace incluído, que representa el tipo de la excepción que se quiere capturar.
  • http_code: Código HTTP que devolverá el objeto Symfony\Component\HttpFoundation\JsonResponse.
  • transformer: Clase con namespace incluído, que transformará la excepción en un array de datos serializables por el objeto Symfony\Component\HttpFoundation\JsonResponse.

Creación de un nuevo transformador

Aunque la aplicación proporciona un par de transformadores básicos, está abierto para que cada proyecto pueda inyectar sus propios transformadores. Las excepción deben implementar la interfaz \Throwable o de heredar de clases que ya lo hagan. Los transformadores son clases que deben heredar de la clase PcComponentes\Apixception\Core\Transformer\ExceptionTransformer. Por cuestiones de simplicidad, no se permite inyectar dependencias, así que heredar de esta clase implica tener un constructor vacío y contener lógica de transformación ligera.

Un ejemplo de un transformador propio sería:

<?php
namespace MyApp\Transformers;

use PcComponentes\Apixception\Core\Transformer\ExceptionTransformer;

class CustomTransformer extends ExceptionTransformer
{
	public function transform(\Throwable $exception): array
	{
		return [
			'exception' => \get_class($exception),
			'message' => $exception->getMessage(),
		];
	}
}

Si llegara una excepción personalizada, con métodos únicos, puedes usarlas. Asegúrate que en la configuración garantice que a tu transformador sólo llegan excepciones del tipo que esperas, o haz que tu transformador actúe en consecuencia.

Transformadores disponibles

La librería proporciona dos transformadores que puedes usar desde el primer momento.

  • PcComponentes\Apixception\Core\Transformer\NoSerializableTransformer: Este transformador es capaz de renderizar cualquier tipo de excepción. En la respuesta meterá un objeto JSON con las propiedades exception con el nombre de la excepción, y message, con el mensaje de la excepción.
  • PcComponentes\Apixception\Core\Transformer\JsonSerializableTransformer: Este transformador será capaz de renderizar cualquier excepción que implemente la interfaz \JsonSerializable. El array que devuelva dicho método, será lo que se incluya en la respuesta.

Excepciones

Como se ha comentado anteriormente, esta librería acepta excepciones de todo tipo.

统计信息

  • 总下载量: 96.32k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 未知

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固