2014-03-26 2 views
0

누가 함수를 호출했는지 확인하려면 debug_backtrace 이외의 다른 방법입니까? 나는 모듈러 시스템에서 일하고 있는데, 어떤 모듈이 특정 함수/변수에 접근 할 수 있는지를 '핵심'함수 세트에서 제어 할 수 있습니다. debug_backtrace은 나를 위해 완벽하게 작동하지만 생산에 사용하고 싶지는 않습니다.PHP에서 누가 함수를 호출했는지 확인하는 방법은 무엇입니까?

+1

디버깅을 위해'debug_backtrace'가 생성됩니다. 다른 객체와 클래스에 어떻게 접근 할 수 있는지 알려주도록 설계된'private','protected','public'을 사용해야합니다. – barell

+0

@barell 나는'private','protected' 및'public'을 사용하는 방법을 알고 있지만, 어떤 모듈이 함수를 호출하는지 확인할 수 있도록 허용하거나 거부 할 수 있습니까? – Thomas

답변

0

대신 객체 지향 (OO) 접근 방식을 사용하십시오.

이 경우 debug_backtrace을 사용하면 디버깅에 문제가 있습니다.

기능을 제한하려면 OO를 사용해야합니다.

예를 들어, 일부 모듈이 Customer, ProductUser 인 경우 각각 다른 클래스를 확장 할 수 있습니다.

class Customer extends Admin_Module 

class Product extends Public_Module 

class User extends Registered_User_Module 

또한 자식 클래스 또는 다른 완전히 다른 클래스의 액세스를 중지 public, privateprotected 문을 사용할 수 있습니다.

+0

이게 전혀 도움이 안된다 ;-(OO를 사용하고 있지만'$ core-> getPassword()'에 접근하기위한'modules/customer/*. php' 액세스를 거부하는 법을 모르겠습니다. debug_backtrace' 나는'debug_backtrace (DEBUG_BACKTRACE_IGNORE_ARGS, 1) [0] [ 'file']'과 job done을 확인해 볼 것입니다! 동일한 기능을 수행하는 '올바른'방법을 찾고 있습니다. – Thomas

+0

접근 방식이 잘못되었습니다. 뒤로 물러나 올바른 접근 방식을 취하면 도움이 될 것입니다. –

+0

클래스를 확장하면 누가 주요 클래스에 액세스 할 수 있는지 제어 할 수 없습니다.이 방법은 모든 모듈이 핵심 모듈을 확장하여 보거나 보이지 않게 할 수 있습니다. 핵심 기능 정의. 내가 원하는 건 예를 들어,/modules/system /에있는 모든 모듈은/modules/custom/core에서 몇 가지 기능에 액세스 할 수 있습니다. – Thomas

관련 문제