Web2py - कोर

कमांड लाइन विकल्प

हमने सीखा है कि पिछले अध्याय में GUI विजेट का उपयोग करके web2py सर्वर कैसे शुरू किया जाए।

सर्वर शुरू करने से इस विजेट को छोड़ दिया जा सकता है command line प्रेरित करना।

python web2py.py -a 'password' -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 को एक विशिष्ट रूप में मैप करता है - 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 अनुरोध शीर्ष लेख को पार्स किया जाता है और डिस्पैचर में भेज दिया जाता है।

  • डिस्पैचर एप्लिकेशन के अनुरोधों का प्रबंधन करता है और मैप करता है PATH_INFOफ़ंक्शन कॉल के URL में। प्रत्येक फ़ंक्शन कॉल को URL में दर्शाया गया है।

  • स्थिर फ़ोल्डर में शामिल फ़ाइलों के सभी अनुरोधों को सीधे प्रबंधित किया जाता है, और बड़ी फ़ाइल क्लाइंट को स्ट्रीम की जाती है।

  • किसी भी चीज़ के लिए अनुरोध लेकिन एक स्थिर फ़ाइल को एक कार्रवाई में मैप किया जाता है।

  • यदि अनुरोध हेडर में ऐप के लिए एक सत्र कुकी होती है, तो सत्र ऑब्जेक्ट पुनर्प्राप्त होता है; या फिर, एक सत्र आईडी बनाई जाती है।

  • यदि क्रिया स्ट्रिंग के रूप में मान लौटाती है, तो यह क्लाइंट को वापस कर दिया जाता है।

  • यदि क्रिया पुन: चलने योग्य है, तो इसका उपयोग क्लाइंट को डेटा को लूप और स्ट्रीम करने के लिए किया जाता है।

सशर्त मॉडल

पिछले अध्याय में, हमने इसकी कार्यक्षमता देखी Controllers। web2py अपने प्रत्येक एप्लिकेशन में मॉडल, दृश्य और नियंत्रक का उपयोग करता है। इसलिए, की कार्यक्षमता को समझना भी आवश्यक हैModel

किसी भी अन्य एमवीसी एप्लिकेशन के विपरीत, 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 में लाइब्रेरी शामिल हैं, जो ऑब्जेक्ट के रूप में सभी एप्लिकेशन के संपर्क में हैं। इन वस्तुओं को "ग्लूऑन" नाम की निर्देशिका के तहत मुख्य फाइलों के अंदर परिभाषित किया गया है।

डीएएल टेम्पलेट जैसे कई मॉड्यूलों की कोई निर्भरता नहीं है और इसे वेब 2 पी के ढांचे के बाहर लागू किया जा सकता है। यह इकाई परीक्षणों को भी बनाए रखता है जिसे अच्छा अभ्यास माना जाता है।

अनुप्रयोग

web2py अनुप्रयोगों को एक आरेखीय रूप में नीचे दिखाया गया है।

Applications web2py में विकसित निम्नलिखित भागों से बना है -

  • Models - डेटा और डेटाबेस तालिकाओं का प्रतिनिधित्व करता है।

  • Controllers - एप्लिकेशन लॉजिक और वर्कफ़्लो का वर्णन करता है।

  • Views - डेटा के प्रदर्शन को प्रस्तुत करने में मदद करता है।

  • Languages - विभिन्न समर्थित भाषाओं में आवेदन में तार का अनुवाद कैसे करें, इसका वर्णन करें।

  • Static files - प्रसंस्करण की आवश्यकता नहीं है (उदाहरण के चित्र, सीएसएस शैली पत्रक आदि)।

  • ABOUT तथा README - परियोजना का विवरण।

  • Errors - स्टोर त्रुटि रिपोर्ट आवेदन द्वारा उत्पन्न।

  • Sessions - प्रत्येक विशेष उपयोगकर्ता से संबंधित जानकारी संग्रहीत करता है।

  • Databases - SQLite डेटाबेस और अतिरिक्त तालिका जानकारी संग्रहीत करें।

  • Cache - स्टोर कैश्ड एप्लिकेशन आइटम।

  • Modules - मॉड्यूल अन्य वैकल्पिक पायथन मॉड्यूल हैं।

  • Private - शामिल फाइलों को नियंत्रकों द्वारा एक्सेस किया जाता है लेकिन सीधे डेवलपर द्वारा नहीं।

  • Uploads - फाइलों को मॉडल द्वारा एक्सेस किया जाता है लेकिन सीधे डेवलपर द्वारा नहीं।

एपीआई

Web2py में, models, controllers तथा views एक ऐसे वातावरण में निष्पादित किया जाता है जहां कुछ वस्तुओं को डेवलपर्स के लिए आयात किया जाता है।

Global Objects - अनुरोध, प्रतिक्रिया, सत्र, कैश।

Helpers- web2py में हेल्पर क्लास शामिल है, जिसका उपयोग HTML प्रोग्रामेटिक रूप से करने के लिए किया जा सकता है। यह HTML टैग्स से मेल खाता है, जिसे टर्मिनेट किया जाता है“HTML helpers”

उदाहरण के लिए, A, B, FIELDSET, FORM, आदि।

अधिवेशन

एक सत्र को सूचना के सर्वर-साइड स्टोरेज के रूप में परिभाषित किया जा सकता है, जो पूरे वेब एप्लिकेशन में उपयोगकर्ता के इंटरैक्शन में बना रहता है।

Web2py में सत्र भंडारण वर्ग का उदाहरण है।

उदाहरण के लिए, एक चर को सत्र के रूप में संग्रहीत किया जा सकता है

session.myvariable = "hello"

इस मान को पुनः प्राप्त किया जा सकता है

a = session.myvariable

चर के मूल्य को तब तक पुनर्प्राप्त किया जा सकता है जब तक कि एक ही उपयोगकर्ता द्वारा एक ही सत्र में कोड निष्पादित किया जाता है।

सत्र के लिए web2py में महत्वपूर्ण विधियों में से एक है “forget” -

session.forget(response);

यह web2py सत्र को बचाने के लिए नहीं निर्देश देता है।

बैकग्राउंड में रनिंग टास्क

एक HTTP अनुरोध वेब सर्वर पर आता है, जो समानांतर में प्रत्येक अनुरोध को अपने स्वयं के थ्रेड में संभालता है। कार्य, जो सक्रिय है, अग्रभूमि में होता है जबकि अन्य पृष्ठभूमि में रखा जाता है। पृष्ठभूमि कार्यों का प्रबंधन भी web2py की मुख्य विशेषताओं में से एक है।

समय लेने वाले कार्यों को अधिमानतः पृष्ठभूमि में रखा गया है। कुछ तंत्र निम्नानुसार सूचीबद्ध हैं, जो पृष्ठभूमि कार्यों का प्रबंधन करते हैं -

  • CRON

  • Queues

  • Scheduler

क्रॉन

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 इसके आउटपुट के साथ अगले अध्याय में चर्चा की जाएगी।