फ्लास्क फ्रेमवर्क

फ्लास्क माइक्रो-फ्रेमवर्क है जिसकी बाहरी पुस्तकालयों पर बहुत कम निर्भरता है। यह एक बहुत ही हल्का ढांचा है और हमें जो कुछ भी चाहिए उसे करने की स्वतंत्रता देता है।

इस अध्याय में, हम पायथन और फ्लास्क ढांचे का उपयोग करके एक परियोजना का निर्माण करने जा रहे हैं।

फ्लास्क स्टार्टअप और कॉन्फ़िगरेशन

सबसे अधिक व्यापक रूप से उपयोग किए जाने वाले अजगर पुस्तकालयों की तरह, फ्लास्क पैकेज पायथन पैकेज इंडेक्स (पीपीआई) से स्थापित करने योग्य है। पहले एक निर्देशिका बनाते हैं (इस अध्याय में, हमने एक निर्देशिका बनाई है जिसे कहा जाता हैflaskProject) फिर एक आभासी वातावरण बनाया (और इसे कहा जाता है flaskEnv) जहां परियोजना संबंधी सभी निर्भरताएँ लोड की जाएंगी (फ्लास्क सहित)। आप फ्लास्क- sqlalchemy भी स्थापित कर सकते हैं ताकि आपके फ्लास्क एप्लिकेशन में SQL डेटाबेस के साथ संवाद करने का एक सरल तरीका हो।

फ्लास्क को स्थापित करने के बाद, आपका फ्लास्कएन्विव (हमारा वर्चुअलीवर्जन नाम) कुछ इस तरह दिखाएगा -

फ्लास्क के साथ एक ऐप बनाना

फ्लास्क स्थापित करके, हम एक सरल बना सकते हैं ”hello application in flask"कोड की बहुत कम पंक्तियों के साथ इस प्रकार है -

टर्मिनल में निम्नलिखित टाइप करें -

$python flaskapp.py

और आप निम्न आउटपुट देख सकते हैं -

पर चल रहा है http://127.0.0.1:5000/ या पर localhost:5000

नीचे हमने अपने उदाहरण कोड में क्या किया, इसकी व्याख्या है -

  • सबसे पहले, हम फ्लास्क क्लास लाइब्रेरी आयात करते हैं। इस वर्ग का एक उदाहरण WSGI ऐप है।

  • दूसरे, हम इस वर्ग का एक उदाहरण बनाते हैं। एप्लिकेशन पैकेज या मॉड्यूल नाम हमारा पहला तर्क है। यह अनिवार्य है कि फ्लास्क जानता है कि स्थिर फाइलें, टेम्प्लेट और अन्य फाइलें कहां मिलेंगी।

  • अगला मार्ग है () डेकोरेटर जिसका उपयोग हम यह जानने के लिए करते हैं कि किस URL को हमारी विधि / फ़ंक्शन को ट्रिगर करना चाहिए।

URL रूटिंग बनाना

URL रूटिंग आपके वेब ऐप में URL को याद रखने में आसान बनाता है। अब हम कुछ URL रूट बनाएंगे -

/hello
/members
/members/name

हम उपरोक्त URL के आधार पर निम्नलिखित कोड लिख सकते हैं और इसे app.py के रूप में सहेज सकते हैं।

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
   return "Index!"
	
@app.route('/Hello')
def hello():
   return "Hello, World!"
	
@app.route("/members")
def members():
   return "Members"
	
@app.route("/members/<name>/")
def getMember(name):
   return name
	
if __name__ == '__main__':
   app.run(debug=True)
आवेदन को पुनः आरंभ करने पर, हम विभिन्न URL पर विभिन्न आउटपुट प्राप्त करने के लिए कोड की निचली पंक्तियों का उपयोग करते हैं -

$ python app.py

Running on http://localhost:5000/

हम अपने ब्राउज़र में निम्न आउटपुट प्राप्त करेंगे -

हम अपने ब्राउज़र में अन्य URL को इस प्रकार आज़मा सकते हैं -

Running on http://localhost:5000/hello, will give the following output −

Running on http://localhost:5000/members, will give −

Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −

लेकिन आम तौर पर हम एक स्ट्रिंग (जैसा कि ऊपर) वापस नहीं करना चाहते हैं, हम टेम्पलेट्स लौटाते हैं। इसके लिए हम एक फ़ंक्शन का उपयोग करना चाहते हैं ”render_templateफ्लास्क से, और कुछ इनपुट के साथ render_template लौटाएं। तो, नीचे कार्य हमारे काम करेगा -

from flask import render_template
return render_template(‘home.html’)

आइए हम एक फ़ोल्डर टेम्पलेट बनाते हैं और उसमें home.html फ़ाइल डालते हैं।

अगला, हम लेआउट के बारे में चर्चा करेंगे। हर एक टेम्पलेट के लिए html हेड टैग और बॉडी टैग का उपयोग करने के बजाय, हम हेड एंड बॉडी टैग को शामिल करने के लिए एक लेआउट डिज़ाइन करेंगे और वर्तमान दृश्यों या वर्तमान टेम्पलेट को लपेटेंगे। उसके लिए हमें एक अलग फाइल बनानी होगी और उसे कॉल करना होगाlayout.html। इसमें हम अपना सामान्य हेड टैग, बॉडी टैग और अन्य सभी आवश्यक टैग लगा सकते हैं।

हम कोड की निम्नलिखित पंक्तियों के साथ अपना नया लेआउट.html बना सकते हैं -

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>MyFlaskApp</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
   </head>
   <body>
      {% include 'includes/_navbar.html' %}
      <div class="container">
      {% block body %}
      {% endblock %}
      </div>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
      </script>
   </body>
</html>

उपरोक्त कोड में, हमने टाइटल ट्रैक, MyFlaskAp, सिर में css cdn और बूट ब्लॉक को सक्षम करने के लिए बॉडी ब्लॉक में जावास्क्रिप्ट का उपयोग किया है।

अब, हमें हर एक पेज के लिए नेवबार बनाना है। उसके लिए, हमें पहले एक सम्मिलित फ़ोल्डर बनाना होगा और फिर उसके अंदर _navbar.html फ़ाइल बनाना होगा। अब _navbar.html में, हमें getbootstrap.com से मानक स्टार्टर टेम्पलेट का उपयोग करना होगा। नव निर्मित _navbar.html फ़ाइल निम्नानुसार होगी -

और इस _navbar.html फ़ाइल को हमारे layout.html फ़ाइल में शामिल करें।

{% include 'includes/_navbar.html' %}

जैसा कि हमारे पास लेआउट ब्लॉक है, हम इस ब्लॉक को अपनी होम फाइल (home.html) में बढ़ा सकते हैं।

नीचे दिए गए कोड का उपयोग करके हमारी home.html फ़ाइल बनाई जा सकती है -

{% extends 'layout.html' %}
{% block body %}
   <div class="jumbotron text-center">
      <h1>Welcome to FlaskApp</h1>
      <p>This application is built on Flask webframework!</p>
   </div>
{% endblock %}

इसका उपयोग करते हुए यदि हम अपनी फ्लास्कैपहोम फ़ाइल चलाने की कोशिश करते हैं, तो हम अपने ब्राउज़र में निम्न आउटपुट देख सकते हैं -

अब हम सक्रिय करना चाहते हैं (वर्तमान में टैब काम नहीं कर रहे हैं) हमारे aboutटैब। लगभग टैब के लिए एक मार्ग बनाएँ और एक टेम्पलेट फ़ाइल बनाएँ,about.html

Appflask.py में टैब रूट के बारे में नीचे दिखाया गया है -

about.html फ़ाइल में नीचे दी गई सामग्री होगी -

इसलिए होम और अब के बारे में ध्यान रखा जाता है। लेखों के लिए, हम रूट डायरेक्टरी में एक नई फ़ाइल (data.py) बना सकते हैं, जहाँ हम डेटा डालते हैं और इसे अपने वेबपेज में कॉल करते हैं।

data.py

def Articles():
   articles = [
      {
         'uid': 1,
         'title': 'Article_One',
         'body': 'Flask, being a microframework, often requires some repetitive step
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Rajesh Joshi',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 2,
         'title': 'Article_Two',
         'body': "Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.",
         'Author': 'Rajesh J',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 3,
         'title': 'Article_Three',
         'body': 'Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could be
            abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Joshi Rajesh',
         'Created-on': '07-09-2018'
      }
   ]
   return articles

नीचे के लिए कोड है articles.html, जो प्रत्येक यूआईडी के लिए लेख शीर्षक प्रदर्शित करेगा।

{% extends 'layout.html' %}
{% block body %}
   <h1>Articles</h1>
   {% for article in articles %}
      <li class="list-group-item">
         <a href="article/{{article.uid}}"> {{article.title}}</a>
      </li>
   {% endfor %}
{% endblock %}

संक्षेप में, फ्लास्क अपने हल्के होने के कारण सबसे लोकप्रिय अजगर वेब फ्रेमवर्क में से एक है। हालांकि यह माइक्रो है यह एक एक्स्टेंसिबल पायथन वेब फ्रेमवर्क है। आवश्यक कार्यक्षमता प्रदान करके, फ्लास्क सरल वेब अनुप्रयोग के विकास को तेज करता है। तो फ्लास्क, छोटे, कम जटिल अनुप्रयोगों के लिए अधिक उपयुक्त है।