> 백엔드 개발 > 파이썬 튜토리얼 > Python 로그인에 대한 자세한 소개(예제 포함)

Python 로그인에 대한 자세한 소개(예제 포함)

不言
풀어 주다: 2019-01-17 11:20:27
앞으로
2695명이 탐색했습니다.

이 글은 Python 로그인에 대한 자세한 소개를 제공합니다(예제 포함). 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

소개

인터넷 로그인에는 기본적인 사용법이 많이 있으므로 여기서는 소개하지 않겠습니다. 본문을 소개하기 전에 먼저 요구 사항을 살펴보겠습니다.

다른 사람이 사용할 수 있도록 특정 기능을 클래스 라이브러리에 캡슐화해야 한다고 가정해 보겠습니다. 클래스 라이브러리의 로그를 처리하는 방법은 무엇입니까?

몇 년 전 어느 날 C#으로 개발된 프로젝트에서는 로깅 기본 클래스를 정의하는 방법을 사용했습니다. 로깅을 사용해야 하는 모든 클래스는 이 기본 클래스에서 상속합니다. 특정 로깅 작업을 구현하는 데 사용되는 LogHandler 이벤트는 동시에 A 클래스의 LogHandler 대리자를 클래스 B의 대리자에 연결할 수 있습니다. LogHandler에는 두 클래스의 로그 정보가 함께 추가됩니다.

파이썬에서 로그인 구현을 살펴보니 내 접근 방식이 정말 취약하다는 것을 알았습니다.

이전 블로그 Python에서 peewee 프레임워크의 로그 출력을 소개했습니다.logging.NullHandler의 사용 간단히 말하면 peewee라는 로거가 peewee에 정의되고 호출자는 NullHandler를 추가하기만 하면 됩니다. 특정 핸들러는 로그를 출력할 수 있어 매우 편리합니다.


주 프로그램에도 Logger가 있다고 가정해 보겠습니다. peewee를 호출한 후 두 로그를 동일한 로그 파일에 출력하고 싶습니다. 동시에 파일을 선점할 위험이 있으므로 두 로그의 FileHandler가 동일한 로그 파일을 가리키도록 하는 것은 바람직하지 않습니다. 물론 메인 프로그램에서 Logger의 이름을 peewee로 지정할 수도 있지만 이는 너무 낮을 뿐만 아니라 Logger를 캡슐화하는 다른 라이브러리를 호출하는 경우 처리하기 어려울 것입니다.

나무 그루터기 구조의 Logger

Logger 객체는 트리 구조로 설계되었으며 상위 속성을 갖습니다. root라는 Logger는 로깅에서 모든 Logger의 루트 노드로 정의되며 루트의 상위 속성은 None입니다. 루트는 전역적입니다.

Logger 개체를 가져오기 위해

logging.getLogger(name=None)
로그인 후 복사

를 호출할 때 이름이 None이면 루트 노드 루트가 반환됩니다. 이름에 .가 포함되어 있으면(예: name = 'a.b') a라는 Logger가 이미 있으면 a.b는 a의 하위 노드입니다. a라는 Logger가 없으면 a.b는 루트의 하위 노드입니다. .노드.

하위 로거가 로그 메시지 처리를 완료한 후 기본적으로 로그 메시지를 상위 로거에 전달합니다. 따라서 애플리케이션에서 사용되는 모든 로거에 대한 핸들러를 정의하고 구성할 필요가 없습니다. 최상위 로거에 대한 핸들러를 구성한 다음 필요에 따라 하위 로거를 생성하는 것으로 충분합니다. Logger의 전파 속성을 False로 설정하여 이 전달 메커니즘을 끌 수 있습니다.

무슨 뜻인가요? 코드를 살펴보겠습니다.

import logging
logA = logging.getLogger('a')
logA.setLevel(logging.DEBUG)
logA.addHandler(logging.StreamHandler())
logB = logging.getLogger('a.b')
logB.addHandler(logging.StreamHandler())
로그인 후 복사

출력 결과:

Logger A
Logger B
Logger B
로그인 후 복사

Logger B가 두 번 출력되는 이유는 logB가 logA의 하위 노드이고 Handler도 logB에 정의되어 있기 때문입니다. 핸들러는 한 번만 출력하고, logA의 핸들러도 한 번, 두 번만 출력합니다. 한번만 출력하고 싶다면 logB에서 Handler를 삭제하면 됩니다. 물론 이는 특히 로그 관리 도구가 없는 경우 유용할 수 있습니다. 예를 들어, 프로그램의 전반적인 실행 순서를 이해하려면 메인 프로그램의 모든 로그를 출력해야 하지만, 특정 모듈의 경우 별도의 로그를 출력하여 오류 보고나 실행 순서를 명확하게 이해할 수 있도록 하려는 경우입니다. 기준 치수.

이전 peewee 예제는 peewee 로그의 상위 속성을 기본 프로그램의 로그로 설정하기만 하면 됩니다.

결론

사실 이 문제는 설명하기가 비교적 쉬운 문제이고, 그렇게 많이 쓸 필요는 없습니다. Python에서 로깅을 사용하는 방법을 여러분과 공유하고 싶지는 않지만 로깅이 어떻게 구현되는지에 대한 아이디어를 여러분과 공유하고 싶습니다. 왜냐하면 저는 이 문제에 직면하고 솔루션을 설계한 후 완전히 망가졌기 때문입니다. 떨어져 있는.

위 내용은 Python 로그인에 대한 자세한 소개(예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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