Web2py-서비스

web2py는 XML, JSON, RSS, CSV, XMLRPC, JSONRPC, AMFRPC 및 SOAP와 같은 다양한 프로토콜을 지원합니다. 각 프로토콜은 여러 가지 방법으로 지원되며 다음과 같이 구분합니다.

  • 주어진 형식으로 함수의 출력을 렌더링합니다.
  • 원격 프로 시저 호출.

사전 렌더링

세션 수를 유지하는 다음 코드를 고려하십시오.

def count():
   session.counter = (session.counter or 0) + 1
   return dict(counter = session.counter, now = request.now)

위의 기능은 사용자가 페이지를 방문 할 때와 횟수를 증가시킵니다. 주어진 함수가 다음에 정의되어 있다고 가정합니다.“default.py”web2py 애플리케이션의 컨트롤러입니다. 페이지는 다음 URL로 요청할 수 있습니다-http://127.0.0.1:8000/app/default/count

web2py는 위의 페이지를 다른 프로토콜로 렌더링하고 다음과 같이 URL에 확장자를 추가하여 렌더링 할 수 있습니다.

http://127.0.0.1:8000/app/default/count.html

http://127.0.0.1:8000/app/default/count.xml

http://127.0.0.1:8000/app/default/count.json

위의 작업에서 반환 된 사전은 HTML, XML 및 JSON으로 렌더링됩니다.

원격 프로 시저 호출

web2py 프레임 워크는 함수를 웹 서비스로 변환하는 메커니즘을 제공합니다. 여기에 설명 된 메커니즘은 이전에 설명 된 메커니즘과 다릅니다.

  • 함수에 인수 포함.
  • 함수는 모델에서 정의되어야합니다.
  • 보다 엄격한 URL 명명 규칙을 적용합니다.
  • 고정 된 프로토콜 세트에서 작동하며 쉽게 확장 할 수 있습니다.
  • 이 기능을 사용하려면 서비스 개체를 가져 와서 시작해야합니다.

이 메커니즘을 구현하려면 먼저 서비스 개체를 가져 와서 인스턴스화해야합니다.

from gluon.tools import Service
service = Service()

이것은 "db.py" 스캐 폴딩 애플리케이션의 모델 파일. Db.py model은 web2py 프레임 워크의 기본 모델로, 데이터베이스 및 컨트롤러와 상호 작용하여 사용자에게 원하는 출력을 제공합니다.

구현 후 모델의 서비스는 필요할 때 컨트롤러에서 액세스 할 수 있습니다.

다음 예제는 웹 서비스 등을 사용하는 원격 프로 시저 호출의 다양한 구현을 보여줍니다.

웹 서비스

웹 서비스는 XML, SOAP, WSDL 및 UDDI와 같은 프로토콜을 사용하여 웹 기반 응용 프로그램을 통합하는 표준화 된 방법으로 정의 할 수 있습니다.

web2py는 대부분을 지원하지만 통합은 매우 까다로울 것입니다.

jQuery로 web2py JSON 서비스 사용

web2py 형식으로 JSON을 반환하는 방법은 여러 가지가 있지만 여기서는 JSON 서비스의 경우를 고려합니다. 예를 들면-

def consumer():return dict()@service.json
def get_days():return ["Sun", "Mon", "Tues", "Wed", "Thurs", "Fri", "Sat"]
def call():return service()

여기서 우리는 관찰합니다-

  • 이 함수는 서비스를 사용하는 뷰를 렌더링하기 위해 빈 사전을 반환합니다.

  • get_days 서비스를 정의하고 함수 호출은 등록 된 모든 서비스를 노출합니다.

  • get_days 컨트롤러에있을 필요가 없으며 모델에있을 수 있습니다.

  • call 항상 default.py 스캐 폴딩 컨트롤러에 있습니다.

소비자 행동으로보기는 다음과 같습니다-

{{extend 'layout.html'}}
<div id = "target"></div>

<script>
   jQuery.getJSON("{{= URL('call',args = ['json','get_days'])}}",
      function(msg){
         jQuery.each(msg, function(){ jQuery("#target").
         append(this + "<br />"); } )
      }
   );
</script>

의 첫 번째 인수 jQuery.getJSON 다음 서비스의 URL입니다. http://127.0.0.1:8000/app/default/call/json/get_days

이것은 항상 패턴을 따릅니다.

http://<domain>/<app>/<controller>/call/<type>/<service>

URL이 사이에 있습니다. {{...}}, 다른 모든 것은 클라이언트 측에서 실행되는 동안 서버 측에서 해결되기 때문입니다. 두 번째 인수jQuery.getJSON JSON 응답이 전달되는 콜백입니다.

이 경우 콜백은 응답의 각 항목 (문자열로 된 요일 목록)을 반복하고 각 문자열을 추가 한 다음 <br/> ~로 <div id = "target">.

이런 식으로 web2py는 다음을 사용하여 웹 서비스 구현을 관리합니다. jQuery.getJSON.