> 백엔드 개발 > PHP 튜토리얼 > PHP 속성 작업: 해야 할 일과 하지 말아야 할 일

PHP 속성 작업: 해야 할 일과 하지 말아야 할 일

Linda Hamilton
풀어 주다: 2024-11-14 18:22:02
원래의
945명이 탐색했습니다.

Working with PHP Attributes: Do’s & Don’ts

PHP의 속성은 메타데이터로 코드 요소에 직접 주석을 달 수 있도록 하여 코드 구성을 단순화하고 잠재적으로 Laravel과 같은 프레임워크의 상용구를 줄일 수 있습니다. 그러나 모든 기능과 마찬가지로 속성도 남용되거나 잘못 적용되어 컨트롤러가 지저분해지고 코드 유지 관리가 어려워질 수 있습니다.

이 게시물에서는 코드 명확성을 높이는 방식으로 속성을 사용하는 모범 사례를 살펴보겠습니다. 또한 각 비교에 대한 예가 포함된 '해야 할 일과 하지 말아야 할 일' 표를 제공하여 속성이 잘 작동하는 시나리오와 그렇지 않은 경우를 강조합니다.

1. PHP의 속성 이해

다음은 컨텍스트를 제공하기 위해 속성을 정의하고 사용하는 간단한 예입니다.

#[Attribute]
class MyCustomAttribute {
    public function __construct(public string $description) {}
}

#[MyCustomAttribute("This is a test class")]
class MyClass {
    #[MyCustomAttribute("This is a test method")]
    public function myMethod() {}
}
로그인 후 복사
로그인 후 복사
로그인 후 복사

2. 해야 할 일과 하지 말아야 할 일: 간략한 개요

다음은 모범 사례와 일반적인 함정을 요약한 표입니다.

Do’s Don’ts
Use attributes for standard, repetitive configurations (e.g., HTTP methods, caching). Don’t overload attributes with complex configurations or conditional logic.
Leverage attributes for metadata rather than core application logic. Avoid embedding business logic or intricate rules within attributes.
Apply attributes for simple, reusable annotations (e.g., #[Throttle], #[Cache]). Don’t try to replace Laravel’s route files entirely with attribute-based routing.
Cache attribute-based reflections when possible to improve performance. Don’t rely solely on attributes for configurations that need flexibility or change often.
Document your attributes, so team members understand their purpose and usage. Avoid using attributes for configurations where traditional methods work better (e.g., middleware settings).

3. 예시와의 상세 비교

구체적인 예를 들어 각각의 비교를 살펴보겠습니다.

1. 표준, 반복 구성에 속성 사용(Do)

속성은 복잡한 로직이 필요하지 않은 표준 구성에 이상적입니다. 다음은 세 가지 좋은 예입니다.

  • 경로 정의: 속성을 사용하여 HTTP 메서드 및 경로로 간단한 경로를 정의합니다.
#[Attribute]
class MyCustomAttribute {
    public function __construct(public string $description) {}
}

#[MyCustomAttribute("This is a test class")]
class MyClass {
    #[MyCustomAttribute("This is a test method")]
    public function myMethod() {}
}
로그인 후 복사
로그인 후 복사
로그인 후 복사
  • 캐시 제어: 속성을 사용하여 메서드의 캐시 기간을 지정합니다.
  #[Attribute]
  class Route {
      public function __construct(public string $method, public string $path) {}
  }

  class ProductController {
      #[Route('GET', '/products')]
      public function index() {}
  }
로그인 후 복사
로그인 후 복사
  • 속도 제한: Throttle 속성을 사용하여 사용자당 요청 수를 제한할 수 있습니다.
  #[Attribute]
  class Cache {
      public function __construct(public int $duration) {}
  }

  class ProductController {
      #[Cache(3600)]
      public function show($id) {}
  }
로그인 후 복사
로그인 후 복사

복잡한 구성으로 속성을 오버로드하지 마세요(하지 마세요)

여러 매개변수나 조건이 필요한 구성에는 속성을 사용하지 마세요. 하지 말아야 할 사항은 다음과 같습니다.

  • 여러 구성으로 인한 오버로드: 속성에 여러 매개변수를 추가하지 마세요.
  #[Attribute]
  class Throttle {
      public function __construct(public int $maxAttempts) {}
  }

  class UserController {
      #[Throttle(5)]
      public function store() {}
  }
로그인 후 복사
로그인 후 복사
  • 속성의 조건부 논리: 속성 내에서는 조건부 설정을 피하세요.
  #[Attribute]
  class Route {
      public function __construct(
          public string $method,
          public string $path,
          public ?string $middleware = null,
          public ?string $prefix = null
      ) {}
  }

  #[Route('POST', '/users', middleware: 'auth', prefix: '/admin')]
로그인 후 복사
로그인 후 복사
  • 단일 속성의 연결 구성: 하나의 속성에서 여러 구성 동작을 연결하지 마세요.
  #[Attribute]
  class Condition {
      public function __construct(public string $condition) {}
  }

  class Controller {
      #[Condition("isAdmin() ? 'AdminRoute' : 'UserRoute'")]
      public function index() {}
  }
로그인 후 복사
로그인 후 복사

2. 메타데이터의 속성 활용(Do)

속성에 애플리케이션 로직을 삽입하는 대신 마커나 메타데이터로 속성을 사용하세요. 방법은 다음과 같습니다.

  • 검증을 위한 주석: 속성을 사용하여 필드를 필수로 표시합니다.
  #[Attribute]
  class Combined {
      public function __construct(
          public int $cacheDuration,
          public int $rateLimit
      ) {}
  }

  #[Combined(cacheDuration: 300, rateLimit: 5)]
로그인 후 복사
  • HTTP 메소드를 메타데이터로 지정: 속성을 사용하여 HTTP 메소드 유형을 표시합니다.
  #[Attribute]
  class Required {}

  class User {
      #[Required]
      public string $name;
  }
로그인 후 복사
  • 액세스 수준 표시: 속성을 사용하여 액세스 수준 요구 사항을 나타냅니다.
  #[Attribute]
  class Get {}

  class BlogController {
      #[Get]
      public function list() {}
  }
로그인 후 복사

속성에 비즈니스 로직을 포함하지 마세요(하지 마세요)

애플리케이션 동작을 직접 결정하기 위해 속성을 사용하지 마세요. 하지 말아야 할 사항은 다음과 같습니다.

  • 속성에 직접적인 조건을 피하세요: 속성에 조건부 확인을 넣지 마세요.
  #[Attribute]
  class RequiresAdmin {}

  class SettingsController {
      #[RequiresAdmin]
      public function update() {}
  }
로그인 후 복사
  • 속성에서 메서드 호출 방지: 속성에 함수 호출이나 비즈니스 로직을 배치하지 마세요.
  #[Attribute]
  class AccessControl {
      public function __construct(public string $role) {}
  }

  #[AccessControl(role: isAdmin() ? 'admin' : 'user')]
로그인 후 복사
  • 속성에서 계산된 값 방지: 속성은 계산된 값이 아닌 정적 메타데이터여야 합니다.
  #[Attribute]
  class ConditionalCache {
      public function __construct(public int $duration) {}
  }

  #[ConditionalCache(duration: userHasPremium() ? 3600 : 300)]
로그인 후 복사

3. 간단하고 재사용 가능한 주석에 속성 적용(Do)

속성은 재사용이 가능한 간단한 주석에 적합합니다. 재사용 가능한 주석의 예는 다음과 같습니다.

  • Simple Throttle: 요청 비율을 제한하는 간단한 제한 속성입니다.
#[Attribute]
class MyCustomAttribute {
    public function __construct(public string $description) {}
}

#[MyCustomAttribute("This is a test class")]
class MyClass {
    #[MyCustomAttribute("This is a test method")]
    public function myMethod() {}
}
로그인 후 복사
로그인 후 복사
로그인 후 복사
  • 캐시 제어: 단일 기간 매개변수로 캐시 제어 속성을 추가합니다.
  #[Attribute]
  class Route {
      public function __construct(public string $method, public string $path) {}
  }

  class ProductController {
      #[Route('GET', '/products')]
      public function index() {}
  }
로그인 후 복사
로그인 후 복사
  • 지원 중단 경고: 메서드를 지원 중단으로 표시하여 개발자에게 알립니다.
  #[Attribute]
  class Cache {
      public function __construct(public int $duration) {}
  }

  class ProductController {
      #[Cache(3600)]
      public function show($id) {}
  }
로그인 후 복사
로그인 후 복사

다른 형식에서 더 쉬운 구성에 대해 속성을 남용하지 마십시오(하지 마십시오)

일부 구성은 속성 외부에서 더 잘 관리됩니다. 하지 말아야 할 사항은 다음과 같습니다.

  • 미들웨어 구성: 속성에서 미들웨어를 직접 구성하지 마세요.
  #[Attribute]
  class Throttle {
      public function __construct(public int $maxAttempts) {}
  }

  class UserController {
      #[Throttle(5)]
      public function store() {}
  }
로그인 후 복사
로그인 후 복사
  • 인증 규칙: 정책 파일에서는 복잡한 인증 구성이 더 좋습니다.
  #[Attribute]
  class Route {
      public function __construct(
          public string $method,
          public string $path,
          public ?string $middleware = null,
          public ?string $prefix = null
      ) {}
  }

  #[Route('POST', '/users', middleware: 'auth', prefix: '/admin')]
로그인 후 복사
로그인 후 복사
  • 복잡한 유효성 검사 규칙: 속성에서 유효성 검사 논리를 유지하세요.
  #[Attribute]
  class Condition {
      public function __construct(public string $condition) {}
  }

  class Controller {
      #[Condition("isAdmin() ? 'AdminRoute' : 'UserRoute'")]
      public function index() {}
  }
로그인 후 복사
로그인 후 복사

결론

속성은 특히 Laravel과 같은 PHP 프레임워크에서 반복적인 구성을 처리하는 우아한 방법을 제공합니다.

그러나 단순한 메타데이터일 때 가장 잘 작동하며 복잡한 구성이나 논리로 인해 과부하가 발생하지 않도록 하는 것이 중요합니다.

모범 사례를 따르고 속성을 가볍고 재사용 가능한 주석으로 사용하면 코드베이스에 불필요한 복잡성을 추가하지 않고도 잠재력을 최대한 활용할 수 있습니다.


스폰서

GitHub 후원자에서 저를 후원하여 저의 오픈 소스 작업을 지원해 주세요! 귀하의 후원은 개발자 커뮤니티에 도움이 되는 유용한 Laravel 패키지, 도구 및 교육 콘텐츠를 계속 만드는 데 도움이 됩니다. 오픈 소스를 개선하는 데 도움을 주셔서 감사합니다!


사진: Milad Fakurian, Unsplash

위 내용은 PHP 속성 작업: 해야 할 일과 하지 말아야 할 일의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿