Web2py-퀵 가이드
web2py데이터베이스 기반 웹 애플리케이션을 포함하는 애자일 개발을위한 무료 오픈 소스 웹 프레임 워크로 정의됩니다. Python으로 작성되고 Python으로 프로그래밍 할 수 있습니다. 풀 스택 프레임 워크입니다. 필요한 모든 구성 요소로 구성되며 개발자는 완전한 기능의 웹 애플리케이션을 구축해야합니다.
web2py 프레임 워크는 Model-View-Controller 전통적인 패턴과 달리 웹 애플리케이션을 실행하는 패턴.
Model데이터에 대한 논리를 포함하는 응용 프로그램의 일부입니다. 모델의 개체는 데이터베이스에서 데이터를 검색하고 저장하는 데 사용됩니다.
View최종 사용자에게 데이터 표시를 렌더링하는 데 도움이되는 응용 프로그램의 일부입니다. 데이터 표시는 모델에서 가져옵니다.
Controller사용자 상호 작용을 처리하는 응용 프로그램의 일부입니다. 컨트롤러는 뷰에서 데이터를 읽고, 사용자 입력을 제어하고, 입력 데이터를 특정 모델로 보낼 수 있습니다.
web2py쿠키 및 세션을 관리하는 내장 기능이 있습니다. 트랜잭션을 커밋 한 후 (SQL 측면에서) 세션도 동시에 저장됩니다.
web2py특정 작업이 완료된 후 예약 된 간격으로 작업을 실행할 수 있습니다. 이것은CRON.
web2py – 워크 플로
아래 주어진 워크 플로우 다이어그램을 살펴보십시오.
워크 플로 다이어그램은 아래에 설명되어 있습니다.
그만큼 Models, Views 과 Controller 구성 요소는 사용자 web2py 응용 프로그램을 구성합니다.
web2py의 동일한 인스턴스에서 여러 애플리케이션을 호스팅 할 수 있습니다.
브라우저는 HTTP 요청을 서버에 보내고 서버는 Model, Controller 과 View 필요한 출력을 가져옵니다.
화살표는 데이터베이스 엔진과의 통신을 나타냅니다. 데이터베이스 쿼리는 원시 SQL로 작성하거나 web2py 데이터베이스 추상화 계층 (추가 장에서 설명)을 사용하여 작성할 수 있습니다.web2py 응용 프로그램 코드는 모든 데이터베이스 엔진과 독립적입니다.
Model 데이터베이스와의 데이터베이스 연결을 설정하고 Controller. 그만큼Controller 반면에 View 데이터 표시를 렌더링합니다.
그만큼 DispatcherHTTP 응답에 제공된대로 요청 된 URL을 컨트롤러의 함수 호출에 매핑합니다. 함수의 출력은 문자열 또는 해시 테이블 일 수 있습니다.
데이터는 View. 사용자가 HTML 페이지 (기본값)를 요청하면 데이터가 HTML 페이지로 렌더링됩니다. 사용자가 XML로 동일한 페이지를 요청하면 web2py는 사전을 XML로 렌더링 할 수있는 뷰를 찾으려고합니다.
web2py의 지원되는 프로토콜에는 HTML, XML, JSON, RSS, CSV 및 RTF가 포함됩니다.
모델-뷰-컨트롤러
그만큼 model-view-controller web2py의 표현은 다음과 같습니다.
모델
"db.py" is the model:
db = DAL('sqlite://storage.sqlite')
db.define_table(employee, Field('name'), Field(‘phone’))
그만큼 Model응용 프로그램 데이터의 논리를 포함합니다. 위의 그림과 같이 데이터베이스에 연결됩니다. SQLite가 사용되고 있으며storage.sqliteemployee로 정의 된 테이블이있는 파일. 테이블이 존재하지 않는 경우 web2py는 해당 테이블을 생성하여 도움을줍니다.
제어 장치
프로그램 "default.py" 이다 Controller.
def employees():
grid = SQLFORM.grid(db.contact, user_signature = False)
return locals()
에 web2py, URL 매핑은 기능 및 모듈에 액세스하는 데 도움이됩니다. 위의 예에서 컨트롤러에는 직원이라는 단일 기능 (또는 "작업")이 포함되어 있습니다.
취한 조치 Controller 로컬 변수 세트를 포함하여 키와 값의 조합 인 문자열 또는 Python 사전을 반환합니다.
전망
"default/contacts.html" 이다 View.
{{extend 'layout.html'}}
<h1>Manage My Employees</h1>
{{=grid}}
주어진 예에서 View 연관된 컨트롤러 기능이 실행 된 후 출력을 표시합니다.
이것의 목적 ViewHTML 형식으로 된 사전에 변수를 렌더링하는 것입니다. 그만큼View 파일은 HTML로 작성되지만 다음의 도움으로 Python 코드를 포함합니다. {{ and }} 구분자.
HTML에 포함 된 코드는 사전에있는 Python 코드로 구성됩니다.
web2py로 시작
web2py Windows, UNIX 및 Mac OS X와 같은 모든 주요 운영 체제 용 바이너리 패키지로 제공됩니다.
web2py를 설치하는 것은 쉽습니다.
Python 인터프리터로 구성되어 있으므로 미리 설치할 필요가 없습니다. 모든 운영 체제에서 실행되는 소스 코드 버전도 있습니다.
다음 링크는 바이너리 패키지로 구성됩니다. web2py사용자의 필요에 따라 다운로드 -www.web2py.com
그만큼 web2py프레임 워크는 다른 프레임 워크와 달리 사전 설치가 필요하지 않습니다. 사용자는 운영 체제 요구 사항에 따라 zip 파일을 다운로드하고 압축을 풀어야합니다.
그만큼 web2py 프레임 워크는 컴파일이나 복잡한 설치가 필요없는 완전한 동적 언어 인 Python으로 작성되었습니다.
Java 또는 .net과 같은 다른 프로그래밍 언어와 같은 가상 머신을 사용하며 개발자가 작성한 소스 코드를 투명하게 바이트 컴파일 할 수 있습니다.
운영 체제 | 명령 |
---|---|
Unix 및 Linux (소스 배포) | 파이썬 web2py.py |
OS X (바이너리 배포) | web2py.app 열기 |
Windows (바이너리 web2py 배포) | web2py.exe |
Windows (소스 web2py 배포) | c : /Python27/python.exe web2py.py |
Python은 객체 지향 언어와 대화 형 언어의 조합으로 정의 할 수 있습니다. 오픈 소스 소프트웨어입니다. Guido van Rossum은 1980 년대 후반에 파이썬을 잉태했습니다.
Python은 명확한 구문과 가독성으로 인해 인기를 얻고있는 PERL (Practical Extraction and Reporting Language)과 유사한 언어입니다.
Python의 주요 특징은 다음과 같습니다.
파이썬은 상대적으로 배우기 쉽고 이식하기 쉽다고합니다. UNIX 기반 시스템을 포함한 여러 운영 체제에서 쉽게 해석 할 수 있습니다.Mac OS, MS-DOS, OS/2및 다양한 버전의 Windows.
Python은 모든 주요 운영 체제에서 이식 가능합니다. 이해하기 쉬운 구문을 사용하여 사용자 친화적 인 프로그램을 만듭니다.
많은 작업을 지원하는 대형 표준 라이브러리가 함께 제공됩니다.
위의 다이어그램에서 Python이 스크립팅과 프로그래밍 언어의 조합임을 분명히 알 수 있습니다. 스크립트 언어와 같은 다른 프로그램 내에서 해석됩니다.
Python 버전
Python에는 CPython, Jython 및 IronPython이라고하는 세 가지 프로덕션 품질 구현이 있습니다. 이들은 또한 Python 버전이라고도합니다.
Classic Python 일명 CPython 컴파일러, 인터프리터이며 표준 C 언어로 구현되는 내장 및 선택적 확장 모듈로 구성됩니다.
Jython Java Virtual Machine (JVM)을위한 Python 구현입니다.
IronPythonCLR (공용 언어 런타임)을 포함하는 Microsoft에서 설계했습니다. 일반적으로 .NET으로 알려져 있습니다.
시작
모든 운영 체제의 기본 Python 프로그램은 헤더로 시작합니다. 프로그램은.py 확장 및 Python 명령은 프로그램 실행에 사용됩니다.
예를 들면 python_rstprogram.py필요한 출력을 제공합니다. 또한 존재하는 경우 오류를 생성합니다.
Python은 들여 쓰기를 사용하여 코드 블록을 구분합니다. 블록은 콜론으로 끝나는 줄로 시작하여 다음 줄과 비슷하거나 더 높은 들여 쓰기가있는 유사한 방식의 모든 줄에 대해 계속됩니다.
# Basic program in Python
print "Welcome to Python!\n"
프로그램의 출력은-
Welcome to Python!
들여 쓰기
프로그램의 들여 쓰기는 Python에서 매우 중요합니다. Python 초보자 인 개발자를위한 Python의 들여 쓰기 규칙에 대한 몇 가지 편견과 신화가 있습니다.
모든 프로그래머를위한 규칙은 다음과 같습니다.
"공백은 Python 소스 코드에서 중요합니다."
Python의 논리 줄 시작 부분에 공백과 탭을 포함하는 선행 공백은 줄의 들여 쓰기 수준을 계산합니다.
노트
들여 쓰기 수준에 따라 문의 그룹화도 결정됩니다.
각 들여 쓰기 수준에 대해 탭과 같이 4 개의 공백을 사용하는 것이 일반적입니다.
탭을 공백과 혼합하지 않는 것이 좋은 정책입니다. 이는 보이지 않는 혼란을 초래할 수 있습니다.
파이썬은 들여 쓰기가 부족한 경우에도 컴파일 시간 오류를 생성합니다.
IndentationError: expected an indented block
제어 흐름 문
Python 프로그램의 제어 흐름은 조건문, 루프 및 함수 호출에 의해 규제됩니다.
그만큼 If 명령문은 else 및 elif (else-if의 조합)와 함께 지정된 조건에서 코드 블록을 실행합니다.
그만큼 For 문은 객체를 반복하여 각 요소를 연결된 블록에서 사용할 수 있도록 지역 변수로 캡처합니다.
그만큼 While 문은 조건 하에서 코드 블록을 실행합니다. True.
그만큼 With문은 컨텍스트 관리자 내에 코드 블록을 포함합니다. 더 읽기 쉬운 대안으로 추가되었습니다.try/finally 성명서.
# If statement in Python
x = int(raw_input("Please enter an integer: ")) #Taking input from the user
if x<0:
print "1 - Got a negative expression value"
print x
else:
print "1 - Got a positive expression value"
print x
print "Good bye!"
산출
sh-4.3$ python main.py
Please enter an integer: 4
1 - Got a positive expression value
4
Good bye!
기능
일반적인 Python 프로그램의 명령문은 다음과 같은 특정 형식으로 구성되고 그룹화됩니다. “Functions". 함수는 요청에 따라 작업을 수행하는 문 그룹입니다. 파이썬은 많은 내장 함수를 제공하고 프로그래머가 자신의 함수를 정의 할 수 있도록합니다.
Python에서 함수는 프로그래밍 언어의 다른 객체처럼 처리되는 값입니다.
그만큼 def 문은 함수를 정의하는 가장 일반적인 방법입니다. def 다음 구문을 사용하는 단일 절 복합 명령문입니다.
def function-name (parameters):statement(s)
다음 예제는 생성기 함수를 보여줍니다. 비슷한 방식으로 객체를 생성하는 반복 가능한 객체로 사용할 수 있습니다.
def demo ():
for i in range(5):
yield (i*i)
for j in demo():
print j
산출
sh-4.3$ python main.py
0
1
4
9
16
특수 속성, 방법 및 연산자
클래스의 이중 밑줄로 시작하는 속성, 메서드 및 연산자는 일반적으로 비공개 동작입니다. 그들 중 일부는 특별한 의미를 포함하는 예약 된 키워드입니다.
그 중 세 가지가 아래에 나열되어 있습니다.
__len__
__getitem__
__setitem__
다른 특수 연산자에는 __getattr__ 및 __setattr__이 포함됩니다. get 과 set 클래스의 속성.
파일 I / O 기능
Python에는 특정 파일을 열고 닫는 기능이 있습니다. 이것은 다음의 도움으로 달성 될 수 있습니다.open(), write() 과 close() 기능.
파일 입력 및 출력에 도움이되는 명령은 다음과 같습니다.
Sr. 아니요 | 명령 및 기능 |
---|---|
1 | open() 파일이나 문서를 여는 데 도움이됩니다. |
2 | write() 파일이나 문서에 문자열을 쓰는 데 도움이됩니다. |
삼 | read() 기존 파일의 내용을 읽는 데 도움이됩니다. |
4 | close() 이 메서드는 파일 개체를 닫습니다. |
예
다음과 같은 파일을 고려하십시오. “demo.txt”, "This is a demo file"이라는 텍스트가 이미 존재합니다.
#!/usr/bin/python
# Open a file
fo = open("demo.txt", "wb")
fo.write( "Insering new line \n");
# Close opend file
fo.close()
파일을 연 후 사용할 수있는 문자열은 다음과 같습니다.
This is a demo file
Inserting a new line
web2py는 개발자가 웹 애플리케이션을 완전히 개발하는 데 사용할 수있는 풀 스택 웹 프레임 워크입니다. 여기에는 프로그램 설계를위한 SQL 데이터베이스 통합 및 다중 스레드 웹 서버가 포함됩니다.
사용자 프로그램 설계를위한 웹 인터페이스
명령이 운영 체제에 따라 실행되면 web2py는 시작 창을 표시 한 다음 사용자에게 선택을 요청하는 GUI 위젯을 표시합니다.
- 일회성 관리자 암호,
- 웹 서버에 사용할 네트워크 인터페이스의 IP 주소,
- 및 요청을 처리 할 포트 번호.
관리자는 새 웹 응용 프로그램을 추가하고 편집 할 수있는 모든 권한을 포함합니다.
기본적으로 web2py는 웹 서버를 127.0.0.1:8000 (localhost의 포트 8000) 그러나 사용자는 요구 사항에 따라 사용 가능한 모든 IP 주소 및 포트에서 실행할 수 있습니다.
web2py GUI 위젯은 아래와 같이 표시됩니다.
암호는 새 모듈의 변경 사항에 대해 관리 인터페이스에서 사용됩니다.
사용자가 관리 비밀번호를 설정하면 web2py는 다음 URL로 페이지에서 웹 브라우저를 시작합니다. http://127.0.0.1:8000/
프레임 워크의 시작 페이지가 아래와 같이 표시됩니다.
web2py에서 기본 프로그램 설계
web2py 응용 프로그램을 시작한 후 위에서 언급 한 URL로 관리 인터페이스를 사용하여 새 모듈을 만들 수 있습니다. 예를 들면 다음과 같습니다. “helloWorld”.
관리자는 새 웹 응용 프로그램을 추가하고 편집 할 수있는 모든 권한을 보유하고 있으므로 관리 인터페이스는 인증 목적으로 암호를 요청합니다.
위에 제공된 스냅 샷에는 설치된 모든 web2py 애플리케이션을 나열하고 관리자가 관리 할 수있는 페이지 세부 정보가 포함되어 있습니다. 기본적으로 web2py 프레임 워크는 세 가지 애플리케이션과 함께 제공됩니다. 그들은-
안 admin 사용자가 현재 구현하고있는 애플리케이션입니다.
안 examples 온라인 대화 형 문서와 web2py 공식 웹 사이트의 인스턴스가있는 응용 프로그램입니다.
ㅏ welcome신청. 다른 web2py 애플리케이션에 대한 기본 템플릿이 포함되어 있습니다. 또한scaffolding application. 또한 응용 프로그램은 시작시 사용자를 환영합니다.
새 응용 프로그램의 이름을 “helloWorld”.
새 애플리케이션이 생성되면 사용자는 해당 애플리케이션의보기, 모델 및 컨트롤러로 구성된 페이지로 리디렉션됩니다.
사용자는 다음 URL을 언급하여 새로 생성 된 애플리케이션을 볼 수 있습니다. http://127.0.0.1:8000/helloWorld
기본적으로 사용자는 위에서 언급 한 URL을 입력하면 다음 화면을 볼 수 있습니다.
주어진 웹 애플리케이션의 메시지를 인쇄하기 위해 “helloWorld”, 변경은 default.py 제어 장치.
이름이 지정된 함수 “index”값을 반환하고 필요한 출력을 표시하는 기본 함수입니다. 위에서 언급했듯이 문자열“Hello World- Welcome to my first web application” 화면에 출력을 표시하는 반환 값으로 사용됩니다.
출력은 다음과 같이 표시됩니다.
포스트 백
양식 입력의 유효성을 검사하는 메커니즘은 매우 일반적이며 좋은 프로그래밍 관행으로 간주되지 않습니다. 입력은 매번 검증되므로 검증에 부담이됩니다.
web2py의 더 나은 패턴은 양식을 생성하는 동일한 작업에 양식을 제출하는 것입니다. 이 메커니즘을“postback”web2py의 주요 기능입니다. 요컨대, 자체 제출은postback.
def first():
if request.vars.visitor_name: #if visitor name exists
session.visitor_name = request.vars.visitor_name
redirect(URL('second'))#postback is implemented
return dict()
CRUD 애플리케이션
web2py에는 생성, 검색, 업데이트 및 삭제 기능을 수행하는 애플리케이션이 포함되어 있습니다. 그만큼CRUD 주기는 영구적 인 데이터베이스의 기본 기능을 설명합니다.
모든 애플리케이션 로직은 컨트롤러에 의해 검색되고보기를 통해 사용자에게 표시되는 모델에 작성됩니다.
appadmin
PHP의 경우 응용 프로그램 서버에는 아래의 모든 데이터베이스 목록이 포함됩니다. phpmyadmin. 유사한 방식으로 web2py는 테이블 또는 데이터베이스를 관리, 생성 및 삭제하기위한 인터페이스를 제공합니다.“appadmin.”
테이블 뒤의 논리를 구현하기 전에 데이터베이스 및 관련 테이블을 만들어야합니다.
액세스 할 URL appadmin −
http://127.0.0.1:8000/applicationname/appadmin
URL을 입력하면 사용자는 주어진 응용 프로그램과 관련된 테이블 목록을 얻게됩니다.
이 인터페이스는 공개용이 아닙니다. 데이터베이스에 쉽게 액세스 할 수 있도록 설계되었습니다. 그것은 두 개의 파일로 구성됩니다-컨트롤러“appadmin.py” 및보기 “appadmin.html”.
한 번에 최대 100 개의 레코드에 페이지를 매길 수 있습니다. 사용법“appadmin” 다음 장에서 설명합니다.
명령 줄 옵션
이전 장에서 GUI 위젯을 사용하여 web2py 서버를 시작하는 방법을 배웠습니다.
이 위젯은 서버를 시작하여 건너 뛸 수 있습니다. command line 신속한.
python web2py.py -a '비밀번호'-i 127.0.0.1 -p 8000
web2py 서버가 시작될 때마다 "parameters_8000.py"여기서 모든 암호는 해시 된 형식으로 저장됩니다.
추가 보안 목적으로 다음 명령 줄을 사용할 수 있습니다.
python web2py.py -a '<recycle>' -i 127.0.0.1 -p 8000
위의 시나리오에서 web2py는 "에 저장된 해시 된 비밀번호를 재사용합니다.parameters_8000.py".
이 경우 파일 "parameters_8000.py"가 실수로 삭제되거나 다른 이유로 인해 web2py에서 웹 기반 관리 인터페이스가 비활성화됩니다.
URL 매핑 / 파견
web2py의 기능은 URL을 특정 형식으로 매핑하는 model-view-controller를 기반으로합니다. http://127.0.0.1:8000/a/d/f.html
기능까지 라우팅됩니다. “f()” 컨트롤러에서 언급 d.py"a"라는 응용 프로그램 아래에 있습니다. 컨트롤러가 애플리케이션에 없으면 web2py는 이름이 지정된 기본 컨트롤러를 사용합니다.“default.py”.
URL에 지정된 함수가 없으면 기본 함수가 호출됩니다. init()사용. URL의 작동은 아래 이미지에 개략적으로 표시됩니다.
확장 .htmlURL의 경우 선택 사항입니다. 확장은 확장을 결정합니다.View컨트롤러에 정의 된 함수의 출력을 렌더링합니다. 동일한 콘텐츠가 html, xml, json, rss 등 여러 형식으로 제공됩니다.
인수를 받아들이고 사용자에게 적절한 출력을 제공하는 함수를 기반으로 요청이 전달됩니다. 사용자의 필요에 따라 출력을 제공하기 위해 애플리케이션의 모델 및 뷰와 상호 작용하는 컨트롤러입니다.
web2py – 워크 플로
web2py의 워크 플로는 아래에서 설명합니다.
웹 서버는 각각의 모든 HTTP 요청을 자체 스레드에서 동시에 관리합니다.
HTTP 요청 헤더가 구문 분석되어 디스패처에 전달됩니다.
Dispatcher는 애플리케이션 요청을 관리하고 PATH_INFO함수 호출의 URL에서. 모든 함수 호출은 URL에 표시됩니다.
정적 폴더에 포함 된 파일에 대한 모든 요청은 직접 관리되며 대용량 파일은 클라이언트로 스트리밍됩니다.
정적 파일을 제외한 모든 요청은 작업에 매핑됩니다.
요청 헤더에 앱에 대한 세션 쿠키가 포함되어 있으면 세션 개체가 검색됩니다. 그렇지 않으면 세션 ID가 생성됩니다.
작업이 값을 문자열로 반환하면 클라이언트에 반환됩니다.
작업이 반복 가능 항목을 반환하는 경우 데이터를 반복하고 클라이언트로 스트리밍하는 데 사용됩니다.
조건부 모델
이전 장에서 우리는 Controllers. web2py는 각 애플리케이션에서 모델,보기 및 컨트롤러를 사용합니다. 따라서 기능을 이해하는 것도 필요합니다.Model.
다른 MVC 응용 프로그램과 달리 web2py의 모델은 조건부로 처리됩니다. 컨트롤러의 사용량에 따라 하위 폴더의 모델이 실행됩니다. 이것은 다음 예를 통해 설명 할 수 있습니다.
URL을 고려하십시오- http://127.0.0.1:8000/a/d/f.html
이 경우 ‘a’ 응용 프로그램의 이름입니다. ‘d’ 컨트롤러의 이름이고 f()컨트롤러와 관련된 기능입니다. 실행될 모델 목록은 다음과 같습니다.
applications/a/models/*.py
applications/a/models/d/*.py
applications/a/models/d/f/*.py
도서관
web2py에는 모든 애플리케이션에 객체로 노출되는 라이브러리가 포함되어 있습니다. 이러한 개체는 "gluon"이라는 디렉터리 아래의 코어 파일 내에 정의됩니다.
DAL 템플릿과 같은 많은 모듈은 종속성이 없으며 web2py의 프레임 워크 외부에서 구현할 수 있습니다. 또한 우수 사례로 간주되는 단위 테스트를 유지합니다.
응용
web2py 애플리케이션은 아래에 다이어그램 형식으로 표시됩니다.
그만큼 Applications web2py에서 개발 한 부분은 다음과 같습니다.
Models − 데이터 및 데이터베이스 테이블을 나타냅니다.
Controllers − 애플리케이션 로직 및 워크 플로우를 설명합니다.
Views − 데이터 표시 렌더링을 도와줍니다.
Languages − 애플리케이션의 문자열을 지원되는 다양한 언어로 번역하는 방법을 설명합니다.
Static files − 처리 할 필요가 없습니다 (예 : 이미지, CSS 스타일 시트 등).
ABOUT 과 README − 프로젝트 세부 사항.
Errors − 응용 프로그램에서 생성 한 오류 보고서를 저장합니다.
Sessions − 각 특정 사용자와 관련된 정보를 저장합니다.
Databases − SQLite 데이터베이스 및 추가 테이블 정보를 저장합니다.
Cache − 캐시 된 애플리케이션 항목을 저장합니다.
Modules − 모듈은 다른 선택적 Python 모듈입니다.
Private − 포함 된 파일은 컨트롤러가 액세스하지만 개발자가 직접 액세스하지 않습니다.
Uploads − 파일은 모델에 의해 액세스되지만 개발자가 직접 액세스하지 않습니다.
API
web2py에서 models, controllers 과 views 개발자를 위해 특정 개체를 가져 오는 환경에서 실행됩니다.
Global Objects − 요청, 응답, 세션, 캐시.
Helpers− web2py에는 HTML을 프로그래밍 방식으로 빌드하는 데 사용할 수있는 도우미 클래스가 포함되어 있습니다. HTML 태그에 해당하며“HTML helpers”.
예 : A, B, FIELDSET, FORM 등
세션
세션은 웹 응용 프로그램 전체에서 사용자의 상호 작용을 통해 유지되는 정보의 서버 측 저장소로 정의 할 수 있습니다.
web2py의 세션은 스토리지 클래스의 인스턴스입니다.
예를 들어, 변수는 세션에 다음과 같이 저장 될 수 있습니다.
session.myvariable = "hello"
이 값은 다음과 같이 검색 할 수 있습니다.
a = session.myvariable
동일한 사용자가 동일한 세션에서 코드를 실행하는 한 변수 값을 검색 할 수 있습니다.
web2py for session에서 중요한 방법 중 하나는 “forget” −
session.forget(response);
세션을 저장하지 않도록 web2py에 지시합니다.
백그라운드에서 작업 실행
HTTP 요청이 웹 서버에 도착하여 각 요청을 자체 스레드에서 병렬로 처리합니다. 활성 상태 인 작업은 포 그라운드에서 수행되고 나머지 작업은 백그라운드에서 유지됩니다. 백그라운드 작업 관리도 web2py의 주요 기능 중 하나입니다.
시간이 많이 걸리는 작업은 백그라운드에서 유지하는 것이 좋습니다. 백그라운드 작업을 관리하는 메커니즘 중 일부는 다음과 같이 나열됩니다.
CRON
Queues
Scheduler
CRON
web2py에서 CRON지정된 시간 간격 내에서 작업을 실행할 수있는 기능을 제공합니다. 각 애플리케이션에는 기능을 정의하는 CRON 파일이 포함되어 있습니다.
스케줄러
기본 제공 스케줄러는 우선 순위를 설정하여 백그라운드에서 작업을 실행하는 데 도움이됩니다. 작업을 생성, 예약 및 수정하기위한 메커니즘을 제공합니다.
예약 된 이벤트는 파일 이름과 함께 모델에 나열됩니다. “scheduler.py”.
애플리케이션 구축
web2py에서 모델과 컨트롤러를 만드는 방법에 대한 개요가있었습니다. 여기서는“Contacts”. 애플리케이션은 회사 목록과 해당 회사에서 일하는 사람들의 목록을 유지해야합니다.
모델 생성
여기서 데이터 사전에 대한 테이블의 식별이 모델입니다. 연락처 애플리케이션의 모델은 "models”폴더. 파일은 다음에 저장됩니다.models/db_contacts.py.
# in file: models/db_custom.py
db.define_table('company', Field('name', notnull = True, unique = True), format = '%(name)s')
db.define_table(
'contact',
Field('name', notnull = True),
Field('company', 'reference company'),
Field('picture', 'upload'),
Field('email', requires = IS_EMAIL()),
Field('phone_number', requires = IS_MATCH('[\d\-\(\) ]+')),
Field('address'),
format = '%(name)s'
)
db.define_table(
'log',
Field('body', 'text', notnull = True),
Field('posted_on', 'datetime'),
Field('contact', 'reference contact')
)
위 파일이 생성되면 URL의 도움으로 테이블에 액세스 할 수 있습니다. http://127.0.0.1:8000/contacts/appadmin
컨트롤러 생성
그만큼 Controller 연락처 나열, 편집 및 삭제를위한 일부 기능이 포함됩니다.
# in file: controllers/default.py
def index():return locals()
def companies():companies = db(db.company).select(orderby = db.company.name)
return locals()
def contacts():company = db.company(request.args(0)) or redirect(URL('companies'))
contacts = db(db.contact.company == company.id).select(orderby = db.contact.name)
return locals()
@auth.requires_login()
def company_create():form = crud.create(db.company, next = 'companies')
return locals()
@auth.requires_login()
def company_edit():company = db.company(request.args(0)) or redirect(URL('companies'))
form = crud.update(db.company, company, next='companies')
return locals()
@auth.requires_login()
def contact_create():db.contact.company.default = request.args(0)
form = crud.create(db.contact, next = 'companies')
return locals()
@auth.requires_login()
def contact_edit():contact = db.contact(request.args(0)) or redirect(URL('companies'))
form = crud.update(db.contact, contact, next = 'companies')
return locals()
def user():return dict(form = auth())
창조의 view 출력과 함께 다음 장에서 설명합니다.
web2py 프레임 워크 사용 Models, Controllers 과 Views응용 프로그램에서. 약간 수정 된 Python 구문이Views 적절한 Python 사용에 대한 제한없이 더 읽기 쉬운 코드를 위해.
web2py의 주요 목적 ViewHTML 문서에 파이썬 코드를 삽입하는 것입니다. 그러나 다음과 같은 몇 가지 문제가 있습니다.
- HTML 문서에 포함 된 파이썬 코드 이스케이프.
- HTML 규칙에 영향을 줄 수있는 Python 기반 들여 쓰기를 따릅니다.
문제를 해결하기 위해 web2py는보기 섹션에서 구분 기호 {{..}}를 사용합니다. 구분 기호는 포함 된 Python 코드를 이스케이프하는 데 도움이됩니다. 또한 HTML 들여 쓰기 규칙을 따르는 데 도움이됩니다.
안에 포함 된 코드 {{..}}구분 기호에는 의도하지 않은 Python 코드가 포함됩니다. 파이썬은 일반적으로 코드 블록을 구분하기 위해 들여 쓰기를 사용하기 때문에 구분자 내의 의도하지 않은 코드는 적절한 방식으로 유지되어야합니다. 이 문제를 극복하기 위해 web2py는“pass” 예어.
줄로 시작하는 코드 블록은 콜론으로 끝나고 pass로 시작하는 줄로 끝납니다.
Note − pass는 Python 키워드이며 web2py 키워드가 아닙니다.
다음 코드는 pass 키워드의 구현을 보여줍니다-
{{
if num > 0:
response.write('positive number')
else:
response.write('negative number')
pass
}}
HTML 도우미
web2py에는 프로그래밍 방식으로 HTML을 빌드하는 데 사용할 수있는 도우미 클래스가 포함되어 있습니다. "HTML 도우미"라고하는 HTML 태그에 해당합니다.
예를 들면-
[(A('Home', _href = URL('default', 'home')), False, None, []), ...]
여기, A 앵커에 해당하는 도우미입니다. <a>HTML의 태그. HTML 앵커를 만듭니다.<a> 프로그래밍 방식으로 태그합니다.
HTML 도우미는 두 가지 유형으로 구성됩니다. positional 과 named 인수.
Positional 인수는 HTML 열기 및 닫기 태그 사이에 포함 된 개체로 해석됩니다.
Named 밑줄로 시작하는 인수는 HTML 태그로 해석됩니다.
도우미는 문자열 직렬화에도 유용합니다. _str_및 xml 메서드. 예를 들면-
>>> print str(DIV(“hello world”))
산출
<div> hello world </div>
Note − HTML 도우미는 DOM (Document Object Model)의 서버 측 표현을 제공합니다.
XML 도우미
XML은 이스케이프해서는 안되는 텍스트를 캡슐화하는 객체라고합니다. 텍스트는 유효한 XML을 포함하거나 포함하지 않을 수 있습니다.
예를 들어 아래 언급 된 코드의 경우 JavaScript를 포함 할 수 있습니다.
>>> print XML('<script>alert("unsafe!")</script>')
산출
<script> alert(“unsafe!”)</script>
내장 도우미
web2py에서 사용되는 많은 내장 도우미가 있습니다. HTML 내장 도우미 중 일부는 다음과 같습니다.
이름 | 용법 | 예 |
---|---|---|
ㅏ | 이 도우미는 링크를 만드는 데 사용됩니다. 앵커 태그에 해당 | |
비 | 이 도우미는 텍스트 내용을 굵게 만드는 데 도움이됩니다. | |
몸 | 이 도우미는 페이지의 본문을 만듭니다. 나누기 횟수를 늘리기위한 곱셈 연산자도 포함됩니다. | |
암호 | Python, C, C ++ 및 web2py 코드에 대한 구문 강조를 수행합니다. 이 도우미는 API 문서를 링크하는 기능도 있습니다. | |
필드 셋 | 레이블과 함께 입력 필드를 만듭니다. | |
머리 | HTML 페이지의 <head> 태그를 태그하는 데 도움이됩니다. | |
IMG | 주어진 HTML 페이지에 이미지를 삽입하는 데 도움이됩니다. | |
맞춤 도우미
이러한 도우미는 요구 사항에 따라 태그를 사용자 지정하는 데 사용됩니다. web2py는 다음 사용자 지정 도우미를 사용합니다.
꼬리표
web2py는 TAG를 범용 태그 생성기로 사용합니다. 사용자 정의 된 XML 태그를 생성하는 데 도움이됩니다. 일반적인 구문은 다음과 같습니다.
{{ = TAG.name('a', 'b', _c = 'd')}}
XML 코드를 다음과 같이 생성합니다. <name c = "d"> ab </ name>
TAG는 객체 TAG.name
이거나 TAG['name']
임시 도우미 클래스를 반환하는 함수입니다.
메뉴
이 도우미는 목록 항목 또는 메뉴 항목의 값 목록을 만들어 메뉴를 나타내는 트리와 같은 구조를 생성합니다. 메뉴 항목 목록은 다음과 같은 형식입니다.response.menu. 예를 들면-
print MENU([['One', False, 'link1'], ['Two', False, 'link2']])
출력은 다음과 같이 표시됩니다.
<ul class = "web2py-menu web2py-menu-vertical">
<li><a href = "link1">One</a></li>
<li><a href = "link2">Two</a></li>
</ul>
아름답게 하다
목록 및 사전을 포함하여 복합 객체의 표현을 작성하는 데 도움이됩니다. 예를 들면
{{ = BEAUTIFY({"a": ["hello", XML("world")], "b": (1, 2)})}}
생성자 인수의 표현과 함께 XML로 직렬화 가능한 XML 객체를 반환합니다. 이 경우 표현은-
{"a": ["hello", XML("world")], "b": (1, 2)}
출력은 다음과 같이 렌더링됩니다.
<table>
<tr>
<td>a</td>
<td>:</td>
<td>hello<br />world</td>
</tr>
<tr>
<td>b</td>
<td>:</td>
<td>1<br />2</td>
</tr>
</table>
서버 측 DOM 렌더링
서버 측 렌더링을 통해 사용자는 web2py 구성 요소의 초기 상태를 미리 렌더링 할 수 있습니다. 파생 된 모든 헬퍼는 서버 측에서 DOM을 렌더링하기 위해 검색 요소와 요소를 제공합니다.
그만큼 element지정된 조건과 일치하는 첫 번째 자식 요소를 반환합니다. 반면에elements일치하는 모든 하위 목록을 반환합니다. 둘 다 동일한 구문을 사용합니다.
이것은 다음 예를 통해 입증 될 수 있습니다.
a = DIV(DIV(DIV('a', _id = 'target',_class = 'abc')))
d = a.elements('div#target')
d[0][0] = 'changed'
print a
출력은 다음과 같이 제공됩니다.
<div><div><div id = "target" class = "abc">changed</div></div></div>
페이지 레이아웃
보기는 최종 사용자에게 출력을 표시하는 데 사용됩니다. 확장 할 수있을뿐만 아니라 다른 뷰도 포함 할 수 있습니다. 이것은 트리와 같은 구조를 구현합니다.
예- “index.html” ~로 확장 “layout.html” 포함 할 수있는 “menu.html” 차례로 포함 “header.html”.
{{extend 'layout.html'}}
<h1>Hello World</h1>
{{include 'page.html'}}
예
이전 장에서 회사 모듈 용 모델과 컨트롤러를 만들었습니다. 이제 데이터 표시를 렌더링하는 데 도움이되는 뷰 생성에 초점을 맞출 것입니다.
기본적으로 web2py의보기에는 다음이 포함됩니다. layout.html 과 index.html, 데이터 표시의 전체 섹션을 정의합니다.
{{extend 'layout.html'}}
<h2>Companies</h2>
<table>
{{for company in companies:}}
<tr>
<td>{{ = A(company.name, _href = URL('contacts', args = company.id))}}</td>
<td>{{ = A('edit', _href = URL('company_edit', args = company.id))}}</td>
</tr>
{{pass}}
<tr>
<td>{{ = A('add company', _href = URL('company_create'))}}</td>
</tr>
</table>
출력은 다음과 같습니다.
그만큼 Database Abstraction Layer (DAL)web2py의 주요 강점으로 간주됩니다. DAL은 기본 SQL 구문에 간단한 API (응용 프로그래밍 인터페이스)를 제공합니다.
이 장에서는 효율적인 태그 검색을위한 쿼리 작성 및 계층 적 범주 트리 작성과 같은 DAL의 중요하지 않은 응용 프로그램에 대해 알아 봅니다.
DAL의 몇 가지 중요한 기능은 다음과 같습니다.
web2py에는 Python 개체를 데이터베이스 개체에 매핑하는 API 인 DAL (데이터베이스 추상화 계층)이 포함되어 있습니다. 데이터베이스 개체는 쿼리, 테이블 및 레코드 일 수 있습니다.
DAL은 데이터베이스 백엔드에 대해 지정된 언어를 사용하여 실시간으로 SQL을 동적으로 생성하므로 개발자가 완전한 SQL 쿼리를 작성해야하는 것은 아닙니다.
DAL 사용의 가장 큰 장점은 응용 프로그램이 다른 종류의 데이터베이스로 이식 가능하다는 것입니다.
DAL 시작하기
web2py의 대부분의 응용 프로그램에는 데이터베이스 연결이 필요합니다. 따라서 데이터베이스 모델 구축은 응용 프로그램 디자인의 첫 번째 단계입니다.
새로 만든 응용 프로그램을 고려하십시오. “helloWorld”. 데이터베이스는 응용 프로그램의 모델 아래에 구현됩니다. 각 응용 프로그램의 모든 모델은-models/db_custom.py.
다음 단계는 DAL을 구현하는 데 사용됩니다-
1 단계-DAL 생성자
데이터베이스 연결을 설정하십시오. DAL 생성자라고도하는 DAL 객체를 사용하여 생성됩니다.
db = DAL ('sqlite://storage.sqlite')
DAL의 주목할만한 기능은 동일한 데이터베이스 또는 다른 데이터베이스와의 다중 연결을 허용한다는 것입니다. 이 줄은 이미 파일에 있습니다.models/db.py. 따라서 삭제하거나 다른 데이터베이스에 연결하지 않는 한 필요하지 않을 수 있습니다. 기본적으로 web2py는 파일에 저장된 SQLite 데이터베이스에 연결합니다.storage.sqlite.
이 파일은 응용 프로그램의 데이터베이스 폴더에 있습니다. 파일이 없으면 응용 프로그램이 처음 실행될 때 web2py에 의해 생성됩니다.
SQLite는 빠르며 모든 데이터를 하나의 파일에 저장합니다. 즉, 데이터를 한 응용 프로그램에서 다른 응용 프로그램으로 쉽게 전송할 수 있습니다. 실제로 SQLite 데이터베이스는 응용 프로그램과 함께 web2py에 의해 패키징됩니다. 번역, 조인 및 집계를 포함한 전체 SQL 지원을 제공합니다.
SQLite에는 두 가지 단점이 있습니다.
하나는 열 유형을 적용하지 않으며 열 추가 및 삭제를 제외하고 ALTER TABLE이 없다는 것입니다.
다른 단점은 쓰기 액세스가 필요한 트랜잭션에 의해 전체 데이터베이스가 잠겨 있다는 것입니다.
2 단계-테이블 생성자
데이터베이스와의 연결이 설정되면 define_table 새 테이블을 정의하는 방법.
예를 들면-
db.define_table('invoice',Field('name'))
위의 방법은 Table 생성자에서도 사용됩니다. 테이블 생성자의 구문은 동일합니다. 첫 번째 인수는 테이블 이름이고 그 뒤에는Field(s). 필드 생성자는 다음 인수를 사용합니다.
Sr. 아니요 | 인수 및 사용법 |
---|---|
1 | The field name 테이블의 필드 이름입니다. |
2 | The field type 문자열 (기본값), 텍스트, 부울, 정수 등과 같은 데이터 유형을 갖는 값을 사용합니다. |
삼 | Length 최대 길이를 정의합니다. |
4 | default = None 새 레코드를 삽입 할 때의 기본값입니다. |
5 | update = None 이것은 기본값과 동일하게 작동하지만 값은 삽입이 아닌 업데이트에만 사용됩니다. |
6 | Notnull 필드 값이 NULL 일 수 있는지 여부를 지정합니다. |
7 | readable = True 필드를 양식에서 읽을 수 있는지 여부를 지정합니다. |
8 | writable = True 필드가 양식에 쓰기 가능한지 여부를 지정합니다. |
9 | label = "Field Name" 양식에서이 필드에 사용할 레이블입니다. |
그만큼 define_table 메서드는 또한 세 개의 명명 된 인수를받습니다-
통사론
db.define_table('....',migrate=True, fake_migrate=False, format = '%(id)s')
migrate = True − 이것은 web2py에게 테이블이 존재하지 않는 경우 생성하거나 모델 정의와 일치하지 않는 경우이를 변경하도록 지시합니다.
fake_migrate = False − 모델이 데이터베이스 테이블 내용과 일치하면 fake_migrate = True로 설정하여 web2py가 데이터를 재 구축하는 데 도움을줍니다.
format = '%(id)s' − 이것은 주어진 테이블의 레코드를 표현하는 방법을 결정하는 형식 문자열입니다.
원시 SQL 생성
DAL을 사용하여 데이터베이스에 대한 연결을 설정하고 테이블 생성자와 필드 생성자를 사용하여 새 테이블과 해당 필드를 만들 수 있습니다.
필요한 출력을 따르기 위해 SQL 문을 생성해야하는 경우도 있습니다. web2py에는 다음과 같이 제공되는 원시 SQL 생성에 도움이되는 다양한 기능이 포함되어 있습니다.
_끼워 넣다
주어진 테이블에 대한 삽입 문을 가져 오는 데 도움이됩니다. 예를 들면
print db.person._insert(name ='ABC')
"person"이라는 테이블에 대한 삽입 문을 검색합니다.
SQL 문 출력-
INSERT INTO person(name) VALUES ('ABC');
_카운트
레코드 수를 제공하는 SQL 문을 가져 오는 데 도움이됩니다. 예를 들어 'person'이라는 이름의 테이블을 고려하고 이름이 'ABC'인 사람의 수를 찾아야합니다.
print db(db.person.name ==' ABC ')._count()
SQL 문 출력-
SELECT count(*) FROM person WHERE person.name = ' ABC ';
_고르다
select SQL 문을 가져 오는 데 도움이됩니다. 예를 들어 'person'이라는 이름의 테이블을 고려하고 이름이 'ABC'인 사람 목록을 찾아야합니다.
print db(db.person.name == ' ABC ')._select()
SQL 문 출력-
SELECT person.name FROM person WHERE person.name = ' ABC ';
_지우다
가져 오는 데 도움이 delete SQL진술. 예를 들어 'person'이라는 이름의 테이블을 고려하면 이름이 'ABC'인 문을 삭제해야합니다.
print db(db.person.name == ' ABC ')._delete()
SQL 문 출력-
DELETE FROM person WHERE person.name = ' ABC ';4
_최신 정보
업데이트 된 SQL 문을 가져 오는 데 도움이됩니다. 예를 들어 'person'이라는 테이블을 고려하고 열 이름을 다른 값으로 업데이트해야합니다.
print db(db.person.name == ' ABC ')._update()
SQL 문 출력-
UPDATE person SET WHERE person.name = ’Alex’;
DAL 관련 문제 (Gotchas)
SQLite
SQLite는 열을 삭제하거나 변경하는 기능이 없습니다. 테이블에서 필드를 삭제하면 데이터베이스에서 활성 상태로 유지되므로 web2py는 변경 사항을 인식하지 못합니다.
이 경우 설정이 필요합니다. fake_migrate = True 이는 변경 또는 삭제와 같은 변경 사항이 web2py의 지식 아래에 유지되도록 메타 데이터를 재정의하는 데 도움이됩니다.
SQLite는 부울 유형을 지원하지 않습니다. 이를 위해 web2py는 내부적으로 Booleans를 1 개의 문자열로 매핑하며 'T'와 'F'는true 과 False 각기.
MySQL
MySQL은 ALTER TABLE 기능을 지원하지 않습니다. 따라서 데이터베이스 마이그레이션에는 여러 커밋이 포함됩니다. 이 상황은 매개 변수를 설정하여 피할 수 있습니다.fake_migrate = True 모든 메타 데이터를 유지하는 데이터베이스를 정의하는 동안
신탁
Oracle은 레코드 페이지 매김 기능을 지원하지 않습니다. 또한 키워드 OFFSET 또는 limit에 대한 지원이 없습니다. 이를 위해 web2py는 복잡한 3 방향 중첩 DAL 선택을 통해 페이지 매김을 수행합니다. Oracle 데이터베이스가 사용 된 경우 DAL은 자체적으로 페이지 매김을 처리해야합니다.
web2py는 양식 생성을위한 강력한 기능을 제공합니다. web2py에서 양식을 작성하는 네 가지 방법은 다음과 같습니다.
FORM− HTML 도우미 측면에서 저수준 구현으로 간주됩니다. FORM 개체는 해당 필드 내용을 인식합니다.
SQLFORM − 기존 데이터베이스에 생성, 업데이트, 삭제 기능을 제공합니다.
SQLFORM.factory− SQLFORM 상단의 추상화 계층으로 간주되어 SQLFORM과 유사한 형태를 생성합니다. 여기에서는 새 데이터베이스를 만들 필요가 없습니다.
CRUD Methods − 이름에서 알 수 있듯이 SQLFORM 기반의 유사한 기능으로 Create, Retrieve, Update, Delete 기능을 제공합니다.
형태
사용자의 입력을 받아들이고 응답을 제출하기위한 "제출"버튼이있는 애플리케이션을 고려하십시오.
제어 장치
“default.py”컨트롤러에는 다음과 같은 관련 기능이 포함됩니다.
def display_form():
return dict()
전망
연관된 뷰 "default / display_form.html"은 HTML 형식의 디스플레이를 다음과 같이 렌더링합니다.
{{extend 'layout.html'}}
<h2>Basic Form</h2>
<form enctype = "multipart/form-data" action = "{{= URL()}}" method = "post">
Your name:
<input name = "name" />
<input type = "submit" />
</form>
<h2>Submitted variables</h2>
{{= BEAUTIFY(request.vars)}}
위의 예는 사용자 입력을 요청하는 일반 HTML 양식입니다. FORM 개체와 같은 도우미를 사용하여 동일한 형식을 생성 할 수 있습니다.
제어 장치
def display_form():
form = FORM('Value:', INPUT(_value = 'name'), INPUT(_type = 'submit'))
return dict(form = form)
“default.py”컨트롤러의 위 함수는 폼 생성을 돕는 FORM 객체 (HTML helper)를 포함합니다.
전망
{{extend 'layout.html'}}
<h2>Basic form</h2>
{{= form}}
<h2>Submitted variables</h2>
{{= BEAUTIFY(request.vars)}}
그는 진술에 의해 생성 된 형태 {{= form}}FORM 개체를 직렬화합니다. 사용자가 양식을 작성하고 제출 버튼을 클릭하면 양식이 자체 제출되고 변수가request.vars.value 입력 값과 함께 하단에 표시됩니다.
SQLFORM
기존 데이터베이스에 양식을 작성하는 데 도움이됩니다. 구현 단계는 아래에서 설명합니다.
DAL을 사용하여 데이터베이스와의 연결을 설정하는 DAL 생성자라고도하는 DAL 객체를 사용하여 생성합니다. 연결을 설정 한 후 사용자는 해당 테이블을 생성 할 수 있습니다.
db = DAL('sqlite://storage.sqlite')
db.define_table('employee', Field('name', requires = IS_NOT_EMPTY()))
따라서 "employee"라는 테이블을 만들었습니다. 컨트롤러는 다음 문장으로 폼과 버튼을 만듭니다.
form = SQLFORM(
db.mytable,
record = mytable_index,
deletable = True,
submit_button = T('Update')
)
따라서 생성 된 직원 테이블의 경우 컨트롤러의 수정은 다음과 같습니다.
def display_form():
form = SQLFORM(db.person)
수정 사항이 없습니다. View. 새 컨트롤러에서는 db.employee 테이블에서 빌드 된 SQLFORM 생성자가 모델에 정의되어 있으므로 FORM을 빌드해야합니다. 직렬화되면 새 양식은 다음과 같이 나타납니다.
<form enctype = "multipart/form-data" action = "" method = "post">
<table>
<tr id = "employee_name__row">
<td>
<label id = "person_name__label" for = "person_name">Your name: </label>
</td>
<td>
<input type = "text" class = "string" name = "name" value = "" id = "employee_name" />
</td>
<td></td>
</tr>
<tr id = "submit_record__row">
<td></td>
<td><input value = "Submit" type = "submit" /></td>
<td></td>
</tr>
</table>
<input value = "9038845529" type = "hidden" name = "_formkey" />
<input value = "employee" type = "hidden" name = "_formname" />
</form>
양식의 모든 태그에는 테이블 및 필드 이름에서 파생 된 이름이 있습니다.
안 SQLFORM객체는 또한 업로드 된 파일을 "uploads"폴더에 저장하여 "upload"필드를 처리합니다. 이것은 자동으로 수행됩니다. SQLFORM은 "Boolean"값을 확인란 및 텍스트 값의 형태로 표시합니다.“textareas”.
SQLFORM은 또한 프로세스 방식을 사용하는데, 이는 사용자가 SQLFORM과 관련된 값을 유지하고자 할 때 필요합니다.
만약 form.process(keepvalues = True) 그런 다음 허용됩니다.
예
def display_form():
form = SQLFORM(db.employee)
if form.process().accepted:
response.flash = 'form accepted'
elif form.errors:
response.flash = 'form has errors'
else:
response.flash = 'please fill out the form'
return dict(form = form)
SQLFORM.factory
때때로 사용자는 데이터베이스 구현없이 기존 데이터베이스 테이블이있는 방식으로 양식을 생성해야합니다. 사용자는 단순히 SQLFORM 기능을 활용하기를 원합니다.
이것은 다음을 통해 수행됩니다. form.factory 세션에서 유지됩니다.
def form_from_factory():
form = SQLFORM.factory(
Field('your_name', requires = IS_NOT_EMPTY()),
Field('your_image', 'upload'))
if form.process().accepted:
response.flash = 'form accepted'
session.your_name = form.vars.your_name
session.your_image = form.vars.your_image
elif form.errors:
response.flash = 'form has errors'
return dict(form = form)
양식은 필드로 이름과 이미지가있는 SQLFORM처럼 나타나지만 데이터베이스에는 이러한 기존 테이블이 없습니다.
"default / form_from_factory.html"보기는 다음과 같이 나타납니다.
{{extend 'layout.html'}}
{{= form}}
CRUD 방법
CRUDSQLFORM 위에서 사용되는 API입니다. 이름에서 알 수 있듯이 적절한 양식의 생성, 검색, 업데이트 및 삭제에 사용됩니다.
web2py의 다른 API에 비해 CRUD는 노출되지 않습니다. 따라서 가져와야합니다.
from gluon.tools import Crud
crud = Crud(db)
위에 정의 된 CRUD 객체는 다음 API를 제공합니다.
Sr. 아니요 | API 및 기능 |
---|---|
1 | crud.tables() 데이터베이스에 정의 된 테이블 목록을 반환합니다. |
2 | crud.create(db.tablename) 생성 양식을 반환합니다. table tablename. |
삼 | crud.read(db.tablename, id) 다음에 대한 읽기 전용 양식을 반환합니다. tablename 및 레코드 ID. |
4 | crud.delete(db.tablename, id) 기록을 삭제합니다 |
5 | crud.select(db.tablename, query) 테이블에서 선택한 레코드 목록을 반환합니다. |
6 | crud.search(db.tablename) 양식이 검색 양식 인 튜플 (양식, 레코드)을 반환합니다. |
7 | crud() request.args ()를 기반으로 위 중 하나를 반환합니다. |
양식 생성
양식을 만들어 보겠습니다. 아래 주어진 코드를 따르십시오.
모델
새 모델은 models응용 프로그램의 폴더. 파일 이름은 다음과 같습니다.“dynamic_search.py”.
def build_query(field, op, value):
if op == 'equals':
return field == value
elif op == 'not equal':
return field != value
elif op == 'greater than':
return field > value
elif op == 'less than':
return field < value
elif op == 'starts with':
return field.startswith(value)
elif op == 'ends with':
return field.endswith(value)
elif op == 'contains':
return field.contains(value)
def dynamic_search(table):
tbl = TABLE()
selected = []
ops = ['equals',
'not equal',
'greater than',
'less than',
'starts with',
'ends with',
'contains']
query = table.id > 0
for field in table.fields:
chkval = request.vars.get('chk'+field,None)
txtval = request.vars.get('txt'+field,None)
opval = request.vars.get('op'+field,None)
row = TR(TD(INPUT(_type = "checkbox",_name = "chk"+field,value = chkval == 'on')),
TD(field),TD(SELECT(ops,_name = "op"+field,value = opval)),
TD(INPUT(_type = "text",_name = "txt"+field,_value = txtval)))
tbl.append(row)
if chkval:
if txtval:
query &= build_query(table[field], opval,txtval)
selected.append(table[field])
form = FORM(tbl,INPUT(_type="submit"))
results = db(query).select(*selected)
return form, results
제어 장치
즉 관련 파일 “dynamic_search.py” 컨트롤러 섹션에서 다음 코드가 포함됩니다-
def index():
form,results = dynamic_search(db.things)
return dict(form = form,results = results)
전망
다음 뷰로이를 렌더링 할 수 있습니다.
{{extend 'layout.html'}}
{{= form}}
{{= results}}
다음은 그 모습입니다.
web2py는 사용자에게 이메일과 SMS를 보내는 기능을 포함합니다. 라이브러리를 사용하여 이메일과 SMS를 보냅니다.
이메일 설정
내장 클래스 즉 gluon.tools.Mail클래스는 web2py 프레임 워크에서 이메일을 보내는 데 사용됩니다. 이 클래스로 메일러를 정의 할 수 있습니다.
from gluon.tools import Mail
mail = Mail()
mail.settings.server = 'smtp.example.com:25'
mail.settings.sender = '[email protected]'
mail.settings.login = 'username:password'
위의 예에서 언급 한 발신자 이메일과 비밀번호는 이메일이 전송 될 때마다 인증됩니다.
사용자가 디버깅 목적으로 실험하거나 사용해야하는 경우 다음 코드를 사용하여 수행 할 수 있습니다.
mail.settings.server = 'logging'
이제 모든 이메일이 전송되지는 않지만 콘솔에 기록됩니다.
이메일 보내기
메일 개체를 사용하여 이메일에 대한 구성 설정을 지정하면 이메일을 많은 사용자에게 보낼 수 있습니다.
완전한 구문 mail.send() 다음과 같습니다-
send(
to, subject = 'Abc',
message = 'None', attachments = [],
cc = [], bcc = [], reply_to = [],
sender = None, encoding = 'utf-8',
raw = True, headers = {}
)
구현 mail.send() 아래에 주어진다.
mail.send(
to = ['[email protected]'], subject = 'hello',
reply_to = '[email protected]',
message = 'Hello ! How are you?'
)
Mail최종 사용자가 메일을받은 메일 링 서버의 응답을 기반으로 부울 표현식을 반환합니다. 그것은 반환True 사용자에게 이메일 전송에 성공한 경우.
속성, cc 과 bcc 메일을 보낼 유효한 이메일 주소 목록을 포함합니다.
SMS 보내기
SMS 메시지를 전송하기위한 구현은 수신자에게 메시지를 릴레이 할 수있는 타사 서비스가 필요하기 때문에 web2py 프레임 워크에서 이메일을 전송하는 것과 다릅니다. 제 3 자 서비스는 무료 서비스가 아니며 지리적 지역 (국가별로)에 따라 분명히 다릅니다.
web2py는 모듈을 사용하여 다음 프로세스를 통해 SMS를 전송합니다.
from gluon.contrib.sms_utils
import SMSCODES, sms_email
email = sms_email('1 (111) 111-1111','T-Mobile USA (abc)')
mail.send(to = email, subject = 'test', message = 'test')
위의 예에서 SMSCODES 주요 전화 회사의 이름을 이메일 주소 접미사에 매핑하는 web2py에서 관리하는 사전입니다.
전화 회사는 일반적으로 타사 서비스에서 발생하는 이메일을 스팸으로 취급합니다. 더 나은 방법은 전화 회사가 SMS를 중계하는 것입니다. 모든 전화 회사는 저장소에있는 모든 휴대폰 번호에 대해 고유 한 이메일 주소를 포함하고 있으며 SMS는 이메일로 직접 보낼 수 있습니다.
위의 예에서
그만큼 sms_email 함수는 전화 번호 (문자열)를 받아 전화의 이메일 주소를 반환합니다.
스캐 폴딩 앱에는 여러 파일이 포함되어 있습니다. 그중 하나는 models / db.py로 4 개를 가져옵니다.
수업 gluon.tools 메일 라이브러리도 포함하고 다양한 전역 개체를 정의합니다.
스캐 폴딩 애플리케이션은 다음과 같이 auth 개체에 필요한 테이블도 정의합니다. db.auth_user. 기본 스캐 폴딩 응용 프로그램은 모듈식이 아니라 파일 수를 최소화하도록 설계되었습니다. 특히 모델 파일은db.py에는 프로덕션 환경에서 별도의 파일에 가장 잘 보관되는 구성이 포함됩니다.
여기에서 구성 파일을 만드는 것이 좋습니다.
from gluon.storage import Storage
settings = Storage()
settings.production = False
if
settings.production:
settings.db_uri = 'sqlite://production.sqlite'
settings.migrate = False
else:
settings.db_uri = 'sqlite://development.sqlite'
settings.migrate = True
settings.title = request.
settings.subtitle = 'write something here'
settings.author = 'you'
settings.author_email = '[email protected]'
settings.keywords = ''
settings.description = ''
settings.layout_theme = 'Default'
settings.security_key = 'a098c897-724b-4e05-b2d8-8ee993385ae6'
settings.email_server = 'localhost'
settings.email_sender = '[email protected]'
settings.email_login = ''
settings.login_method = 'local'
settings.login_config = ''
입증
거의 모든 애플리케이션은 사용자를 인증하고 권한을 설정할 수 있어야합니다. web2py는 광범위하고 사용자 정의 가능한 역할 기반 액세스 제어와 함께 제공됩니다.mechanism.web2py. 또한 CAS, OpenID, OAuth 1.0, LDAP, PAM, X509 등과 같은 프로토콜을 지원합니다.
web2py에는 권한있는 사용자에게 시스템 액세스를 제한하는 접근 방식 인 RBAC (역할 기반 액세스 제어 메커니즘)라는 메커니즘이 포함되어 있습니다. RBAC를 구현하는 web2py 클래스를 Auth라고합니다.
아래 주어진 스키마를보십시오.
Auth 다음 테이블을 정의합니다-
Sr. 아니요 | 테이블 이름 및 설명 |
---|---|
1 | auth_user 사용자 이름, 이메일 주소, 비밀번호 및 상태를 저장합니다. |
2 | auth_group 다 대다 구조로 사용자의 그룹 또는 역할을 저장합니다. |
삼 | auth_membership 링크 사용자 및 그룹의 정보를 다 대다 구조로 저장합니다. |
4 | auth_permission 표는 그룹과 권한을 연결합니다. |
5 | auth_event 다른 테이블의 변경 사항과 성공적인 액세스를 기록합니다. |
6 | auth_cas 중앙 인증 서비스에 사용됩니다. |
인증 사용자 지정
인증을 맞춤 설정하는 방법에는 두 가지가 있습니다.
사용자 정의를 정의하려면 db.auth_user 처음부터 테이블.
web2py가 auth 표.
정의하는 마지막 방법을 살펴 보겠습니다. auth표. 에서db.py 모델, 다음 줄을 바꿉니다-
auth.define_tables()
다음 코드로 대체하십시오-
auth.settings.extra_fields['auth_user'] = [
Field('phone_number',requires = IS_MATCH('\d{3}\-\d{3}\-\d{4}')),
Field('address','text')
]
auth.define_tables(username = True)
각 사용자는 전화 번호, 사용자 이름 및 주소로 구성되어 있다고 가정합니다.
auth.settings.extra_fields추가 필드의 사전입니다. 키는 추가 필드를 추가 할 인증 테이블의 이름입니다. 값은 추가 필드 목록입니다. 여기에 두 개의 추가 필드를 추가했습니다.phone_number and address.
username일반적으로 이메일 필드를 기반으로하는 인증 프로세스에 관련되기 때문에 특수한 방식으로 처리되어야합니다. 다음 줄에 사용자 이름 인수를 전달하면 사용자 이름 필드를 원하고 이메일 필드 대신 로그인에 사용하고 싶다는 것을 web2py에 알립니다. 기본 키처럼 작동합니다.
auth.define_tables(username = True)
사용자 이름은 고유 한 값으로 처리됩니다. 일반 등록 양식을 벗어나 등록하는 경우가 있습니다. 또한 새 사용자가 등록을 완료하기 위해 강제로 로그인해야합니다.
이것은 더미 필드를 사용하여 수행 할 수 있습니다. complete_registration 그것은 False 기본적으로 설정되어 있습니다. True 프로필을 업데이트 할 때
auth.settings.extra_fields['auth_user'] = [
Field('phone_number',requires = IS_MATCH('\d{3}\-\d{3}\-\d{4}'),
comment = "i.e. 123-123-1234"),
Field('address','text'),
Field('complete_registration',default = False,update = True,
writable = False, readable = False)
]
auth.define_tables(username = True)
이 시나리오는 로그인시 새 사용자가 등록을 완료하도록 의도 할 수 있습니다.
에 db.py, models 폴더에 다음 코드를 추가 할 수 있습니다.
if auth.user and not auth.user.complete_registration:
if not (request.controller,request.function) == ('default','user'):
redirect(URL('default','user/profile'))
이렇게하면 새 사용자가 요구 사항에 따라 프로필을 편집해야합니다.
권한 부여
사용자에게 일부 액세스 권한을 부여하거나 권한을 부여하는 프로세스입니다.
web2py에서 새 사용자가 생성되거나 등록되면 사용자를 포함하는 새 그룹이 생성됩니다. 새 사용자의 역할은 일반적으로 다음과 같습니다.“user_[id]” 여기서 id는 사용자의 고유 ID입니다.
새 그룹 생성에 대한 기본값은-
auth.settings.create_user_groups = "user_%(id)s"
사용자 간의 그룹 생성은 다음에 의해 비활성화 될 수 있습니다.
auth.settings.create_user_groups = None
생성, 특정 구성원 및 권한에 대한 액세스 권한 부여는 appadmin의 도움으로 프로그래밍 방식으로 수행 할 수도 있습니다.
구현 중 일부는 다음과 같습니다.
Sr. 아니요 | 명령 및 사용법 |
---|---|
1 | auth.add_group('role', 'description') 새로 생성 된 그룹의 ID를 반환합니다. |
2 | auth.del_group(group_id) 지정된 ID를 가진 그룹을 삭제합니다. |
삼 | auth.del_group(auth.id_group('user_7')) 주어진 ID로 사용자 그룹을 삭제합니다. |
4 | auth.user_group(user_id) 주어진 사용자에 대해 고유하게 연결된 그룹의 id 값을 반환합니다. |
5 | auth.add_membership(group_id, user_id) 주어진 group_id에 대한 user_id의 값을 반환합니다. |
6 | auth.del_membership(group_id, user_id) 주어진 그룹에서 주어진 member_id, 즉 user_id의 액세스를 취소합니다. |
7 | auth.has_membership(group_id, user_id, role) user_id가 주어진 그룹에 속하는지 확인합니다. |
중앙 인증 서비스 (CAS)
web2py는 클라이언트 및 서버에 내장 된 web2py 모두를위한 클라이언트 인증 서비스 – CAS라는 업계 표준을 제공합니다. 타사 인증 도구입니다.
분산 인증을위한 개방형 프로토콜입니다. CAS의 작동 방식은 다음과 같습니다.
사용자가 웹 사이트를 방문하면 프로토콜은 사용자가 인증되었는지 확인합니다.
사용자가 애플리케이션에 대해 인증되지 않은 경우 프로토콜은 사용자가 애플리케이션에 등록하거나 로그인 할 수있는 페이지로 리디렉션됩니다.
등록이 완료되면 사용자에게 이메일이 발송됩니다. 사용자가 이메일을 확인할 때까지 등록이 완료되지 않습니다.
성공적으로 등록되면 사용자는 CAS 어플라이언스에서 사용하는 키로 인증됩니다.
이 키는 백그라운드에서 설정된 HTTP 요청을 통해 사용자의 자격 증명을 가져 오는 데 사용됩니다.
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.
이 장에서는 통합의 예를 설명합니다. jQuery 플러그인 web2py. 이러한 플러그인은 양식과 테이블을 사용자에게보다 상호 작용하고 친숙하게 만들어 응용 프로그램의 유용성을 향상시키는 데 도움이됩니다.
특히 우리는
대화 형 추가 옵션 버튼으로 다중 선택 드롭 다운을 개선하는 방법,
입력 필드를 슬라이더로 바꾸는 방법
사용하여 테이블 형식 데이터를 표시하는 방법 jqGrid 과 WebGrid.
web2py는 서버 측 개발 구성 요소이지만 welcome 비계 앱에는베이스가 포함됩니다. jQuery도서관. 이 스캐 폴딩 web2py 애플리케이션 "welcome"에는views/web2py_ajax.html.
보기의 내용은 다음과 같습니다-
<script type = "text/javascript"><!--
// These variables are used by the web2py_ajax_init function in web2py_ajax.js
(which is loaded below).
var w2p_ajax_confirm_message = "{{= T('Are you sure you want to delete this object?')}}";
var w2p_ajax_disable_with_message = "{{= T('Working...')}}";
var w2p_ajax_date_format = "{{= T('%Y-%m-%d')}}";
var w2p_ajax_datetime_format = "{{= T('%Y-%m-%d %H:%M:%S')}}";
var ajax_error_500 = '{{=T.M('An error occured, please [[reload %s]] the page') %
URL(args = request.args, vars = request.get_vars) }}'
//--></script>
{{
response.files.insert(0,URL('static','js/jquery.js'))
response.files.insert(1,URL('static','css/calendar.css'))
response.files.insert(2,URL('static','js/calendar.js'))
response.files.insert(3,URL('static','js/web2py.js'))
response.include_meta()
response.include_files()
}}
이 파일은 JavaScript 구현과 AJAX 구현으로 구성됩니다. web2py는 사용자가 Prototype, ExtJS와 같은 다른 AJAX 라이브러리를 사용하는 것을 방지합니다. 이러한 라이브러리를 구현하는 것이 항상 더 쉽기 때문입니다.
JQuery 효과
의 기본 렌더링 <select multiple = "true">..</select>특히 비 연속적인 옵션을 선택해야 할 때 사용하기에는 그리 직관적이지 않은 것으로 간주됩니다. 이것은 HTML 단점이라고 할 수는 없지만 대부분의 브라우저의 디자인이 좋지 않습니다. 다중 선택의 표시는 JavaScript를 사용하여 덮어 쓸 수 있습니다. 이것은 jQuery 플러그인을 사용하여 구현할 수 있습니다.jquery.multiselect.js.
이를 위해 사용자는 플러그인을 다운로드해야합니다. jquery.muliselect.js ...에서 http://abeautifulsite.net/2008/04/jquery-multiselect, 해당 파일을 static/js/jquery.multiselect.js 과 static/css/jquery.multiselect.css.
예
다음 코드를 해당 뷰에 추가해야합니다. {{extend ‘layout.html’}}
{{
response.files.append('https://ajax.googleapis.com/ajax\
/libs/jqueryui/1.8.9/jquery-ui.js')
response.files.append('https://ajax.googleapis.com/ajax\
/libs/jqueryui/1.8.9/themes/ui-darkness/jquery-ui.css')
response.files.append(URL('static','js/jquery.multiSelect.js'))
response.files.append(URL('static','css/jquery.\multiSelect.css'))
}}
뒤에 다음을 배치하십시오 {{extend 'layout.html'}} −
<script>
jQuery(document).ready(function(){jQuery('[multiple]').multiSelect();});
</script>
이것은 스타일에 도움이 될 것입니다 multiselect 주어진 형태에 대해
제어 장치
def index():
is_fruits = IS_IN_SET(['Apples','Oranges','Bananas','Kiwis','Lemons'], multiple = True)
form = SQLFORM.factory(Field('fruits','list:string', requires = is_fruits))
if form.accepts(request,session):response.flash = 'Yummy!'
return dict(form = form)
이 작업은 다음보기에서 시도 할 수 있습니다.
{{
response.files.append('https://ajax.googleapis.com/ajax\
/libs/jqueryui/1.8.9/jquery-ui.js')
response.files.append('https://ajax.googleapis.com/ajax\
/libs/jqueryui/1.8.9/themes/ui-darkness/jquery-ui.css')
response.files.append(URL('static','js/jquery.multiSelect.js'))
response.files.append(URL('static','css/jquery.\multiSelect.css'))
}}
{{extend 'layout.html}}
<script>
jQuery(document).ready(function(){jQuery('[multiple]'). multiSelect();});
</script>
{{= form}}
출력의 스크린 샷은 다음과 같습니다.
유용한 Jquery 이벤트 중 일부는 다음 표에 나열되어 있습니다.
Sr. 아니. | 이벤트 및 사용 |
---|---|
1 | onchange 요소가 변경 될 때 실행됩니다. |
2 | onsubmit 양식 제출시 실행 |
삼 | onselect 요소가 선택 될 때 실행됩니다. |
4 | onblur 요소가 초점을 잃을 때 실행됩니다. |
5 | onfocus 요소가 포커스를받을 때 실행됩니다. |
JQuery 및 Ajax-jqGrid
jqGrid는 테이블 형식 데이터를 표현하고 조작하기위한 솔루션을 제공하는 jQuery에 구축 된 Ajax 지원 JavaScript 컨트롤입니다. jqGrid 클라이언트 측 솔루션이며 Ajax 콜백을 통해 데이터를 동적으로로드하므로 페이지 매김, 검색 팝업, 인라인 편집 등을 제공합니다.
jqGrid는 PluginWiki에 통합되어 있지만 여기서는 플러그인을 사용하지 않는 web2py 프로그램을위한 독립형으로 논의합니다. jqGrid는 독자적인 책이 필요하지만 여기서는 기본 기능과 가장 간단한 통합에 대해서만 설명합니다.
jqGrid의 구문은 다음과 같습니다.
def JQGRID(
table, fieldname = None,
fieldvalue = None, col_widths = [],
colnames = [], _id = None, fields = [],
col_width = 80, width = 700,
height = 300, dbname = 'db'
):
구성 요소는 자율적으로 작동하는 웹 페이지의 기능 부분으로 정의됩니다. 웹 페이지에 포함 된 모듈, 컨트롤러 및보기로 구성 될 수 있습니다. 응용 프로그램의 구성 요소는 현지화 된 태그 여야하며 성능은 모듈과 무관 한 것으로 간주됩니다.
web2py에서 주요 초점은 페이지에로드되고 AJAX를 통해 구성 요소 컨트롤러와 통신하는 구성 요소를 사용하는 것입니다.
web2py에는 함수가 포함되어 있습니다. LOAD 함수를 사용하면 명시적인 JavaScript 또는 AJAX 프로그래밍없이 구성 요소를 쉽게 구현할 수 있습니다.
간단한 웹 애플리케이션 즉“test”파일의 사용자 정의 모델로 web2py 애플리케이션을 확장합니다.models/db_comments.py”.
db.define_table(
'comment_post', Field('body','text',
label = 'Your comment'),auth.signature
)
위의 코드는 "comment_post”을 적절한 테이블 정의로 지정합니다. 이 작업은 "의 기능을 사용하여 구현됩니다.controllers/comments.py”.
def post():
return dict(
form = SQLFORM(db.comment_post).process(),
comments = db(db.comment_post).select()
)
해당보기는 다음과 같이 표시됩니다.
{{extend 'layout.html'}}
{{for post in comments:}}
<div class = "post">
On {{= post.created_on}} {{= post.created_by.first_name}}
says <span class = "post_body">{{= post.body}}</span>
</div>
{{pass}}
{{= form}}
페이지는 주어진 URL을 사용하여 액세스 할 수 있습니다- http://127.0.0.1:8000/test/comments/post
위에서 언급 한 방법은 뷰에 액세스하는 전통적인 방법으로, LOAD 함수 구현으로 변경할 수 있습니다.
확장 기능을 사용하여 새보기를 만들면됩니다. ".load" 레이아웃을 확장하지 않습니다.
생성 된 새보기는 "views/comments/post.load" −
<div class = "post">
On {{= post.created_on}} {{= post.created_by.first_name}}
says <blockquote class = "post_body">{{= post.body}}</blockquote>
</div>
{{pass}}
{{= form}}
페이지에 액세스하는 URL은 다음과 같습니다. http://127.0.0.1:8000/test/comments/post.load
LOAD 컴포넌트는 web2py 애플리케이션의 다른 페이지에 임베드 될 수 있습니다. 다음 문을 사용하여 수행 할 수 있습니다.
{{= LOAD('comments','post.load',ajax = True)}}
예를 들어 Controllers 다음과 같이 편집 할 수 있습니다.
def index():
return dict()
에 View, 우리는 구성 요소를 추가 할 수 있습니다-
{{extend 'layout.html'}}
{{= LOAD('comments','post.load',ajax = True)}}
페이지는 URL로 액세스 할 수 있습니다- http://127.0.0.1:8000/test/default/index
구성 요소 플러그인
구성 요소 플러그인은 고유하게 정의하는 플러그인입니다. Components. 구성 요소는 모델 정의를 사용하여 데이터베이스에 직접 액세스합니다.
이전 예에서 언급했듯이 주석 구성 요소는 comments_plugin 할 수 있습니다 Models 섹션-
"models/plugin_comments.py"−
db.define_table(
'plugin_comments_comment',
Field('body','text', label = 'Your comment'),
auth.signature
)
그만큼 Controller 다음 플러그인이 포함됩니다-
def plugin_comments():
return LOAD('plugin_comments','post',ajax = True)
Ubuntu (Linux)에 web2py 설치
Ubuntu Desktop에 web2py를 설치하기 위해 다음 단계가 구현됩니다.
Step 1 − web2py 다운로드
cd /home
mkdir www-dev
cd www-dev
wget http://www.web2py.com/examples/static/web2py_src.zip
Step 2 − 다운로드가 완료되면 압축을 풉니 다.
unzip -x web2py_src.zip
Step 3 − GUI에 액세스해야하는 경우 선택적으로 Python 용 tk 라이브러리를 설치합니다.
sudo apt-get install python-tk
Step 4 − web2py를 시작하려면 web2py 디렉토리에 액세스하여 web2py를 실행하십시오.
cd web2py
python web2py.py
GUI는 다음과 같이 나타납니다.
설치 후 실행할 때마다 web2py는 비밀번호를 선택하도록 요청합니다. 이 암호는 관리 암호입니다. 암호를 비워두면 관리 인터페이스가 비활성화됩니다.
서버가 시작되면 web2py는 다음 URL을 사용하여 화면으로 리디렉션됩니다. http://127.0.0.1:8000/
이것은 web2py가 Ubuntu 데스크탑에서 완벽하게 실행된다는 결론을 내릴 것입니다.
Ubuntu에서 프로덕션 배포
Step 1 − web2py 실행에 필요한 모든 모듈 설치.
postgreSQL 설치
sudo apt-get install postgresql
ssh-server의 압축을 풀고 엽니 다.
sudo apt-get install unzip
sudo apt-get install openssh-server
Apache 2 및 mod-wsgi 설치
sudo apt-get install apache2
sudo apt-get install libapache2-mod-wsgi
Step 2 − / home / www-data에 web2py 설치
이는 프로덕션 환경에서 적절한 배포에 도움이됩니다.
sudo apt-get install unzip
sudo apt-get install openssh-server
cd /home
sudo mkdir www-data
cd www-data
web2py 사이트에서 web2py 소스 가져 오기-
sudo wget http://web2py.com/examples/static/web2py_src.zip
sudo unzip web2py_src.zip
sudo chown -R www-data:www-data web2py
Step 3− 자체 서명 된 인증서를 생성합니다. SSL 인증서는 신뢰할 수있는 인증 기관에서 얻어야합니다. 인증서가있는 SSL 폴더를 유지하십시오.
Step 4 − 프로덕션 환경의 요구 사항에 따라 아파치 구성을 편집합니다.
Step 5 − Apache 서버를 다시 시작하고 프로덕션 환경이 주어진 IP 주소에 대해 작동하는지 확인합니다.
Windows에 web2py 설치
Windows 환경 (실행 파일 및 표준 라이브러리 패키징)을위한 바이너리 배포가 있지만 web2py는 오픈 소스이며 일반 Python 설치와 함께 사용할 수 있습니다.
이 방법을 사용하면 최신 web2py 릴리스로 작업하고 사용할 Python 모듈을 사용자 정의 할 수 있습니다.
Step 1 − web2py 공식 웹 사이트에서 소스 패키지 다운로드 − http://www.web2py.com/examples/static/web2py_src.zip 압축을 풉니 다.
web2py는 설치가 필요하지 않으므로 사용자는 임의의 폴더에서 압축을 풀 수 있습니다.
Step 2 − 시작하려면 두 번 클릭하십시오. web2py.py. 콘솔에서-
cd c:\web2py
c:\python27\python.exe web2py.py
Step 3− 여기에서 명령 줄 매개 변수를 추가 할 수 있습니다 (관리자 암호를 설정하려면 −a, 대체 포트를 지정하려면 −p). 시작 옵션은-
C:\web2py>c:\python27\python.exe web2py.py --help
노트
web2py는 실행을 위해 컴파일이나 복잡한 설치가 필요하지 않은 이식 가능하고 해석 된 동적 언어 인 Python으로 작성되었습니다.
가상 머신 (예 : Java 및 .Net)을 사용하며 스크립트를 실행할 때 즉시 소스 코드를 투명하게 바이트 컴파일 할 수 있습니다.
데이터베이스 및 테스트를위한 web2py의 기능
web2py 모델을 만들고 해당 코드를 생성하는 데 도움이되는 SQLDesigner라는 소프트웨어입니다. 다음은 스크린 샷 중 일부입니다.
SQLDesigner는 간단한 방식으로 테이블의 관계를 유지하는 데 도움이되며 주어진 응용 프로그램의 모델에서 해당 코드를 생성합니다.
기능 테스트
기능 테스트에는 구성 요소 또는 전체 시스템의 기능 테스트가 포함됩니다. 요구 사항 및 비즈니스 프로세스를 기반으로 할 수 있습니다.
web2py는 모듈과 함께 제공됩니다 gluon.contrib.webclient, 원격 및 로컬 web2py 애플리케이션에서 기능 테스트를 수행합니다. 기본적으로 web2py 세션 및 포스트 백을 이해하도록 설계되었습니다.
필요한 것은 기능 테스트가 주어진 모듈에서 구현되도록 패키지를 가져 오는 것입니다.
패키지를 가져 오는 구문은 다음과 같습니다.
from gluon.contrib.webclient import WebClient
이전 장에서는 다양한 도구를 사용한 web2py 구현에 대한 완전한 정보가있었습니다. web2py 애플리케이션 개발의 주요 관심사는 사용자 관점의 보안입니다.
web2py의 고유 한 기능은 다음과 같습니다.
사용자는 구현을 쉽게 배울 수 있습니다. 설치 및 종속성이 필요하지 않습니다.
출시일부터 안정적이었습니다.
web2py는 가볍고 데이터 추상화 계층 및 템플릿 언어 용 라이브러리를 포함합니다.
웹 서버와 애플리케이션 간의 통신 역할을하는 웹 서버 게이트웨이 인터페이스의 도움으로 작동합니다.
개방형 웹 애플리케이션 보안 프로젝트 (OWASP)는 웹 애플리케이션의 보안 위반 사항을 나열하는 커뮤니티입니다.
보안 위반
OWASP와 관련하여 웹 애플리케이션과 관련된 문제와 web2py가이를 극복하는 방법은 아래에서 설명합니다.
크로스 사이드 스크립팅
XSS라고도합니다. 애플리케이션이 사용자가 제공 한 데이터를 가져 와서 콘텐츠를 인코딩하거나 유효성을 검사하지 않고 사용자의 브라우저로 보낼 때마다 발생합니다. 공격자는 크로스 사이드 스크립팅을 사용하여 웜과 바이러스를 주입하는 스크립트를 실행합니다.
web2py는 렌더링 된 모든 변수를 View.
정보 유출
때때로 응용 프로그램은 내부 작업, 개인 정보 및 구성에 대한 정보를 유출합니다. 공격자는이를 사용하여 민감한 데이터를 침해하고 심각한 공격으로 이어질 수 있습니다.
web2py는 티켓팅 시스템을 통해이를 방지합니다. 모든 오류를 기록하고 오류가 등록 된 사용자에게 티켓이 발급됩니다. 이러한 오류는 관리자 만 액세스 할 수 있습니다.
깨진 인증
계정 자격 증명은 종종 보호되지 않습니다. 공격자는 사용자의 신원을 도용하기 위해 암호, 인증 토큰을 손상시킵니다.
web2py는 관리 인터페이스를위한 메커니즘을 제공합니다. 또한 클라이언트가 "localhost"가 아닌 경우 보안 세션을 사용하도록합니다.
안전하지 않은 통신
애플리케이션이 네트워크 트래픽을 암호화하지 못하는 경우가 있습니다. 민감한 통신을 보호하려면 트래픽을 관리해야합니다.
web2py는 SSL 사용 인증서를 제공하여 통신 암호화를 제공합니다. 이것은 또한 민감한 의사 소통을 유지하는 데 도움이됩니다.
URL 액세스 제한
웹 응용 프로그램은 일반적으로 일부 사용자에게 링크 및 URL 표시를 방지하여 중요한 기능을 보호합니다. 공격자는 일부 정보로 URL을 조작하여 민감한 데이터를 침해 할 수 있습니다.
wb2py에서 URL은 주어진 파일이 아닌 모듈과 기능에 매핑됩니다. 또한 공개 기능과 비공개 기능을 지정하는 메커니즘도 포함되어 있습니다. 이것은 문제 해결에 도움이됩니다.