जावा एनआईओ - सर्वरस्केट चैनल

Java NIO सर्वर सॉकेट चैनल फिर से एक चुनिंदा प्रकार का चैनल है जो धारा उन्मुख डेटा प्रवाह को सॉकेट से कनेक्ट करने के लिए उपयोग किया जाता है। Sver सॉकेट चैनल को अपने स्थैतिक को शामिल करके बनाया जा सकता है open() विधि, कोई भी पहले से मौजूद सॉकेट प्रदान करना पहले से मौजूद नहीं है। सेवर सॉकेट चैनल खुली विधि को लागू करके बनाया गया है, लेकिन अभी तक बाध्य नहीं है। सॉकेट चैनल को बाध्य करने के लिए bind() विधि कहलाती है।

यहां उल्लेख किया जाने वाला एक बिंदु यह है कि यदि चैनल बाध्य नहीं है और किसी भी I / O ऑपरेशन का प्रयास करने की कोशिश की जाती है तो NotYetBoundException को इस चैनल द्वारा फेंक दिया जाता है। किसी को यह सुनिश्चित करना होगा कि चैनल किसी IO ऑपरेशन को करने से पहले बाध्य है।

सर्वर सॉकेट चैनल के लिए आने वाले कनेक्शन ServerSocketChannel.accept () विधि को कॉल करके सुनते हैं। जब स्वीकार () विधि वापस आती है, तो यह एक सॉकेटचैनल को एक आने वाले कनेक्शन के साथ देता है। इस प्रकार, आवक कनेक्शन आने तक स्वीकार () विधि अवरुद्ध हो जाती है। यदि चैनल गैर-अवरुद्ध मोड में है, तो स्वीकार विधि तुरंत लंबित होने पर शून्य वापस आ जाएगी। अन्यथा यह अनिश्चित काल तक अवरुद्ध रहेगा जब तक कि एक नया कनेक्शन उपलब्ध न हो या I / O त्रुटि न हो।

नए चैनल का सॉकेट शुरू में अनबाउंड है; यह कनेक्शन स्वीकार किए जाने से पहले अपने सॉकेट के बाइंड विधियों में से एक के माध्यम से एक विशिष्ट पते पर होना चाहिए। इसके अलावा, नया चैनल सिस्टम-वाइड डिफॉल्ट सेलेक्टरप्रॉइडर ऑब्जेक्ट के ओपनसर्वर सॉकेटचैनल विधि को लागू करके बनाया जाता है।

सॉकेट चैनल सर्वर सॉकेट चैनल की तरह डेटा का उपयोग कर पढ़ सकता है read()Method। पूरी तरह से बफर आवंटित किया गया है। ServerSocketChannel से पढ़ा गया डेटा बफर में स्टोर हो जाता है। इसके अलावा हम ServerSocketChannel.read () विधि को कॉल करते हैं और यह ServerSocketChannel के डेटा को बफर में पढ़ता है। रीड () विधि का पूर्णांक मान बफर में कितने बाइट्स लिखा गया था

इसी तरह डेटा को सर्वर सॉकेट चैनल का उपयोग करके लिखा जा सकता है write() बफ़र को पैरामीटर के रूप में उपयोग करने की विधि। एक समय में लूप में लिखने की विधि का उपयोग करता है जब तक कि बफ़र के पास लिखने के लिए उपलब्ध न हो तब तक लिखने () विधि को दोहराने की आवश्यकता होती है।

सॉकेट चैनल के महत्वपूर्ण तरीके

  • bind(SocketAddress local) - इस विधि का उपयोग सॉकेट चैनल को स्थानीय पते पर बाँधने के लिए किया जाता है जो इस विधि के पैरामीटर के रूप में प्रदान किया जाता है।

  • accept() - इस विधि का उपयोग इस चैनल के सॉकेट में किए गए कनेक्शन को स्वीकार करने के लिए किया जाता है।

  • connect(SocketAddress remote) - इस विधि का उपयोग सॉकेट को दूरस्थ पते से जोड़ने के लिए किया जाता है।

  • finishConnect() - इस विधि का उपयोग सॉकेट चैनल को जोड़ने की प्रक्रिया को पूरा करने के लिए किया जाता है।

  • getRemoteAddress() - यह विधि रिमोट लोकेशन के पते को लौटाती है जिससे चैनल का सॉकेट जुड़ा होता है।

  • isConnected() - जैसा कि पहले ही उल्लेख किया गया है कि यह विधि सॉकेट चैनल के कनेक्शन की स्थिति लौटाती है अर्थात यह जुड़ा हुआ है या नहीं।

  • open() - ओपन मेथड का उपयोग बिना किसी निर्दिष्ट पते के लिए सॉकेट चैनल खोलने के लिए किया जाता है। यह सुविधा विधि इस तरह काम करती है जैसे कि ओपन () विधि को लागू करने से, परिणामस्वरूप सर्वर सॉकेट चैनल पर कनेक्ट विधि को लागू करना, इसे दूरस्थ रूप से पारित करना, और फिर उस चैनल को वापस करना।

  • read(ByteBuffer dst) - इस विधि का उपयोग सॉकेट चैनल के माध्यम से दिए गए बफर के डेटा को पढ़ने के लिए किया जाता है।

  • setOption(SocketOption<T> name, T value) - यह विधि सॉकेट विकल्प का मान सेट करती है।

  • socket() - यह विधि इस चैनल से जुड़े सर्वर सॉकेट को पुनः प्राप्त करती है।

  • validOps() - यह विधि इस चैनल के समर्थित संचालनों की पहचान करते हुए एक ऑपरेशन सेट लौटाती है। सेवर-सॉकेट चैनल केवल नए कनेक्शन स्वीकार करने का समर्थन करते हैं, इसलिए यह विधि SelectionKey.OP_ACCEPT देता है।

उदाहरण

निम्न उदाहरण दिखाता है कि जावा NIO ServerShanChannel से डेटा कैसे भेजा जाए।

सी: /Test/temp.txt

Hello World!

ग्राहक: सॉकेटचैनलाइनक्लाइंट। जावा

import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardOpenOption;
import java.util.EnumSet;

public class SocketChannelClient {
   public static void main(String[] args) throws IOException {
      ServerSocketChannel serverSocket = null;
      SocketChannel client = null;
      serverSocket = ServerSocketChannel.open();
      serverSocket.socket().bind(new InetSocketAddress(9000));
      client = serverSocket.accept();
      System.out.println("Connection Set:  " + client.getRemoteAddress());
      Path path = Paths.get("C:/Test/temp1.txt");
      FileChannel fileChannel = FileChannel.open(path, 
         EnumSet.of(StandardOpenOption.CREATE, 
            StandardOpenOption.TRUNCATE_EXISTING,
            StandardOpenOption.WRITE)
         );      
      ByteBuffer buffer = ByteBuffer.allocate(1024);
      while(client.read(buffer) > 0) {
         buffer.flip();
         fileChannel.write(buffer);
         buffer.clear();
      }
      fileChannel.close();
      System.out.println("File Received");
      client.close();
   }
}

उत्पादन

क्लाइंट को चलाने से सर्वर शुरू होने तक कुछ भी प्रिंट नहीं होगा।

सर्वर: सॉकेटचैनलाइनरवर.जावा

import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.channels.SocketChannel;
import java.nio.file.Path;
import java.nio.file.Paths;

public class SocketChannelServer {
   public static void main(String[] args) throws IOException {
      SocketChannel server = SocketChannel.open();
      SocketAddress socketAddr = new InetSocketAddress("localhost", 9000);
      server.connect(socketAddr);
      Path path = Paths.get("C:/Test/temp.txt");
      FileChannel fileChannel = FileChannel.open(path);
      ByteBuffer buffer = ByteBuffer.allocate(1024);
      while(fileChannel.read(buffer) > 0) {
         buffer.flip();
         server.write(buffer);
         buffer.clear();
      }
      fileChannel.close();
      System.out.println("File Sent");
      server.close();
   }
}

उत्पादन

सर्वर चलाना निम्नलिखित प्रिंट करेगा।

Connection Set:  /127.0.0.1:49558
File Received