स्पंदन - पहुँच एपीआई

स्पंदन HTTP संसाधनों का उपभोग करने के लिए http पैकेज प्रदान करता है। http एक फ्यूचर बेस्ड लाइब्रेरी है और इसमें वेट और एसिंक्स फीचर्स का उपयोग किया जाता है। यह कई उच्च स्तरीय विधियाँ प्रदान करता है और REST आधारित मोबाइल अनुप्रयोगों के विकास को सरल बनाता है।

मूल अवधारणा

http पैकेज वेब अनुरोध करने के लिए एक उच्च स्तरीय वर्ग और http प्रदान करता है।

  • HTTP वर्ग सभी प्रकार के HTTP अनुरोधों को करने के लिए कार्यक्षमता प्रदान करता है।

  • HTTP तरीके डार्ट मैप (पोस्ट डेटा, अतिरिक्त हेडर, आदि) के माध्यम से एक यूआरएल और अतिरिक्त जानकारी स्वीकार करते हैं। यह सर्वर का अनुरोध करता है और प्रतिक्रिया को वापस async / प्रतीक्षा पैटर्न में एकत्रित करता है। उदाहरण के लिए, नीचे दिया गया कोड निर्दिष्ट यूआरएल से डेटा पढ़ता है और इसे कंसोल में प्रिंट करता है।

print(await http.read('https://flutter.dev/'));

कुछ मुख्य विधियाँ इस प्रकार हैं -

  • read - GET विधि के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <String> के रूप में वापस करें

  • get- GET विधि के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <Response> के रूप में वापस करें। प्रतिक्रिया एक वर्ग है जो प्रतिक्रिया की जानकारी रखता है।

  • post - आपूर्ति किए गए डेटा को पोस्ट करके POST विधि के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <Response> के रूप में वापस करें

  • put - PUT विधि के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <Response> के रूप में वापस करें

  • head - HEAD विधि के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <Response> के रूप में वापस करें

  • delete - DELETE पद्धति के माध्यम से निर्दिष्ट url का अनुरोध करें और प्रतिक्रिया को Future <Response> के रूप में वापस करें

HTTP एक अधिक मानक HTTP क्लाइंट क्लास, क्लाइंट भी प्रदान करता है। क्लाइंट लगातार कनेक्शन का समर्थन करता है। यह तब उपयोगी होगा जब किसी विशेष सर्वर के लिए बहुत अनुरोध किया जाए। करीबी विधि का उपयोग करके इसे ठीक से बंद करने की आवश्यकता है। अन्यथा, यह http वर्ग के समान है। नमूना कोड इस प्रकार है -

var client = new http.Client(); 
try { 
   print(await client.get('https://flutter.dev/')); 
} 
finally { 
   client.close(); 
}

एक्सेस करने वाली उत्पाद सेवा एपीआई

वेब सर्वर से उत्पाद डेटा प्राप्त करने के लिए एक सरल एप्लिकेशन बनाएं और फिर सूची दृश्य का उपयोग करके उत्पादों को दिखाएं ।

  • एंड्रॉइड स्टूडियो में एक नया फ़्लटर एप्लिकेशन बनाएं , product_rest_app

  • डिफ़ॉल्ट स्टार्टअप कोड (main.dart) को हमारे product_nav_app कोड से बदलें ।

  • से फ़ोल्डर संपत्ति कॉपी product_nav_app को product_rest_app और pubspec.yaml फाइल के अंदर संपत्ति जोड़ें।

flutter: 
   assets: 
      - assets/appimages/floppy.png 
      - assets/appimages/iphone.png 
      - assets/appimages/laptop.png 
      - assets/appimages/pendrive.png 
      - assets/appimages/pixel.png 
      - assets/appimages/tablet.png
  • नीचे दिखाए गए अनुसार pubspec.yaml फ़ाइल में http पैकेज कॉन्फ़िगर करें -

dependencies: 
   http: ^0.12.0+2
  • यहां, हम http पैकेज के नवीनतम संस्करण का उपयोग करेंगे। एंड्रॉइड स्टूडियो एक पैकेज अलर्ट भेजेगा कि pubspec.yaml अपडेट किया गया है।

  • निर्भरता विकल्प प्राप्त करें पर क्लिक करें। एंड्रॉइड स्टूडियो को इंटरनेट से पैकेज मिलेगा और एप्लिकेशन के लिए इसे ठीक से कॉन्फ़िगर करना होगा।

  • मुख्य http फ़ाइल में http पैकेज आयात करें -

import 'dart:async'; 
import 'dart:convert'; 
import 'package:http/http.dart' as http;
  • एक नई JSON फ़ाइल बनाएँ, नीचे दिखाए अनुसार उत्पाद की जानकारी के साथ products.json -

[ 
   { 
      "name": "iPhone", 
      "description": "iPhone is the stylist phone ever", 
      "price": 1000, 
      "image": "iphone.png" 
   }, 
   { 
      "name": "Pixel", 
      "description": "Pixel is the most feature phone ever", 
      "price": 800, 
      "image": "pixel.png"
   }, 
   { 
      "name": "Laptop", 
      "description": "Laptop is most productive development tool", 
      "price": 2000, 
      "image": "laptop.png" 
   }, 
   { 
      "name": "Tablet", 
      "description": "Tablet is the most useful device ever for meeting", 
      "price": 1500, 
      "image": "tablet.png" 
   }, 
   { 
      "name": "Pendrive", 
      "description": "Pendrive is useful storage medium", 
      "price": 100, 
      "image": "pendrive.png" 
   }, 
   { 
      "name": "Floppy Drive", 
      "description": "Floppy drive is useful rescue storage medium", 
      "price": 20, 
      "image": "floppy.png" 
   } 
]
  • एक नया फ़ोल्डर, JSONWebServer बनाएँ और JSON फ़ाइल, products.json लगाएं।

  • JSONWebServer के साथ किसी भी वेब सर्वर को रूट निर्देशिका के रूप में चलाएं और इसका वेब पथ प्राप्त करें। उदाहरण के लिए, http://192.168.184.1:8000/products.json। हम किसी भी वेब सर्वर का उपयोग कर सकते हैं जैसे अपाचे, नग्नेक्स आदि।

  • सबसे आसान तरीका है नोड आधारित http-server एप्लिकेशन इंस्टॉल करना। Http- सर्वर एप्लिकेशन को स्थापित करने और चलाने के लिए नीचे दिए गए चरणों का पालन करें

    • Nodejs एप्लिकेशन इंस्टॉल करें ( nodejs.org )

    • JSONWebServer फ़ोल्डर पर जाएं।

cd /path/to/JSONWebServer
  • Npm का उपयोग करके http-server पैकेज स्थापित करें।

npm install -g http-server
  • अब, सर्वर चलाएं।

http-server . -p 8000 

Starting up http-server, serving . 
Available on: 
   http://192.168.99.1:8000
   http://127.0.0.1:8000 
   Hit CTRL-C to stop the server
  • एक नया फ़ाइल, Product.dart को लेबर फ़ोल्डर में बनाएँ और उसमें उत्पाद वर्ग को स्थानांतरित करें।

  • मैप किए गए डेटा मैप को प्रोडक्ट ऑब्जेक्ट में बदलने के लिए प्रोडक्ट क्लास, Product.fromMap में एक फैक्ट्री कंस्ट्रक्टर लिखें। आम तौर पर, JSON फाइल को डार्ट मैप ऑब्जेक्ट में और फिर संबंधित ऑब्जेक्ट (उत्पाद) में परिवर्तित किया जाएगा।

factory Product.fromJson(Map<String, dynamic> data) {
   return Product(
      data['name'],
      data['description'], 
      data['price'],
      data['image'],
   );
}
  • Product.dart का पूरा कोड इस प्रकार है -

class Product {
   final String name; 
   final String description;
   final int price;
   final String image; 
   
   Product(this.name, this.description, this.price, this.image); 
   factory Product.fromMap(Map<String, dynamic> json) { 
      return Product( 
         json['name'], 
         json['description'], 
         json['price'], 
         json['image'], 
      );
   }
}
  • दो तरीके लिखें - parseProducts और fetchProducts - वेब सर्वर से उत्पाद जानकारी को सूची <उत्पाद> ऑब्जेक्ट में लाने और लोड करने के लिए मुख्य वर्ग में।

List<Product> parseProducts(String responseBody) { 
   final parsed = json.decode(responseBody).cast<Map<String, dynamic>>(); 
   return parsed.map<Product>((json) =>Product.fromJson(json)).toList(); 
} 
Future<List<Product>> fetchProducts() async { 
   final response = await http.get('http://192.168.1.2:8000/products.json'); 
   if (response.statusCode == 200) { 
      return parseProducts(response.body); 
   } else { 
      throw Exception('Unable to fetch products from the REST API');
   } 
}
  • निम्नलिखित बिंदुओं पर ध्यान दें -

    • भविष्य का उपयोग उत्पाद जानकारी को आलसी करने के लिए किया जाता है। आलसी लोडिंग एक अवधारणा है जब तक यह आवश्यक नहीं है कोड के निष्पादन को स्थगित करना।

    • http.get का उपयोग इंटरनेट से डेटा लाने के लिए किया जाता है।

    • json.decode का उपयोग DSON मैप ऑब्जेक्ट में JSON डेटा को डीकोड करने के लिए किया जाता है। JSON डेटा के डिकोड होने के बाद, इसे उत्पाद वर्ग के मानचित्र से उपयोग करके इसे सूची <Product> में बदल दिया जाएगा।

    • MyApp वर्ग में, नए सदस्य चर, भविष्य के उत्पाद <उत्पाद> को जोड़ें और इसे निर्माता में शामिल करें।

class MyApp extends StatelessWidget { 
   final Future<List<Product>> products; 
   MyApp({Key key, this.products}) : super(key: key); 
   ...
  • MyHomePage क्लास में, Future <Product> प्रकार के नए सदस्य वैरिएबल उत्पाद जोड़ें और इसे कंस्ट्रक्टर में शामिल करें। इसके अलावा, आइटम चर और इसकी संबंधित विधि को हटा दें, getProducts विधि कॉल करें। कंस्ट्रक्टर में प्रोडक्ट्स वैरिएबल में रखें। यह केवल पहली बार आवेदन शुरू होने पर केवल एक बार इंटरनेट से उत्पादों को लाने की अनुमति देगा।

class MyHomePage extends StatelessWidget { 
   final String title; 
   final Future<ListList<Product>> products; 
   MyHomePage({Key key, this.title, this.products}) : super(key: key); 
   ...
  • उपरोक्त परिवर्तनों को समायोजित करने के लिए MyApp विजेट की बिल्ड विधि में होम विकल्प (MyHomePage) बदलें -

home: MyHomePage(title: 'Product Navigation demo home page', products: products),
  • भविष्य <उत्पाद> तर्कों को शामिल करने के लिए मुख्य फ़ंक्शन बदलें -

void main() => runApp(MyApp(fetchProduct()));
  • होम पेज में उत्पाद सूची बनाने के लिए एक नया विजेट, प्रोडक्टबॉक्सलिस्ट बनाएं।

class ProductBoxList extends StatelessWidget { 
   final List<Product> items;
   ProductBoxList({Key key, this.items}); 
   
   @override 
   Widget build(BuildContext context) {
      return ListView.builder(
         itemCount: items.length,
         itemBuilder: (context, index) {
            return GestureDetector(
               child: ProductBox(item: items[index]), 
               onTap: () {
                  Navigator.push(
                     context, MaterialPageRoute(
                        builder: (context) =gt; ProductPage(item: items[index]), 
                     ), 
                  ); 
               }, 
            ); 
         }, 
      ); 
   } 
}

ध्यान दें कि हमने उत्पाद को सूचीबद्ध करने के लिए नेविगेशन एप्लिकेशन में उपयोग की जाने वाली एक ही अवधारणा का उपयोग किया है, इसके अलावा यह सूची <उत्पाद> के उत्पादों (ऑब्जेक्ट) को पास करके एक अलग विजेट के रूप में डिज़ाइन किया गया है।

  • अंत में, सामान्य विधि कॉल के बजाय भविष्य के विकल्प का उपयोग करके उत्पाद जानकारी प्राप्त करने के लिए MyHomePage विजेट की बिल्ड विधि को संशोधित करें।

Widget build(BuildContext context) { 
   return Scaffold(
      appBar: AppBar(title: Text("Product Navigation")),
      body: Center(
         child: FutureBuilder<List<Product>>(
            future: products, builder: (context, snapshot) {
               if (snapshot.hasError) print(snapshot.error); 
               return snapshot.hasData ? ProductBoxList(items: snapshot.data)
               
               // return the ListView widget : 
               Center(child: CircularProgressIndicator()); 
            }, 
         ), 
      )
   ); 
}
  • यहां ध्यान दें कि हमने विजेट रेंडर करने के लिए FutureBuilder विजेट का उपयोग किया है। FutureBuilder यह भविष्य की संपत्ति (भविष्य के प्रकार <सूची <उत्पाद >>) से डेटा लाने की कोशिश करेगा। यदि भविष्य की संपत्ति डेटा वापस करती है, तो वह ProductBoxList का उपयोग करके विजेट को प्रस्तुत करेगा, अन्यथा एक त्रुटि फेंकता है।

  • Main.dart का पूरा कोड इस प्रकार है -

import 'package:flutter/material.dart'; 
import 'dart:async'; 
import 'dart:convert'; 
import 'package:http/http.dart' as http; 
import 'Product.dart'; 

void main() => runApp(MyApp(products: fetchProducts())); 

List<Product> parseProducts(String responseBody) { 
   final parsed = json.decode(responseBody).cast<Map<String, dynamic>>(); 
   return parsed.map<Product>((json) => Product.fromMap(json)).toList(); 
} 
Future<List<Product>> fetchProducts() async { 
   final response = await http.get('http://192.168.1.2:8000/products.json'); 
   if (response.statusCode == 200) { 
      return parseProducts(response.body); 
   } else { 
      throw Exception('Unable to fetch products from the REST API'); 
   } 
}
class MyApp extends StatelessWidget {
   final Future<List<Product>> products; 
   MyApp({Key key, this.products}) : super(key: key); 
   
   // This widget is the root of your application. 
   @override 
   Widget build(BuildContext context) {
      return MaterialApp(
         title: 'Flutter Demo', 
         theme: ThemeData( 
            primarySwatch: Colors.blue, 
         ), 
         home: MyHomePage(title: 'Product Navigation demo home page', products: products), 
      ); 
   }
}
class MyHomePage extends StatelessWidget { 
   final String title; 
   final Future<List<Product>> products; 
   MyHomePage({Key key, this.title, this.products}) : super(key: key); 
   
   // final items = Product.getProducts();
   @override 
   Widget build(BuildContext context) { 
      return Scaffold(
         appBar: AppBar(title: Text("Product Navigation")), 
         body: Center(
            child: FutureBuilder<List<Product>>(
               future: products, builder: (context, snapshot) {
                  if (snapshot.hasError) print(snapshot.error); 
                  return snapshot.hasData ? ProductBoxList(items: snapshot.data) 
                  
                  // return the ListView widget : 
                  Center(child: CircularProgressIndicator()); 
               },
            ),
         )
      );
   }
}
class ProductBoxList extends StatelessWidget {
   final List<Product> items; 
   ProductBoxList({Key key, this.items}); 
   
   @override 
   Widget build(BuildContext context) {
      return ListView.builder(
         itemCount: items.length, 
         itemBuilder: (context, index) { 
            return GestureDetector( 
               child: ProductBox(item: items[index]), 
               onTap: () { 
                  Navigator.push(
                     context, MaterialPageRoute( 
                        builder: (context) => ProductPage(item: items[index]), 
                     ), 
                  ); 
               }, 
            ); 
         }, 
      ); 
   } 
} 
class ProductPage extends StatelessWidget { 
   ProductPage({Key key, this.item}) : super(key: key); 
   final Product item; 
   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(title: Text(this.item.name),), 
         body: Center( 
            child: Container(
               padding: EdgeInsets.all(0), 
               child: Column( 
                  mainAxisAlignment: MainAxisAlignment.start, 
                  crossAxisAlignment: CrossAxisAlignment.start, 
                  children: <Widget>[
                     Image.asset("assets/appimages/" + this.item.image), 
                     Expanded( 
                        child: Container( 
                           padding: EdgeInsets.all(5), 
                           child: Column( 
                              mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
                              children: <Widget>[ 
                                 Text(this.item.name, style: 
                                    TextStyle(fontWeight: FontWeight.bold)), 
                                 Text(this.item.description), 
                                 Text("Price: " + this.item.price.toString()), 
                                 RatingBox(), 
                              ], 
                           )
                        )
                     ) 
                  ]
               ), 
            ), 
         ), 
      ); 
   } 
}
class RatingBox extends StatefulWidget { 
   @override 
   _RatingBoxState createState() =>_RatingBoxState(); 
} 
class _RatingBoxState extends State<RatingBox> { 
   int _rating = 0; 
   void _setRatingAsOne() {
      setState(() { 
         _rating = 1; 
      }); 
   }
   void _setRatingAsTwo() {
      setState(() {
         _rating = 2; 
      }); 
   }
   void _setRatingAsThree() { 
      setState(() {
         _rating = 3; 
      }); 
   }
   Widget build(BuildContext context) {
      double _size = 20; 
      print(_rating); 
      return Row(
         mainAxisAlignment: MainAxisAlignment.end, 
         crossAxisAlignment: CrossAxisAlignment.end, 
         mainAxisSize: MainAxisSize.max, 
         
         children: <Widget>[
            Container(
               padding: EdgeInsets.all(0), 
               child: IconButton( 
                  icon: (
                     _rating >= 1 
                     ? Icon(Icons.star, ize: _size,) 
                     : Icon(Icons.star_border, size: _size,)
                  ), 
                  color: Colors.red[500], onPressed: _setRatingAsOne, iconSize: _size, 
               ), 
            ), 
            Container(
               padding: EdgeInsets.all(0), 
               child: IconButton(
                  icon: (
                     _rating >= 2 
                     ? Icon(Icons.star, size: _size,) 
                     : Icon(Icons.star_border, size: _size, )
                  ), 
                  color: Colors.red[500], 
                  onPressed: _setRatingAsTwo, 
                  iconSize: _size, 
               ), 
            ), 
            Container(
               padding: EdgeInsets.all(0), 
               child: IconButton(
                  icon: (
                     _rating >= 3 ? 
                     Icon(Icons.star, size: _size,)
                     : Icon(Icons.star_border, size: _size,)
                  ), 
                  color: Colors.red[500], 
                  onPressed: _setRatingAsThree, 
                  iconSize: _size, 
               ), 
            ), 
         ], 
      ); 
   } 
}
class ProductBox extends StatelessWidget {
   ProductBox({Key key, this.item}) : super(key: key); 
   final Product item; 
   
   Widget build(BuildContext context) {
      return Container(
         padding: EdgeInsets.all(2), height: 140, 
         child: Card(
            child: Row( 
               mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
               children: <Widget>[
                  Image.asset("assets/appimages/" + this.item.image), 
                  Expanded( 
                     child: Container( 
                        padding: EdgeInsets.all(5), 
                        child: Column( 
                           mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
                           children: <Widget>[ 
                              Text(this.item.name, style:TextStyle(fontWeight: FontWeight.bold)), 
                              Text(this.item.description), 
                              Text("Price: " + this.item.price.toString()), 
                              RatingBox(), 
                           ], 
                        )
                     )
                  )
               ]
            ), 
         )
      ); 
   } 
}

परिणाम देखने के लिए अंत में एप्लिकेशन को चलाएं। यह हमारे नेविगेशन उदाहरण के समान होगा सिवाय डेटा के जो कि स्थानीय से बजाय इंटरनेट से है, स्थैतिक डेटा अनुप्रयोग को कोड करते समय दर्ज किया गया है।