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.