प्रॉक्सी पैटर्न: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 1: Line 1:
[[कंप्यूटर प्रोग्रामिंग]] में, प्रॉक्सी पैटर्न एक [[सॉफ्टवेयर डिजाइन पैटर्न]] है। एक ''प्रॉक्सी'', अपने सबसे सामान्य रूप में, एक ऐसा वर्ग है जो किसी अन्य चीज़ के इंटरफ़ेस के रूप में कार्य करता है। प्रॉक्सी किसी भी चीज़ से इंटरफ़ेस कर सकता है: एक नेटवर्क कनेक्शन, मेमोरी में एक बड़ी वस्तु, एक फ़ाइल, या कुछ अन्य संसाधन जो महंगा या डुप्लिकेट करना असंभव है। संक्षेप में, एक प्रॉक्सी एक आवरण या एजेंट वस्तु है जिसे क्लाइंट द्वारा पर्दे के पीछे वास्तविक सेवारत वस्तु तक पहुँचने के लिए बुलाया जा रहा है। प्रॉक्सी का उपयोग केवल वास्तविक वस्तु को अग्रेषित (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग) हो सकता है, या अतिरिक्त तर्क प्रदान कर सकता है। प्रॉक्सी में, अतिरिक्त कार्यक्षमता प्रदान की जा सकती है, उदाहरण के लिए कैशिंग जब वास्तविक वस्तु पर संचालन संसाधन गहन होते हैं, या वास्तविक वस्तु पर संचालन से पहले पूर्व शर्त की जाँच की जाती है। क्लाइंट के लिए, प्रॉक्सी ऑब्जेक्ट का उपयोग वास्तविक ऑब्जेक्ट का उपयोग करने के समान होता है, क्योंकि दोनों एक ही इंटरफ़ेस को लागू करते हैं।
[[कंप्यूटर प्रोग्रामिंग]] में, प्रॉक्सी स्वरूप एक [[सॉफ्टवेयर डिजाइन पैटर्न|सॉफ्टवेयर डिजाइन स्वरूप]] है। एक ''प्रॉक्सी'', अपने सबसे सामान्य रूप में, एक ऐसा वर्ग है जो किसी अन्य चीज़ के इंटरफ़ेस के रूप में कार्य करता है। प्रॉक्सी किसी भी चीज़ से इंटरफ़ेस कर सकता है: एक नेटवर्क कनेक्शन, मेमोरी में एक बड़ी वस्तु, एक फ़ाइल, या कुछ अन्य संसाधन जो महंगा या डुप्लिकेट करना असंभव है। संक्षेप में, एक प्रॉक्सी एक आवरण या एजेंट वस्तु है जिसे क्लाइंट द्वारा पर्दे के पीछे वास्तविक सेवारत वस्तु तक पहुँचने के लिए बुलाया जा रहा है। प्रॉक्सी का उपयोग केवल वास्तविक वस्तु को अग्रेषित (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग) हो सकता है, या अतिरिक्त तर्क प्रदान कर सकता है। प्रॉक्सी में, अतिरिक्त कार्यक्षमता प्रदान की जा सकती है, उदाहरण के लिए कैशिंग जब वास्तविक वस्तु पर संचालन संसाधन गहन होते हैं, या वास्तविक वस्तु पर संचालन से पहले पूर्व शर्त की जाँच की जाती है। क्लाइंट के लिए, प्रॉक्सी ऑब्जेक्ट का उपयोग वास्तविक ऑब्जेक्ट का उपयोग करने के समान होता है, क्योंकि दोनों एक ही इंटरफ़ेस को लागू करते हैं।


== सिंहावलोकन ==
== सिंहावलोकन ==
प्रॉक्सी
प्रॉक्सी
  <ref name="GoF">{{cite book|author=Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides|title=Design Patterns: Elements of Reusable Object-Oriented Software|year=1994|publisher=Addison Wesley|isbn=0-201-63361-2|pages=[https://archive.org/details/designpatternsel00gamm/page/207 207ff]|url-access=registration|url=https://archive.org/details/designpatternsel00gamm/page/207}}</ref>
  <ref name="GoF">{{cite book|author=Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides|title=Design Patterns: Elements of Reusable Object-Oriented Software|year=1994|publisher=Addison Wesley|isbn=0-201-63361-2|pages=[https://archive.org/details/designpatternsel00gamm/page/207 207ff]|url-access=registration|url=https://archive.org/details/designpatternsel00gamm/page/207}}</ref>
डिजाइन पैटर्न तेईस प्रसिद्ध में से एक है
डिजाइन स्वरूप तेईस प्रसिद्ध में से एक है
[[डिजाइन पैटर्न्स]]
[[डिजाइन पैटर्न्स|डिजाइन स्वरूप्स]]
यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो।
यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो।


=== प्रॉक्सी डिज़ाइन पैटर्न किन समस्याओं को हल कर सकता है? <ref>{{cite web|title=The Proxy design pattern - Problem, Solution, and Applicability|url=http://w3sdesign.com/?gr=s07&ugr=proble|website=w3sDesign.com|access-date=2017-08-12}}</ref>===
=== प्रॉक्सी डिज़ाइन स्वरूप किन समस्याओं को हल कर सकता है? <ref>{{cite web|title=The Proxy design pattern - Problem, Solution, and Applicability|url=http://w3sdesign.com/?gr=s07&ugr=proble|website=w3sDesign.com|access-date=2017-08-12}}</ref>===


* किसी वस्तु की पहुंच को नियंत्रित किया जाना चाहिए।
* किसी वस्तु की पहुंच को नियंत्रित किया जाना चाहिए।
Line 15: Line 15:
संवेदनशील वस्तुओं तक पहुँचते समय, उदाहरण के लिए, यह जाँचना संभव होना चाहिए कि ग्राहकों के पास आवश्यक पहुँच अधिकार हैं।
संवेदनशील वस्तुओं तक पहुँचते समय, उदाहरण के लिए, यह जाँचना संभव होना चाहिए कि ग्राहकों के पास आवश्यक पहुँच अधिकार हैं।


=== प्रॉक्सी डिज़ाइन पैटर्न किस समाधान का वर्णन करता है? ===
=== प्रॉक्सी डिज़ाइन स्वरूप किस समाधान का वर्णन करता है? ===


अलग परिभाषित करें <code>Proxy</code> उस पर आपत्ति करें
अलग परिभाषित करें <code>Proxy</code> उस पर आपत्ति करें
Line 31: Line 31:


=== यूएमएल वर्ग और अनुक्रम आरेख ===
=== यूएमएल वर्ग और अनुक्रम आरेख ===
[[File:w3sDesign Proxy Design Pattern UML.jpg|frame|none|प्रॉक्सी डिजाइन पैटर्न के लिए एक नमूना यूएमएल वर्ग और अनुक्रम आरेख।
[[File:w3sDesign Proxy Design Pattern UML.jpg|frame|none|प्रॉक्सी डिजाइन स्वरूप के लिए एक नमूना यूएमएल वर्ग और अनुक्रम आरेख।
<ref>{{cite web|title=The Proxy design pattern - Structure and Collaboration|url=http://w3sdesign.com/?gr=s07&ugr=struct|website=w3sDesign.com|access-date=2017-08-12}}</ref>]]उपरोक्त [[एकीकृत मॉडलिंग भाषा]] [[वर्ग आरेख]] में,
<ref>{{cite web|title=The Proxy design pattern - Structure and Collaboration|url=http://w3sdesign.com/?gr=s07&ugr=struct|website=w3sDesign.com|access-date=2017-08-12}}</ref>]]उपरोक्त [[एकीकृत मॉडलिंग भाषा]] [[वर्ग आरेख]] में,
  <code>Proxy</code> वर्ग लागू करता है <code>Subject</code> इंटरफ़ेस ताकि यह इसके विकल्प के रूप में कार्य कर सके <code>Subject</code> वस्तुओं। यह एक संदर्भ रखता है (<code>realSubject</code>)
  <code>Proxy</code> वर्ग लागू करता है <code>Subject</code> इंटरफ़ेस ताकि यह इसके विकल्प के रूप में कार्य कर सके <code>Subject</code> वस्तुओं। यह एक संदर्भ रखता है (<code>realSubject</code>)
प्रतिस्थापित वस्तु के लिए (<code>RealSubject</code>) ताकि वह इसे अनुरोधों को अग्रेषित कर सके
प्रतिस्थापित वस्तु के लिए (<code>RealSubject</code>) ताकि वह इसे अनुरोधों को अग्रेषित कर सके
Line 64: Line 64:


=== सी # ===
=== सी # ===
(कोड)
<syntaxhighlight>
उत्पादन
interface ICar
{
    void DriveCar() ;
}
 
// Real Object
public class Car : ICar
{
    public void DriveCar()
    {
        Console.WriteLine("Car has been driven!");
    }
}
 
// Proxy Object
public class ProxyCar : ICar
{
    private Driver driver;
    private ICar realCar;
 
    public ProxyCar(Driver driver)
    {
        this.driver = driver;
        this.realCar = new Car();
    }
 
    public void DriveCar()
    {
        if (driver.Age < 16)
            Console.WriteLine("Sorry, the driver is too young to drive.");
        else
            this.realCar.DriveCar();
    }
}
 
public class Driver
{
    public int Age { get; set; }
 
    public Driver(int age)
    {
        this.Age = age;
    }
}
 
// How to use above Proxy class?
private void btnProxy_Click(object sender, EventArgs e)
{
    ICar car = new ProxyCar(new Driver(15));
    car.DriveCar();
 
    car = new ProxyCar(new Driver(25));
    car.DriveCar();
}
</syntaxhighlight>उत्पादन
  क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
  क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
  कार चलाई गई है!
  कार चलाई गई है!
Line 73: Line 127:
* एक प्रॉक्सी ऑन डिमांड लोडिंग जैसे अनुकूलन का प्रदर्शन कर सकता है।
* एक प्रॉक्सी ऑन डिमांड लोडिंग जैसे अनुकूलन का प्रदर्शन कर सकता है।
* एक प्रॉक्सी अतिरिक्त हाउसकीपिंग का काम कर सकता है जैसे ऑडिट कार्य।
* एक प्रॉक्सी अतिरिक्त हाउसकीपिंग का काम कर सकता है जैसे ऑडिट कार्य।
* प्रॉक्सी डिज़ाइन पैटर्न को सरोगेट डिज़ाइन पैटर्न के रूप में भी जाना जाता है।
* प्रॉक्सी डिज़ाइन स्वरूप को सरोगेट डिज़ाइन स्वरूप के रूप में भी जाना जाता है।


=== सी ++ ===
=== सी ++ ===
(कोड)
<syntaxhighlight>
#include <iostream>
#include <memory>
 
class ICar {
public:
  virtual ~ICar() { std::cout << "ICar destructor!" << std::endl; }
 
  virtual void DriveCar() = 0;
};
 
class Car : public ICar {
public:
  void DriveCar() override { std::cout << "Car has been driven!" << std::endl; }
};
 
class ProxyCar : public ICar {
public:
  ProxyCar(int driver_age) : driver_age_(driver_age) {}
 
  void DriveCar() override {
    if (driver_age_ > 16) {
      real_car_->DriveCar();
    } else {
      std::cout << "Sorry, the driver is too young to drive." << std::endl;
    }
  }
 
private:
  std::unique_ptr<ICar> real_car_ = std::make_unique<Car>();
  int driver_age_;
};
 
int main() {
  std::unique_ptr<ICar> car = std::make_unique<ProxyCar>(16);
  car->DriveCar();
 
  car = std::make_unique<ProxyCar>(25);
  car->DriveCar();
}
</syntaxhighlight>


=== क्रिस्टल ===
=== क्रिस्टल ===
(कोड)
<syntaxhighlight>
abstract class AbstractCar
  abstract def drive
end
 
class Car < AbstractCar
  def drive
    puts "Car has been driven!"
  end
end
 
class Driver
  getter age : Int32
 
  def initialize(@age)
  end
end
 
class ProxyCar < AbstractCar
  private getter driver : Driver
  private getter real_car : AbstractCar
 
  def initialize(@driver)
    @real_car = Car.new
  end
 
  def drive
    if driver.age <= 16
      puts "Sorry, the driver is too young to drive."
    else
      @real_car.drive
    end
  end
end
 
# Program
driver = Driver.new(16)
car = ProxyCar.new(driver)
car.drive
 
driver = Driver.new(25)
car = ProxyCar.new(driver)
car.drive
</syntaxhighlight>




Line 87: Line 224:


=== डेल्फी/ऑब्जेक्ट पास्कल ===
=== डेल्फी/ऑब्जेक्ट पास्कल ===
(कोड)
<syntaxhighlight>
// Proxy Design pattern
unit DesignPattern.Proxy;
 
interface
 
type
    // Car Interface
    ICar = interface
      procedure DriveCar;
    end;
 
    // TCar class, implementing ICar
    TCar = Class(TInterfacedObject, ICar)
      class function New: ICar;
      procedure DriveCar;
    End;
 
    // Driver Interface
    IDriver = interface
      function Age: Integer;
    end;
 
    // TDriver Class, implementing IDriver
    TDriver = Class(TInterfacedObject, IDriver)
    private
      FAge: Integer;
    public
      constructor Create(Age: Integer); Overload;
      class function New(Age: Integer): IDriver;
      function Age: Integer;
    End;
 
    // Proxy Object
    TProxyCar = Class(TInterfacedObject, ICar)
    private
      FDriver: IDriver;
      FRealCar: ICar;
    public
      constructor Create(Driver: IDriver); Overload;
      class function New(Driver: IDriver): ICar;
      procedure DriveCar;
    End;
 
implementation
 
{ TCar Implementation }
 
class function TCar.New: ICar;
begin
    Result := Create;
end;
 
procedure TCar.DriveCar;
begin
    WriteLn('Car has been driven!');
end;
 
{ TDriver Implementation }
 
constructor TDriver.Create(Age: Integer);
begin
    inherited Create;
    FAge := Age;
end;
 
class function TDriver.New(Age: Integer): IDriver;
begin
    Result := Create(Age);
end;
 
function TDriver.Age: Integer;
begin
    Result := FAge;
end;
 
{ TProxyCar Implementation }
 
constructor TProxyCar.Create(Driver: IDriver);
begin
    inherited Create;
    Self.FDriver  := Driver;
    Self.FRealCar := TCar.Create AS ICar;
end;
 
class function TProxyCar.New(Driver: IDriver): ICar;
begin
    Result := Create(Driver);
end;
 
procedure TProxyCar.DriveCar;
begin
    if (FDriver.Age <= 16)
        then WriteLn('Sorry, the driver is too young to drive.')
        else FRealCar.DriveCar();
end;
 
end.
</syntaxhighlight>उपयोग<syntaxhighlight>
program Project1;
{$APPTYPE Console}
uses
    DesignPattern.Proxy in 'DesignPattern.Proxy.pas';
begin
    TProxyCar.New(TDriver.New(16)).DriveCar;
    TProxyCar.New(TDriver.New(25)).DriveCar;
end.
</syntaxhighlight>


उपयोग
    DesignPattern.Proxy 'DesignPattern.Proxy.pas' में;
शुरू
    TProxyCar.New (TDriver.New (16))। ड्राइवकार;
    TProxyCar.New (TDriver.New (25))। ड्राइवकार;
अंत।
</वाक्यविन्यास हाइलाइट>


उत्पादन
उत्पादन
  क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
  क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
  कार चलाई गई है!
  कार चलाई गई है!
=== जावा ===
निम्न [[जावा (प्रोग्रामिंग भाषा)]] उदाहरण वर्चुअल प्रॉक्सी स्वरूप दिखाता है। <code>ProxyImage</code> e> वर्ग का उपयोग दूरस्थ विधि तक पहुँचने के लिए किया जाता है।
उदाहरण पहले एक इंटरफ़ेस बनाता है जिसके विरुद्ध स्वरूप कक्षाएं बनाता है। इस इंटरफ़ेस में छवि प्रदर्शित करने के लिए केवल एक विधि है, जिसे कहा जाता है <code>displayImage()</code>, जिसे इसे लागू करने वाले सभी वर्गों द्वारा कोडित किया जाना है।
प्रॉक्सी वर्ग <code>ProxyImage</code> वास्तविक छवि वर्ग की तुलना में किसी अन्य सिस्टम पर चल रहा है और वास्तविक छवि का प्रतिनिधित्व कर सकता है <code>RealImage</code> वहाँ। छवि जानकारी डिस्क से एक्सेस की जाती है। प्रॉक्सी स्वरूप का उपयोग करते हुए, का कोड <code>ProxyImage</code> मेमोरी-सेविंग तरीके से अन्य सिस्टम से इसे एक्सेस करते हुए, छवि के कई लोडिंग से बचा जाता है। इस उदाहरण में प्रदर्शित आलसी लोडिंग प्रॉक्सी स्वरूप का हिस्सा नहीं है, बल्कि प्रॉक्सी के उपयोग से संभव हुआ एक लाभ है।<syntaxhighlight>
interface Image {
    public void displayImage();
}
// On System A
class RealImage implements Image {
    private final String filename;
    /**
    * Constructor
    * @param filename
    */
    public RealImage(String filename) {
        this.filename = filename;
        loadImageFromDisk();
    }
    /**
    * Loads the image from the disk
    */
    private void loadImageFromDisk() {
        System.out.println("Loading  " + filename);
    }


=== जावा ===
    /**
निम्न [[जावा (प्रोग्रामिंग भाषा)]] उदाहरण वर्चुअल प्रॉक्सी पैटर्न दिखाता है। <code>ProxyImage</code> e> वर्ग का उपयोग दूरस्थ विधि तक पहुँचने के लिए किया जाता है।
    * Displays the image
    */
    public void displayImage() {
        System.out.println("Displaying " + filename);
    }
}
 
// On System B
class ProxyImage implements Image {
    private final String filename;
    private RealImage image;
   
    /**
    * Constructor
    * @param filename
    */
    public ProxyImage(String filename) {
        this.filename = filename;
    }


उदाहरण पहले एक इंटरफ़ेस बनाता है जिसके विरुद्ध पैटर्न कक्षाएं बनाता है। इस इंटरफ़ेस में छवि प्रदर्शित करने के लिए केवल एक विधि है, जिसे कहा जाता है <code>displayImage()</code>, जिसे इसे लागू करने वाले सभी वर्गों द्वारा कोडित किया जाना है।
    /**
    * Displays the image
    */
    public void displayImage() {
        if (image == null) {
          image = new RealImage(filename);
        }
        image.displayImage();
    }
}


प्रॉक्सी वर्ग <code>ProxyImage</code> वास्तविक छवि वर्ग की तुलना में किसी अन्य सिस्टम पर चल रहा है और वास्तविक छवि का प्रतिनिधित्व कर सकता है <code>RealImage</code> वहाँ। छवि जानकारी डिस्क से एक्सेस की जाती है। प्रॉक्सी पैटर्न का उपयोग करते हुए, का कोड <code>ProxyImage</code> मेमोरी-सेविंग तरीके से अन्य सिस्टम से इसे एक्सेस करते हुए, छवि के कई लोडिंग से बचा जाता है। इस उदाहरण में प्रदर्शित आलसी लोडिंग प्रॉक्सी पैटर्न का हिस्सा नहीं है, बल्कि प्रॉक्सी के उपयोग से संभव हुआ एक लाभ है।
class ProxyExample {
  /**
    * Test method
    */
  public static void main(final String[] arguments) {
        Image image1 = new ProxyImage("HiRes_10MB_Photo1");
        Image image2 = new ProxyImage("HiRes_10MB_Photo2");


(कोड)
        image1.displayImage(); // loading necessary
        image1.displayImage(); // loading unnecessary
        image2.displayImage(); // loading necessary
        image2.displayImage(); // loading unnecessary
        image1.displayImage(); // loading unnecessary
    }
}
</syntaxhighlight>




उत्पादन
उत्पादन<syntaxhighlight>
लोड हो रहा है HiRes_10MB_Photo1
Loading  HiRes_10MB_Photo1
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
Displaying HiRes_10MB_Photo1
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
Displaying HiRes_10MB_Photo1
लोड हो रहा है HiRes_10MB_Photo2
Loading  HiRes_10MB_Photo2
HiRes_10MB_Photo2 प्रदर्शित कर रहा है
Displaying HiRes_10MB_Photo2
HiRes_10MB_Photo2 प्रदर्शित कर रहा है
Displaying HiRes_10MB_Photo2
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
Displaying HiRes_10MB_Photo1
</syntaxhighlight>


=== जावास्क्रिप्ट ===
=== जावास्क्रिप्ट ===
<syntaxhighlight>
// Driver class
class Driver {
  constructor (age) {
    this.age = age
  }
}
// Car class
class Car {
  drive () {
    console.log('Car has been driven!')
  }
}
// Proxy car class
class ProxyCar {
  constructor (driver) {
    this.car = new Car()
    this.driver = driver
  }
  drive () {
    if (this.driver.age <= 16) {
      console.log('Sorry, the driver is too young to drive.')
    } else {
      this.car.drive()
    }
  }
}


(कोड)
// Run program
const driver = new Driver(16)
const car = new ProxyCar(driver)
car.drive()
 
const driver2 = new Driver(25)
const car2 = new ProxyCar(driver2)
car2.drive()
</syntaxhighlight>




Line 133: Line 478:


=== पीएचपी ===
=== पीएचपी ===
(कोड)
<syntaxhighlight>
<?php


interface Image
{
    public function displayImage();
}


उत्पादन
// On System A
लोड हो रहा है HiRes_10MB_Photo1
class RealImage implements Image
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
{
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
    private string $filename = null;
लोड हो रहा है HiRes_10MB_Photo2
 
HiRes_10MB_Photo2 प्रदर्शित कर रहा है
    public function __construct(string $filename)
HiRes_10MB_Photo2 प्रदर्शित कर रहा है
    {
HiRes_10MB_Photo1 प्रदर्शित कर रहा है
        $this->filename = $filename;
        $this->loadImageFromDisk();
    }
 
    /**
    * Loads the image from the disk
    */
    private function loadImageFromDisk()
    {
        echo "Loading {$this->filename}" . \PHP_EOL;
    }
 
    /**
    * Displays the image
    */
    public function displayImage()
    {
    echo "Displaying {$this->filename}" . \PHP_EOL;
    }
}
 
// On System B
class ProxyImage implements Image
{
    private ?Image $image = null;
    private string $filename = null;
 
    public function __construct(string $filename)
    {
        $this->filename = $filename;
    }
 
    /**
    * Displays the image
    */
    public function displayImage()
    {
        if ($this->image === null) {
          $this->image = new RealImage($this->filename);
        }
        $this->image->displayImage();
    }
}
 
 
$image1 = new ProxyImage("HiRes_10MB_Photo1");
$image2 = new ProxyImage("HiRes_10MB_Photo2");
 
$image1->displayImage(); // Loading necessary
$image1->displayImage(); // Loading unnecessary
$image2->displayImage(); // Loading necessary
$image2->displayImage(); // Loading unnecessary
$image1->displayImage(); // Loading unnecessary
</syntaxhighlight>
 
 
उत्पादन<syntaxhighlight>
Loading HiRes_10MB_Photo1  
Displaying HiRes_10MB_Photo1  
Displaying HiRes_10MB_Photo1  
Loading HiRes_10MB_Photo2  
Displaying HiRes_10MB_Photo2  
Displaying HiRes_10MB_Photo2  
Displaying HiRes_10MB_Photo1
</syntaxhighlight>


===पायथन===
===पायथन===
(कोड)
<syntaxhighlight>
"""
Proxy pattern example.
"""
from abc import ABCMeta, abstractmethod
 
 
NOT_IMPLEMENTED = "You should implement this."
 
 
class AbstractCar:
    __metaclass__ = ABCMeta
 
    @abstractmethod
    def drive(self):
        raise NotImplementedError(NOT_IMPLEMENTED)
 
 
class Car(AbstractCar):
    def drive(self) -> None:
        print("Car has been driven!")
 
 
class Driver:
    def __init__(self, age: int) -> None:
        self.age = age
 
 
class ProxyCar(AbstractCar):
    def __init__(self, driver) -> None:
        self.car = Car()
        self.driver = driver
 
    def drive(self) -> None:
        if self.driver.age <= 16:
            print("Sorry, the driver is too young to drive.")
        else:
            self.car.drive()
 
 
driver = Driver(16)
car = ProxyCar(driver)
car.drive()
 
driver = Driver(25)
car = ProxyCar(driver)
car.drive()
</syntaxhighlight>




Line 154: Line 615:


=== जंग ===
=== जंग ===
(कोड)
<syntaxhighlight>
trait ICar {
    fn drive(&self);
}
 
struct Car {}
 
impl ICar for Car {
    fn drive(&self) {
        println!("Car has been driven!");
    }
}
 
impl Car {
    fn new() -> Car {
        Car {}
    }
}
 
struct ProxyCar<'a> {
    real_car: &'a ICar,
    driver_age: i32,
}
 
impl<'a> ICar for ProxyCar<'a> {
    fn drive(&self) {
        if self.driver_age > 16 {
            self.real_car.drive();
        } else {
            println!("Sorry, the driver is too young to drive.")
        }
    }
}
 
impl<'a> ProxyCar<'a> {
    fn new(driver_age: i32, other_car: &'a ICar) -> ProxyCar {
        ProxyCar {
            real_car: other_car,
            driver_age: driver_age,
        }
    }
}
 
#[cfg(test)]
mod tests {
    use super::*;
   
    #[test]
    fn test_underage() {
        let car = Car::new();
        let proxy_car = ProxyCar::new(16, &car);
        proxy_car.drive();
    }
 
    #[test]
    fn test_can_drive() {
        let car = Car::new();
        let proxy_car = ProxyCar::new(17, &car);
        proxy_car.drive();
    }
}
</syntaxhighlight>




Line 162: Line 684:


== यह भी देखें ==
== यह भी देखें ==
* [[समग्र पैटर्न]]
* [[समग्र पैटर्न|समग्र स्वरूप]]
* [[डेकोरेटर पैटर्न]]
* [[डेकोरेटर पैटर्न|डेकोरेटर स्वरूप]]
* [[आलसी आरंभीकरण]]
* [[आलसी आरंभीकरण|मंद आरंभीकरण]]


==संदर्भ==
==संदर्भ==

Revision as of 12:18, 3 March 2023

कंप्यूटर प्रोग्रामिंग में, प्रॉक्सी स्वरूप एक सॉफ्टवेयर डिजाइन स्वरूप है। एक प्रॉक्सी, अपने सबसे सामान्य रूप में, एक ऐसा वर्ग है जो किसी अन्य चीज़ के इंटरफ़ेस के रूप में कार्य करता है। प्रॉक्सी किसी भी चीज़ से इंटरफ़ेस कर सकता है: एक नेटवर्क कनेक्शन, मेमोरी में एक बड़ी वस्तु, एक फ़ाइल, या कुछ अन्य संसाधन जो महंगा या डुप्लिकेट करना असंभव है। संक्षेप में, एक प्रॉक्सी एक आवरण या एजेंट वस्तु है जिसे क्लाइंट द्वारा पर्दे के पीछे वास्तविक सेवारत वस्तु तक पहुँचने के लिए बुलाया जा रहा है। प्रॉक्सी का उपयोग केवल वास्तविक वस्तु को अग्रेषित (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग) हो सकता है, या अतिरिक्त तर्क प्रदान कर सकता है। प्रॉक्सी में, अतिरिक्त कार्यक्षमता प्रदान की जा सकती है, उदाहरण के लिए कैशिंग जब वास्तविक वस्तु पर संचालन संसाधन गहन होते हैं, या वास्तविक वस्तु पर संचालन से पहले पूर्व शर्त की जाँच की जाती है। क्लाइंट के लिए, प्रॉक्सी ऑब्जेक्ट का उपयोग वास्तविक ऑब्जेक्ट का उपयोग करने के समान होता है, क्योंकि दोनों एक ही इंटरफ़ेस को लागू करते हैं।

सिंहावलोकन

प्रॉक्सी

[1]

डिजाइन स्वरूप तेईस प्रसिद्ध में से एक है डिजाइन स्वरूप्स यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो।

प्रॉक्सी डिज़ाइन स्वरूप किन समस्याओं को हल कर सकता है? [2]

  • किसी वस्तु की पहुंच को नियंत्रित किया जाना चाहिए।
  • किसी वस्तु तक पहुँचने पर अतिरिक्त कार्यक्षमता प्रदान की जानी चाहिए।

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

प्रॉक्सी डिज़ाइन स्वरूप किस समाधान का वर्णन करता है?

अलग परिभाषित करें Proxy उस पर आपत्ति करें

  • किसी अन्य वस्तु के विकल्प के रूप में इस्तेमाल किया जा सकता है (Subject) और
  • इस विषय तक पहुंच को नियंत्रित करने के लिए अतिरिक्त कार्यक्षमता लागू करता है।

यह एक के माध्यम से काम करना संभव बनाता है Proxy किसी विषय तक पहुँचने पर अतिरिक्त कार्यक्षमता करने के लिए ऑब्जेक्ट। उदाहरण के लिए, किसी संवेदनशील वस्तु तक पहुँचने वाले ग्राहकों के पहुँच अधिकारों की जाँच करने के लिए।

किसी विषय के स्थानापन्न के रूप में कार्य करने के लिए, प्रॉक्सी को लागू करना चाहिए Subject इंटरफेस। ग्राहक यह नहीं बता सकते कि वे किसी विषय या उसके प्रॉक्सी के साथ काम करते हैं या नहीं।

नीचे यूएमएल क्लास और सीक्वेंस डायग्राम भी देखें।

संरचना

यूएमएल वर्ग और अनुक्रम आरेख

प्रॉक्सी डिजाइन स्वरूप के लिए एक नमूना यूएमएल वर्ग और अनुक्रम आरेख। [3]

उपरोक्त एकीकृत मॉडलिंग भाषा वर्ग आरेख में,

Proxy वर्ग लागू करता है Subject इंटरफ़ेस ताकि यह इसके विकल्प के रूप में कार्य कर सके Subject वस्तुओं। यह एक संदर्भ रखता है (realSubject)

प्रतिस्थापित वस्तु के लिए (RealSubject) ताकि वह इसे अनुरोधों को अग्रेषित कर सके (realSubject.operation()).

अनुक्रम आरेख रन-टाइम इंटरैक्शन दिखाता है: Client ई> वस्तु ए के माध्यम से काम करता है Proxy उस पर आपत्ति करें ए तक पहुंच को नियंत्रित करता है RealSubject वस्तु। इस उदाहरण में, Proxy को अनुरोध अग्रेषित करता है RealSubject, जो अनुरोध करता है।

वर्ग आरेख

एकीकृत मॉडलिंग भाषा में प्रॉक्सी
Lepus3 में प्रॉक्सी (लीजेंड)

संभावित उपयोग परिदृश्य

रिमोट प्रॉक्सी

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

वर्चुअल प्रॉक्सी

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

सुरक्षा प्रॉक्सी

एक्सेस अधिकारों के आधार पर संसाधन तक पहुंच को नियंत्रित करने के लिए एक सुरक्षा प्रॉक्सी का उपयोग किया जा सकता है।

उदाहरण

सी #

interface ICar
{
    void DriveCar() ;
}

// Real Object
public class Car : ICar
{
    public void DriveCar()
    {
        Console.WriteLine("Car has been driven!");
    }
}

// Proxy Object
public class ProxyCar : ICar
{
    private Driver driver;
    private ICar realCar;

    public ProxyCar(Driver driver)
    {
        this.driver = driver;
        this.realCar = new Car();
    }

    public void DriveCar()
    {
        if (driver.Age < 16)
            Console.WriteLine("Sorry, the driver is too young to drive.");
        else
            this.realCar.DriveCar();
     }
}

public class Driver
{
    public int Age { get; set; }

    public Driver(int age)
    {
        this.Age = age;
    }
}

// How to use above Proxy class?
private void btnProxy_Click(object sender, EventArgs e)
{
    ICar car = new ProxyCar(new Driver(15));
    car.DriveCar();

    car = new ProxyCar(new Driver(25));
    car.DriveCar();
}

उत्पादन

क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
कार चलाई गई है!

टिप्पणियाँ:

  • एक प्रॉक्सी क्लाइंट को वास्तविक वस्तु के बारे में जानकारी छुपा सकता है।
  • एक प्रॉक्सी ऑन डिमांड लोडिंग जैसे अनुकूलन का प्रदर्शन कर सकता है।
  • एक प्रॉक्सी अतिरिक्त हाउसकीपिंग का काम कर सकता है जैसे ऑडिट कार्य।
  • प्रॉक्सी डिज़ाइन स्वरूप को सरोगेट डिज़ाइन स्वरूप के रूप में भी जाना जाता है।

सी ++

#include <iostream>
#include <memory>

class ICar {
 public:
  virtual ~ICar() { std::cout << "ICar destructor!" << std::endl; }

  virtual void DriveCar() = 0;
};

class Car : public ICar {
 public:
  void DriveCar() override { std::cout << "Car has been driven!" << std::endl; }
};

class ProxyCar : public ICar {
 public:
  ProxyCar(int driver_age) : driver_age_(driver_age) {}

  void DriveCar() override {
    if (driver_age_ > 16) {
      real_car_->DriveCar();
    } else {
      std::cout << "Sorry, the driver is too young to drive." << std::endl;
    }
  }

 private:
  std::unique_ptr<ICar> real_car_ = std::make_unique<Car>();
  int driver_age_;
};

int main() {
  std::unique_ptr<ICar> car = std::make_unique<ProxyCar>(16);
  car->DriveCar();

  car = std::make_unique<ProxyCar>(25);
  car->DriveCar();
}

क्रिस्टल

abstract class AbstractCar
  abstract def drive
end

class Car < AbstractCar
  def drive
    puts "Car has been driven!"
  end
end

class Driver
  getter age : Int32

  def initialize(@age)
  end
end

class ProxyCar < AbstractCar
  private getter driver : Driver
  private getter real_car : AbstractCar

  def initialize(@driver)
    @real_car = Car.new
  end

  def drive
    if driver.age <= 16
      puts "Sorry, the driver is too young to drive."
    else
      @real_car.drive
    end
  end
end

# Program
driver = Driver.new(16)
car = ProxyCar.new(driver)
car.drive

driver = Driver.new(25)
car = ProxyCar.new(driver)
car.drive


उत्पादन

क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
कार चलाई गई है!

डेल्फी/ऑब्जेक्ट पास्कल

// Proxy Design pattern
unit DesignPattern.Proxy;

interface

type
    // Car Interface
    ICar = interface
      procedure DriveCar;
    end;

    // TCar class, implementing ICar
    TCar = Class(TInterfacedObject, ICar)
      class function New: ICar;
      procedure DriveCar;
    End;

    // Driver Interface
    IDriver = interface
      function Age: Integer;
    end;

    // TDriver Class, implementing IDriver
    TDriver = Class(TInterfacedObject, IDriver)
    private
      FAge: Integer;
    public
      constructor Create(Age: Integer); Overload;
      class function New(Age: Integer): IDriver;
      function Age: Integer;
    End;

    // Proxy Object
    TProxyCar = Class(TInterfacedObject, ICar)
    private
      FDriver: IDriver;
      FRealCar: ICar;
    public
      constructor Create(Driver: IDriver); Overload;
      class function New(Driver: IDriver): ICar;
      procedure DriveCar;
    End;

implementation

{ TCar Implementation }

class function TCar.New: ICar;
begin
     Result := Create;
end;

procedure TCar.DriveCar;
begin
     WriteLn('Car has been driven!');
end;

{ TDriver Implementation }

constructor TDriver.Create(Age: Integer);
begin
     inherited Create;
     FAge := Age;
end;

class function TDriver.New(Age: Integer): IDriver;
begin
     Result := Create(Age);
end;

function TDriver.Age: Integer;
begin
     Result := FAge;
end;

{ TProxyCar Implementation }

constructor TProxyCar.Create(Driver: IDriver);
begin
     inherited Create;
     Self.FDriver  := Driver;
     Self.FRealCar := TCar.Create AS ICar;
end;

class function TProxyCar.New(Driver: IDriver): ICar;
begin
     Result := Create(Driver);
end;

procedure TProxyCar.DriveCar;
begin
     if (FDriver.Age <= 16)
        then WriteLn('Sorry, the driver is too young to drive.')
        else FRealCar.DriveCar();
end;

end.

उपयोग

program Project1;
{$APPTYPE Console}
uses
    DesignPattern.Proxy in 'DesignPattern.Proxy.pas';
begin
     TProxyCar.New(TDriver.New(16)).DriveCar;
     TProxyCar.New(TDriver.New(25)).DriveCar;
end.


उत्पादन

क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
कार चलाई गई है!

जावा

निम्न जावा (प्रोग्रामिंग भाषा) उदाहरण वर्चुअल प्रॉक्सी स्वरूप दिखाता है। ProxyImage e> वर्ग का उपयोग दूरस्थ विधि तक पहुँचने के लिए किया जाता है।

उदाहरण पहले एक इंटरफ़ेस बनाता है जिसके विरुद्ध स्वरूप कक्षाएं बनाता है। इस इंटरफ़ेस में छवि प्रदर्शित करने के लिए केवल एक विधि है, जिसे कहा जाता है displayImage(), जिसे इसे लागू करने वाले सभी वर्गों द्वारा कोडित किया जाना है।

प्रॉक्सी वर्ग ProxyImage वास्तविक छवि वर्ग की तुलना में किसी अन्य सिस्टम पर चल रहा है और वास्तविक छवि का प्रतिनिधित्व कर सकता है RealImage वहाँ। छवि जानकारी डिस्क से एक्सेस की जाती है। प्रॉक्सी स्वरूप का उपयोग करते हुए, का कोड ProxyImage मेमोरी-सेविंग तरीके से अन्य सिस्टम से इसे एक्सेस करते हुए, छवि के कई लोडिंग से बचा जाता है। इस उदाहरण में प्रदर्शित आलसी लोडिंग प्रॉक्सी स्वरूप का हिस्सा नहीं है, बल्कि प्रॉक्सी के उपयोग से संभव हुआ एक लाभ है।

interface Image {
    public void displayImage();
}

// On System A
class RealImage implements Image {
    private final String filename;

    /**
     * Constructor
     * @param filename
     */
    public RealImage(String filename) {
        this.filename = filename;
        loadImageFromDisk();
    }

    /**
     * Loads the image from the disk
     */
    private void loadImageFromDisk() {
        System.out.println("Loading   " + filename);
    }

    /**
     * Displays the image
     */
    public void displayImage() {
        System.out.println("Displaying " + filename);
    }
}

// On System B
class ProxyImage implements Image {
    private final String filename;
    private RealImage image;
    
    /**
     * Constructor
     * @param filename
     */
    public ProxyImage(String filename) {
        this.filename = filename;
    }

    /**
     * Displays the image
     */
    public void displayImage() {
        if (image == null) {
           image = new RealImage(filename);
        }
        image.displayImage();
    }
}

class ProxyExample {
   /**
    * Test method
    */
   public static void main(final String[] arguments) {
        Image image1 = new ProxyImage("HiRes_10MB_Photo1");
        Image image2 = new ProxyImage("HiRes_10MB_Photo2");

        image1.displayImage(); // loading necessary
        image1.displayImage(); // loading unnecessary
        image2.displayImage(); // loading necessary
        image2.displayImage(); // loading unnecessary
        image1.displayImage(); // loading unnecessary
    }
}


उत्पादन

Loading   HiRes_10MB_Photo1
Displaying HiRes_10MB_Photo1
Displaying HiRes_10MB_Photo1
Loading   HiRes_10MB_Photo2
Displaying HiRes_10MB_Photo2
Displaying HiRes_10MB_Photo2
Displaying HiRes_10MB_Photo1

जावास्क्रिप्ट

// Driver class
class Driver {
  constructor (age) {
    this.age = age
  }
}

// Car class
class Car {
  drive () {
    console.log('Car has been driven!')
  }
}

// Proxy car class
class ProxyCar {
  constructor (driver) {
    this.car = new Car()
    this.driver = driver
  }

  drive () {
    if (this.driver.age <= 16) {
      console.log('Sorry, the driver is too young to drive.')
    } else {
      this.car.drive()
    }
  }
}

// Run program
const driver = new Driver(16)
const car = new ProxyCar(driver)
car.drive()

const driver2 = new Driver(25)
const car2 = new ProxyCar(driver2)
car2.drive()


उत्पादन

क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
कार चलाई गई है!

अधिक उन्नत प्रॉक्सी में शामिल हैं Proxy ऑब्जेक्ट, जो गुणों तक पहुँचने जैसे मूलभूत कार्यों को रोक और फिर से परिभाषित कर सकता है। इस मामले में हैंडलर फ़ंक्शंस को कभी-कभी ट्रैप कहा जाता है।[4]


पीएचपी

<?php 

interface Image
{
    public function displayImage();
}

// On System A
class RealImage implements Image
{
    private string $filename = null;

    public function __construct(string $filename)
    {
        $this->filename = $filename;
        $this->loadImageFromDisk();
    }

    /**
     * Loads the image from the disk
     */
    private function loadImageFromDisk()
    {
        echo "Loading {$this->filename}" . \PHP_EOL;
    }

    /**
     * Displays the image
     */
    public function displayImage()
    {
    	echo "Displaying {$this->filename}" . \PHP_EOL;
    }
}

// On System B
class ProxyImage implements Image
{
    private ?Image $image = null;
    private string $filename = null;

    public function __construct(string $filename)
    {
        $this->filename = $filename;
    }

    /**
     * Displays the image
     */
    public function displayImage()
    {
        if ($this->image === null) {
           $this->image = new RealImage($this->filename);
        }
        $this->image->displayImage();
    }
}


$image1 = new ProxyImage("HiRes_10MB_Photo1");
$image2 = new ProxyImage("HiRes_10MB_Photo2");

$image1->displayImage(); // Loading necessary
$image1->displayImage(); // Loading unnecessary
$image2->displayImage(); // Loading necessary
$image2->displayImage(); // Loading unnecessary
$image1->displayImage(); // Loading unnecessary


उत्पादन

Loading HiRes_10MB_Photo1 
Displaying HiRes_10MB_Photo1 
Displaying HiRes_10MB_Photo1 
Loading HiRes_10MB_Photo2 
Displaying HiRes_10MB_Photo2 
Displaying HiRes_10MB_Photo2 
Displaying HiRes_10MB_Photo1

पायथन

"""
Proxy pattern example.
"""
from abc import ABCMeta, abstractmethod


NOT_IMPLEMENTED = "You should implement this."


class AbstractCar:
    __metaclass__ = ABCMeta

    @abstractmethod
    def drive(self):
        raise NotImplementedError(NOT_IMPLEMENTED)


class Car(AbstractCar):
    def drive(self) -> None:
        print("Car has been driven!")


class Driver:
    def __init__(self, age: int) -> None:
        self.age = age


class ProxyCar(AbstractCar):
    def __init__(self, driver) -> None:
        self.car = Car()
        self.driver = driver

    def drive(self) -> None:
        if self.driver.age <= 16:
            print("Sorry, the driver is too young to drive.")
        else:
            self.car.drive()


driver = Driver(16)
car = ProxyCar(driver)
car.drive()

driver = Driver(25)
car = ProxyCar(driver)
car.drive()


उत्पादन

क्षमा करें, ड्राइवर ड्राइव करने के लिए बहुत छोटा है।
कार चलाई गई है!

जंग

trait ICar {
    fn drive(&self);
}

struct Car {}

impl ICar for Car {
    fn drive(&self) {
        println!("Car has been driven!");
    }
}

impl Car {
    fn new() -> Car {
        Car {}
    }
}

struct ProxyCar<'a> {
    real_car: &'a ICar,
    driver_age: i32,
}

impl<'a> ICar for ProxyCar<'a> {
    fn drive(&self) {
        if self.driver_age > 16 {
            self.real_car.drive();
        } else {
            println!("Sorry, the driver is too young to drive.")
        }
    }
}

impl<'a> ProxyCar<'a> {
    fn new(driver_age: i32, other_car: &'a ICar) -> ProxyCar {
        ProxyCar {
            real_car: other_car,
            driver_age: driver_age,
        }
    }
}

#[cfg(test)]
mod tests {
    use super::*;
    
    #[test]
    fn test_underage() {
        let car = Car::new();
        let proxy_car = ProxyCar::new(16, &car);
        proxy_car.drive();
    }

    #[test]
    fn test_can_drive() {
        let car = Car::new();
        let proxy_car = ProxyCar::new(17, &car);
        proxy_car.drive();
    }
}


उत्पादन

क्षमा करें, आपके ड्राइव करने के लिए कार बहुत छोटी है।
कार चलाई गई है!

यह भी देखें

संदर्भ

  1. Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides (1994). Design Patterns: Elements of Reusable Object-Oriented Software. Addison Wesley. pp. 207ff. ISBN 0-201-63361-2.{{cite book}}: CS1 maint: multiple names: authors list (link)
  2. "The Proxy design pattern - Problem, Solution, and Applicability". w3sDesign.com. Retrieved 2017-08-12.
  3. "The Proxy design pattern - Structure and Collaboration". w3sDesign.com. Retrieved 2017-08-12.
  4. "Proxy - JavaScript | MDN". developer.mozilla.org. Retrieved 21 January 2022.


बाहरी संबंध