Android - सामग्री प्रदाता

एक सामग्री प्रदाता घटक अनुरोध पर एक आवेदन से दूसरे में डेटा की आपूर्ति करता है। ऐसे अनुरोध ContentResolver वर्ग की विधियों द्वारा नियंत्रित किए जाते हैं। एक सामग्री प्रदाता अपने डेटा को संग्रहीत करने के लिए विभिन्न तरीकों का उपयोग कर सकता है और डेटा को डेटाबेस में, फाइलों में, या यहां तक ​​कि एक नेटवर्क पर संग्रहीत किया जा सकता है।

सामग्री प्रदाता

sometimes it is required to share data across applications. This is where content providers become very useful.

सामग्री प्रदाता आपको एक ही स्थान पर सामग्री को केंद्रीकृत करने की अनुमति देते हैं और कई अलग-अलग अनुप्रयोग इसे आवश्यकतानुसार एक्सेस करते हैं। एक सामग्री प्रदाता एक डेटाबेस की तरह बहुत व्यवहार करता है जहां आप इसे क्वेरी कर सकते हैं, इसकी सामग्री को संपादित कर सकते हैं, साथ ही सम्मिलित (), अपडेट (), हटाएं (), और क्वेरी () विधियों का उपयोग करके सामग्री को जोड़ या हटा सकते हैं। ज्यादातर मामलों में यह डेटा एक में संग्रहीत किया जाता हैSQlite डेटाबेस।

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

public class My Application extends  ContentProvider {
}

सामग्री यू.आर.आई.

किसी कंटेंट प्रोवाइडर को क्वेरी करने के लिए, आप एक यूआरआई के रूप में क्वेरी स्ट्रिंग को निर्दिष्ट करते हैं जिसमें निम्न प्रारूप होता है -

<prefix>://<authority>/<data_type>/<id>

यहाँ URI के विभिन्न भागों का विवरण दिया गया है -

अनु क्रमांक भाग विवरण
1

prefix

यह हमेशा सामग्री पर सेट होता है: //

2

authority

यह सामग्री प्रदाता का नाम निर्दिष्ट करता है, उदाहरण के लिए संपर्क , ब्राउज़र आदि। तृतीय-पक्ष सामग्री प्रदाताओं के लिए, यह पूरी तरह से योग्य नाम हो सकता है, जैसे com.tutorialspoint.statusprovider

3

data_type

यह उस डेटा के प्रकार को इंगित करता है जो यह विशेष प्रदाता प्रदान करता है। उदाहरण के लिए, यदि आप संपर्क सामग्री प्रदाता से सभी संपर्क प्राप्त कर रहे हैं , तो डेटा पथ लोग होंगे और यूआरआई इस सामग्री की तरह दिखाई देगा : // संपर्क / लोग

4

id

यह अनुरोधित विशिष्ट रिकॉर्ड को निर्दिष्ट करता है। उदाहरण के लिए, यदि आप संपर्क सामग्री प्रदाता में संपर्क नंबर 5 की तलाश कर रहे हैं तो URI इस सामग्री की तरह दिखाई देगा : // संपर्क / लोग / 5

कंटेंट प्रोवाइडर बनाएं

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

  • सबसे पहले आपको एक कंटेंट प्रोवाइडर क्लास बनाने की जरूरत है जो कि कंटेंटप्रोवाइडरबैसेकल्स को बढ़ाती है।

  • दूसरा, आपको अपने सामग्री प्रदाता यूआरआई पते को परिभाषित करने की आवश्यकता है जिसका उपयोग सामग्री तक पहुंचने के लिए किया जाएगा।

  • आगे आपको सामग्री रखने के लिए अपना खुद का डेटाबेस बनाना होगा। आमतौर पर, एंड्रॉइड SQLite डेटाबेस का उपयोग करता है और फ्रेमवर्क को ऑनक्रिएट () विधि को ओवरराइड करने की आवश्यकता होती है जो प्रदाता के डेटाबेस को बनाने या खोलने के लिए SQLite ओपन हेल्पर विधि का उपयोग करेगा। जब आपका एप्लिकेशन लॉन्च किया जाता है, तो उसके प्रत्येक सामग्री प्रदाता के ऑनक्रीट () हैंडलर को मुख्य एप्लिकेशन थ्रेड पर बुलाया जाता है।

  • आगे आपको विभिन्न डेटाबेस विशिष्ट संचालन करने के लिए सामग्री प्रदाता प्रश्नों को लागू करना होगा।

  • अंत में <प्रदाता> टैग का उपयोग करके अपनी सामग्री प्रदाता को अपनी गतिविधि फ़ाइल में पंजीकृत करें।

यहां उन तरीकों की सूची दी गई है, जिन्हें आपको अपने कंटेंट प्रोवाइडर के काम करने के लिए कंटेंट प्रोवाइडर वर्ग में ओवरराइड करने की आवश्यकता है -

सामग्री प्रदाता

  • onCreate() जब प्रदाता शुरू किया जाता है तो इस विधि को कहा जाता है।

  • query()यह विधि क्लाइंट से अनुरोध प्राप्त करती है। परिणाम को Cursor ऑब्जेक्ट के रूप में लौटाया जाता है।

  • insert()यह विधि सामग्री प्रदाता में एक नया रिकॉर्ड सम्मिलित करती है।

  • delete() यह विधि सामग्री प्रदाता से मौजूदा रिकॉर्ड को हटा देती है।

  • update() यह विधि सामग्री प्रदाता से मौजूदा रिकॉर्ड को अपडेट करती है।

  • getType() यह विधि दिए गए URI में MIME प्रकार का डेटा लौटाती है।

उदाहरण

यह उदाहरण आपको बताएगा कि अपना खुद का ContentProvider कैसे बनाया जाए । तो चलिए नमस्ते वर्ल्ड उदाहरण बनाते समय हमने जो कुछ भी अनुसरण किया है उसके समान निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 आप Android StudioIDE का उपयोग एंड्रॉइड एप्लिकेशन बनाने के लिए करेंगे और इसे एक पैकेज com.example.MyApplication के तहत My Application के रूप में नाम देंगे , जिसमें रिक्त गतिविधि है।
2 दो नए तरीकों onClickAddName () और onClickRetrieveStudents () को जोड़ने के लिए मुख्य गतिविधि फ़ाइल MainActivity.java को संशोधित करें ।
3 अपने वास्तविक प्रदाता और संबंधित तरीकों को परिभाषित करने के लिए पैकेज com.example.MyApplication के तहत StudentsProvider.java नामक एक नई जावा फ़ाइल बनाएँ ।
4 अपने प्रदाता को अपने AndroidManifest.xml फ़ाइल में <प्रदाता ... /> टैग का उपयोग करके पंजीकृत करें
5 छात्रों के रिकॉर्ड को जोड़ने के लिए छोटे GUI को शामिल करने के लिए Res / Layout / activity_main.xml फ़ाइल की डिफ़ॉल्ट सामग्री को संशोधित करें ।
6 String.xml को बदलने की कोई आवश्यकता नहीं है।और थायराइड स्टूडियो string.xml फ़ाइल का ध्यान रखता है।
7 एंड्रॉइड एमुलेटर लॉन्च करने के लिए एप्लिकेशन चलाएं और एप्लिकेशन में किए गए परिवर्तनों के परिणाम की पुष्टि करें।

निम्नलिखित संशोधित मुख्य गतिविधि फ़ाइल की सामग्री है src/com.example.MyApplication/MainActivity.java। यह फ़ाइल मूलभूत जीवन चक्र विधियों में से प्रत्येक को शामिल कर सकती है। हमने एप्लिकेशन के साथ उपयोगकर्ता इंटरैक्शन को संभालने के लिए दो नए तरीके onClickAddName () और onClickRetrieveStudents () जोड़े हैं

package com.example.MyApplication;

import android.net.Uri;
import android.os.Bundle;
import android.app.Activity;

import android.content.ContentValues;
import android.content.CursorLoader;

import android.database.Cursor;

import android.view.Menu;
import android.view.View;

import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends Activity {

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
   }
   public void onClickAddName(View view) {
      // Add a new student record
      ContentValues values = new ContentValues();
      values.put(StudentsProvider.NAME,
         ((EditText)findViewById(R.id.editText2)).getText().toString());

      values.put(StudentsProvider.GRADE,
         ((EditText)findViewById(R.id.editText3)).getText().toString());

      Uri uri = getContentResolver().insert(
         StudentsProvider.CONTENT_URI, values);

      Toast.makeText(getBaseContext(),
         uri.toString(), Toast.LENGTH_LONG).show();
   }
   public void onClickRetrieveStudents(View view) {
      // Retrieve student records
      String URL = "content://com.example.MyApplication.StudentsProvider";

      Uri students = Uri.parse(URL);
      Cursor c = managedQuery(students, null, null, null, "name");

      if (c.moveToFirst()) {
         do{
            Toast.makeText(this,
               c.getString(c.getColumnIndex(StudentsProvider._ID)) +
                  ", " +  c.getString(c.getColumnIndex( StudentsProvider.NAME)) +
                     ", " + c.getString(c.getColumnIndex( StudentsProvider.GRADE)),
            Toast.LENGTH_SHORT).show();
         } while (c.moveToNext());
      }
   }
}

Com.example.MyApplication पैकेज के अंतर्गत नई फ़ाइल StudentsProvider.java बनाएँ और निम्नलिखित की सामग्री हैsrc/com.example.MyApplication/StudentsProvider.java -

package com.example.MyApplication;

import java.util.HashMap;

import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.UriMatcher;

import android.database.Cursor;
import android.database.SQLException;

import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteQueryBuilder;

import android.net.Uri;
import android.text.TextUtils;

public class StudentsProvider extends ContentProvider {
   static final String PROVIDER_NAME = "com.example.MyApplication.StudentsProvider";
   static final String URL = "content://" + PROVIDER_NAME + "/students";
   static final Uri CONTENT_URI = Uri.parse(URL);

   static final String _ID = "_id";
   static final String NAME = "name";
   static final String GRADE = "grade";

   private static HashMap<String, String> STUDENTS_PROJECTION_MAP;

   static final int STUDENTS = 1;
   static final int STUDENT_ID = 2;

   static final UriMatcher uriMatcher;
   static{
      uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
      uriMatcher.addURI(PROVIDER_NAME, "students", STUDENTS);
      uriMatcher.addURI(PROVIDER_NAME, "students/#", STUDENT_ID);
   }

   /**
      * Database specific constant declarations
   */
   
   private SQLiteDatabase db;
   static final String DATABASE_NAME = "College";
   static final String STUDENTS_TABLE_NAME = "students";
   static final int DATABASE_VERSION = 1;
   static final String CREATE_DB_TABLE =
      " CREATE TABLE " + STUDENTS_TABLE_NAME +
         " (_id INTEGER PRIMARY KEY AUTOINCREMENT, " +
         " name TEXT NOT NULL, " +
         " grade TEXT NOT NULL);";

   /**
      * Helper class that actually creates and manages
      * the provider's underlying data repository.
   */
   
   private static class DatabaseHelper extends SQLiteOpenHelper {
      DatabaseHelper(Context context){
         super(context, DATABASE_NAME, null, DATABASE_VERSION);
      }

      @Override
      public void onCreate(SQLiteDatabase db) {
         db.execSQL(CREATE_DB_TABLE);
      }

      @Override
      public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
         db.execSQL("DROP TABLE IF EXISTS " +  STUDENTS_TABLE_NAME);
         onCreate(db);
      }
   }

   @Override
   public boolean onCreate() {
      Context context = getContext();
      DatabaseHelper dbHelper = new DatabaseHelper(context);

      /**
         * Create a write able database which will trigger its
         * creation if it doesn't already exist.
      */
         
      db = dbHelper.getWritableDatabase();
      return (db == null)? false:true;
   }

   @Override
   public Uri insert(Uri uri, ContentValues values) {
      /**
         * Add a new student record
      */
      long rowID = db.insert(	STUDENTS_TABLE_NAME, "", values);

      /**
         * If record is added successfully
      */
      if (rowID > 0) {
         Uri _uri = ContentUris.withAppendedId(CONTENT_URI, rowID);
         getContext().getContentResolver().notifyChange(_uri, null);
         return _uri;
      }
        
      throw new SQLException("Failed to add a record into " + uri);
   }

   @Override
   public Cursor query(Uri uri, String[] projection, 
      String selection,String[] selectionArgs, String sortOrder) {
      SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
      qb.setTables(STUDENTS_TABLE_NAME);

      switch (uriMatcher.match(uri)) {
         case STUDENTS:
            qb.setProjectionMap(STUDENTS_PROJECTION_MAP);
         break;

         case STUDENT_ID:
            qb.appendWhere( _ID + "=" + uri.getPathSegments().get(1));
         break;
         
         default:   
      }

      if (sortOrder == null || sortOrder == ""){
         /**
            * By default sort on student names
         */
         sortOrder = NAME;
      }
      
      Cursor c = qb.query(db,	projection,	selection, 
         selectionArgs,null, null, sortOrder);
      /**
         * register to watch a content URI for changes
      */
      c.setNotificationUri(getContext().getContentResolver(), uri);
      return c;
   }

   @Override
   public int delete(Uri uri, String selection, String[] selectionArgs) {
      int count = 0;
      switch (uriMatcher.match(uri)){
         case STUDENTS:
            count = db.delete(STUDENTS_TABLE_NAME, selection, selectionArgs);
         break;

         case STUDENT_ID:
            String id = uri.getPathSegments().get(1);
            count = db.delete( STUDENTS_TABLE_NAME, _ID +  " = " + id +
               (!TextUtils.isEmpty(selection) ? " 
               AND (" + selection + ')' : ""), selectionArgs);
            break;
         default:
            throw new IllegalArgumentException("Unknown URI " + uri);
      }

      getContext().getContentResolver().notifyChange(uri, null);
      return count;
   }

   @Override
   public int update(Uri uri, ContentValues values, 
      String selection, String[] selectionArgs) {
      int count = 0;
      switch (uriMatcher.match(uri)) {
         case STUDENTS:
            count = db.update(STUDENTS_TABLE_NAME, values, selection, selectionArgs);
         break;

         case STUDENT_ID:
            count = db.update(STUDENTS_TABLE_NAME, values, 
               _ID + " = " + uri.getPathSegments().get(1) +
               (!TextUtils.isEmpty(selection) ? " 
               AND (" +selection + ')' : ""), selectionArgs);
            break;
         default:
            throw new IllegalArgumentException("Unknown URI " + uri );
      }
        
      getContext().getContentResolver().notifyChange(uri, null);
      return count;
   }

   @Override
   public String getType(Uri uri) {
      switch (uriMatcher.match(uri)){
         /**
            * Get all student records
         */
         case STUDENTS:
            return "vnd.android.cursor.dir/vnd.example.students";
         /**
            * Get a particular student
         */
         case STUDENT_ID:
            return "vnd.android.cursor.item/vnd.example.students";
         default:
            throw new IllegalArgumentException("Unsupported URI: " + uri);
      }
   }
}

AndroidManifest.xml फ़ाइल की संशोधित सामग्री निम्नलिखित होगी । यहाँ हमने अपने कंटेंट प्रोवाइडर को शामिल करने के लिए <प्रदाता ... /> टैग जोड़ा है:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.MyApplication">

   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:supportsRtl="true"
      android:theme="@style/AppTheme">
         <activity android:name=".MainActivity">
            <intent-filter>
               <action android:name="android.intent.action.MAIN" />
               <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
         </activity>
        
      <provider android:name="StudentsProvider"
         android:authorities="com.example.MyApplication.StudentsProvider"/>
   </application>
</manifest>

निम्नलिखित की सामग्री होगी res/layout/activity_main.xml फ़ाइल

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:paddingBottom="@dimen/activity_vertical_margin"
   android:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   tools:context="com.example.MyApplication.MainActivity">

   <TextView
      android:id="@+id/textView1"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Content provider"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true"
      android:textSize="30dp" />

   <TextView
      android:id="@+id/textView2"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials point "
      android:textColor="#ff87ff09"
      android:textSize="30dp"
      android:layout_below="@+id/textView1"
      android:layout_centerHorizontal="true" />

   <ImageButton
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageButton"
      android:src="@drawable/abc"
      android:layout_below="@+id/textView2"
      android:layout_centerHorizontal="true" />

   <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/button2"
      android:text="Add Name"
      android:layout_below="@+id/editText3"
      android:layout_alignRight="@+id/textView2"
      android:layout_alignEnd="@+id/textView2"
      android:layout_alignLeft="@+id/textView2"
      android:layout_alignStart="@+id/textView2"
      android:onClick="onClickAddName"/>

   <EditText
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/editText"
      android:layout_below="@+id/imageButton"
      android:layout_alignRight="@+id/imageButton"
      android:layout_alignEnd="@+id/imageButton" />

   <EditText
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/editText2"
      android:layout_alignTop="@+id/editText"
      android:layout_alignLeft="@+id/textView1"
      android:layout_alignStart="@+id/textView1"
      android:layout_alignRight="@+id/textView1"
      android:layout_alignEnd="@+id/textView1"
      android:hint="Name"
      android:textColorHint="@android:color/holo_blue_light" />

   <EditText
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/editText3"
      android:layout_below="@+id/editText"
      android:layout_alignLeft="@+id/editText2"
      android:layout_alignStart="@+id/editText2"
      android:layout_alignRight="@+id/editText2"
      android:layout_alignEnd="@+id/editText2"
      android:hint="Grade"
      android:textColorHint="@android:color/holo_blue_bright" />

   <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Retrive student"
      android:id="@+id/button"
      android:layout_below="@+id/button2"
      android:layout_alignRight="@+id/editText3"
      android:layout_alignEnd="@+id/editText3"
      android:layout_alignLeft="@+id/button2"
      android:layout_alignStart="@+id/button2"
      android:onClick="onClickRetrieveStudents"/>
</RelativeLayout>

सुनिश्चित करें कि आपके पास निम्नलिखित सामग्री है res/values/strings.xml फ़ाइल:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="app_name">My Application</string>
</resources>;

आइए हमारे संशोधित को चलाने का प्रयास करें My Applicationआवेदन हमने अभी बनाया है। मुझे लगता है कि आपने अपना बनाया थाAVDपर्यावरण की स्थापना करते हुए। एंड्रॉइड स्टूडियो आईडीई से ऐप को चलाने के लिए, अपने प्रोजेक्ट की गतिविधि फ़ाइलों में से एक खोलें और

टूल बार से रन आइकन पर क्लिक करें । Android Studio आपके AVD पर ऐप इंस्टॉल करता है और इसे शुरू करता है और यदि आपके सेट-अप और एप्लिकेशन के साथ सब कुछ ठीक है, तो यह एमुलेटर विंडो के बाद प्रदर्शित होगा, धैर्य रखें क्योंकि यह आपके कंप्यूटर की गति के आधार पर कुछ समय ले सकता है -

अब छात्र प्रवेश करें Name तथा Grade और अंत में क्लिक करें Add Nameबटन, यह डेटाबेस में छात्र रिकॉर्ड जोड़ देगा और डेटाबेस में रिकॉर्ड संख्या के साथ ContentProvider URI दिखाने के तल पर एक संदेश फ्लैश करेगा। यह ऑपरेशन हमारा उपयोग करता हैinsert()तरीका। हमारे सामग्री प्रदाता के डेटाबेस में कुछ और छात्रों को जोड़ने के लिए इस प्रक्रिया को दोहराते हैं।

एक बार जब आप डेटाबेस में रिकॉर्ड जोड़ने के साथ हो जाते हैं, तो अब कंटेंटप्रॉइडर से हमें उन रिकॉर्ड को वापस देने के लिए कहने का समय है, तो चलिए क्लिक करते हैं Retrieve Students बटन जो हमारे द्वारा हमारे कार्यान्वयन के अनुसार एक-एक करके सभी रिकॉर्ड प्राप्त करेगा और प्रदर्शित करेगा query() तरीका।

आप कॉलबैक फ़ंक्शंस प्रदान करके अपडेट के विरुद्ध गतिविधियों को लिख सकते हैं और संचालन हटा सकते हैं MainActivity.java फ़ाइल और फिर अद्यतन और हटाए गए संचालन के लिए बटन के लिए उपयोगकर्ता इंटरफ़ेस को उसी तरह से संशोधित करें जैसे हमने ऑपरेशन और ऐड पढ़ने के लिए किया है।

इस तरह से आप पता पुस्तिका जैसे मौजूदा सामग्री प्रदाता का उपयोग कर सकते हैं या आप अच्छे डेटाबेस उन्मुख अनुप्रयोगों को विकसित करने में सामग्री प्रदाता अवधारणा का उपयोग कर सकते हैं जहां आप उदाहरण के रूप में ऊपर बताए गए अनुसार सभी प्रकार के डेटाबेस संचालन पढ़ सकते हैं, लिख सकते हैं, अपडेट कर सकते हैं और हटा सकते हैं।