이러한 개념은 코드를 보다 체계적으로 구성하고 유지하는 데 도움이 되므로 소프트웨어 아키텍처에서 널리 사용되는 개념입니다. 이제 각 개인의 역할과 책임을 이해해보세요!
서비스는 사용자가 보내는 요청의 유효성을 검사하는 역할을 담당하는 계층입니다. 즉, 비즈니스 규칙이나 애플리케이션 논리를 담당합니다.
이해를 더 쉽게 하기 위해 은행 거래를 수행하는 애플리케이션이 있다고 가정해 보겠습니다. 거래가 완료되기 전에 계정에 신용 한도가 있는지, 데이터베이스에 충돌을 일으키는 정보 중복이 있는지, 전송된 정보가 올바른지 등 일부 정보를 검증해야 합니다. 논리 및 비즈니스 규칙에 적용됩니다.
애플리케이션 뒤에 있는 이 모든 논리는 소프트웨어 내의 서비스 계층에 위임되며, 이것이 전송된 데이터가 예상한 것과 일치하는지 여부를 알려줍니다.
이 레이어는 데이터베이스와 나머지 애플리케이션을 중재하는 역할을 담당합니다. 사용자가 제공한 데이터를 데이터베이스에 저장하는 것입니다. 즉, CRUD(생성, 읽기, 업데이트 및 삭제)의 복잡성은 데이터베이스에 액세스하고 전송된 정보가 조작되는 Repository 계층에 숨겨져 있습니다.
데이터베이스 액세스 로직을 분리하면 코드가 더 깔끔하고 이해하기 쉬워집니다.
컨트롤러는 사용자 요청을 처리하고 이에 대한 응답을 보냅니다. 따라서 입력(일반적으로 웹을 통해 HTTP)을 수신하고 서비스를 검증 및 호출하여 비즈니스 로직을 처리한 다음 사용자에게 응답을 반환합니다.
즉, 이 데이터를 서비스에 전달하기 전에 사용자가 전달한 데이터(예: 필수 필드, 데이터 유형 또는 형식, ID 유효성 검사)의 유효성을 검사한 다음 비즈니스 로직의 유효성을 검사합니다. 그 후 컨트롤러는 요청의 성공 여부를 알리는 응답을 사용자에게 보냅니다.
사용자가 HTTP 요청을 하면 컨트롤러가 이를 수신하고 사전 검증을 수행합니다. 모두 맞다면 서비스로 보내주세요.
서비스는 애플리케이션의 논리에 따라 정보를 수집하고 유효성을 검사합니다. 모든 것이 정상이면 요청을 저장소로 보냅니다.
저장소는 컨트롤러에 전송된 요청에 따라 이 데이터를 저장, 업데이트 또는 삭제합니다.
컨트롤러는 최종 응답을 받아 사용자에게 전송하여 작업의 성공 또는 오류를 알립니다.
각 계층마다 고유한 책임이 있다는 점을 확인했으며 이로 인해 코드 유지 관리가 더 쉬워졌습니다.
서비스: 비즈니스 로직, 프로세스 검증
저장소: 데이터베이스의 CRUD를 담당
컨트롤러: API를 통해 요청을 수신하고 사용자에게 최종 메시지를 알리는 역할을 담당합니다.
위 내용은 서비스, 저장소 및 컨트롤러 이해, PT. 1의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!