जावामेल एपीआई - कोर क्लासेस
JavaMail API में ई-मेल संदेश भेजने, पढ़ने और हटाने के लिए उपयोग किए जाने वाले कुछ इंटरफेस और कक्षाएं शामिल हैं। हालाँकि JavaMail API में कई पैकेज हैं, वे मुख्य दो पैकेजों को कवर करेंगे जिनका उपयोग जावा मेल एपीआई में अक्सर किया जाता है: javax.mail और javax.mail.internet पैकेज। इन पैकेजों में सभी जावामैल कोर क्लास होते हैं। वो हैं:
कक्षा | विवरण |
---|---|
javax.mail.Session | एपीआई का प्रमुख वर्ग। एक मल्टीथ्रेडेड ऑब्जेक्ट कनेक्शन फ़ैक्टरी का प्रतिनिधित्व करता है। |
javax.mail.Message | एक अमूर्त वर्ग जो एक ई-मेल संदेश मॉडल करता है। उपवर्ग वास्तविक कार्यान्वयन प्रदान करते हैं। |
javax.mail.Address | एक अमूर्त वर्ग जो एक संदेश में पते (से और पते से) को मॉडल करता है। उपवर्ग विशिष्ट कार्यान्वयन प्रदान करते हैं। |
javax.mail.Authenticator | मेल सर्वर पर मेल संसाधनों की रक्षा के लिए एक अमूर्त वर्ग का उपयोग किया जाता है। |
javax.mail.Transport | एक सार वर्ग जो एक ई-मेल संदेश भेजने के लिए एक संदेश परिवहन तंत्र को मॉडल करता है। |
javax.mail.Store | एक अमूर्त वर्ग जो संदेशों को संग्रहीत करने और पुनर्प्राप्त करने के लिए एक संदेश स्टोर और इसके एक्सेस प्रोटोकॉल को मॉडल करता है। एक स्टोर फोल्डर्स में विभाजित है। |
javax.mail.Folder | एक अमूर्त वर्ग जो मेल संदेशों के एक फ़ोल्डर का प्रतिनिधित्व करता है। इसमें सबफ़ोल्डर्स हो सकते हैं। |
javax.mail.internet।MimeMessage | संदेश एक सार वर्ग है, इसलिए एक उपवर्ग के साथ काम करना चाहिए; ज्यादातर मामलों में, आप एक MimeMessage का उपयोग करेंगे। एक MimeMessage एक ई-मेल संदेश है जो MIME प्रकार और हेडर को समझता है। |
javax.mail.internet।InternetAddress | यह वर्ग RFC822 के सिंटैक्स का उपयोग करके एक इंटरनेट ईमेल पते का प्रतिनिधित्व करता है। विशिष्ट पता वाक्य रचना उपयोगकर्ता@host.domain या व्यक्तिगत नाम <[email protected]> का है । |
आइए हम इनमें से प्रत्येक कक्षा का विस्तार से अध्ययन करें और बाद के अध्यायों में हम इनमें से प्रत्येक का उपयोग करके उदाहरणों का अध्ययन करेंगे।
सत्र कक्षा
सत्र वर्ग JavaMail एपीआई के प्राथमिक वर्ग है और यह subclassed नहीं है। सत्र वस्तु JavaMail एपीआई, जो दोनों कॉन्फ़िगरेशन सेटिंग और प्रमाणीकरण संभालती के लिए कनेक्शन कारखाने के रूप में कार्य करता है।
सत्र वस्तु को निम्नलिखित तरीकों से बनाया जा सकता है:
JNDI सेवा में संग्रहीत प्रशासित वस्तु को देखकर
InitialContext ctx = new InitialContext(); Session session = (Session) ctx.lookup("usersMailSession");
usersMailSession JNDI नाम ऑब्जेक्ट है जिसे सत्र ऑब्जेक्ट के लिए प्रशासित ऑब्जेक्ट के रूप में उपयोग किया जाता है। userMailSession नाम / मूल्य जोड़े के रूप में आवश्यक पैरामीटर के साथ बनाया और कॉन्फ़िगर किया जा सकता है, जिसमें मेल सर्वर होस्टनाम, मेल भेजने वाले उपयोगकर्ता खाते और सत्र ऑब्जेक्ट द्वारा समर्थित प्रोटोकॉल जैसी जानकारी शामिल है।
सत्र ऑब्जेक्ट बनाने का एक अन्य तरीका प्रोग्रामेटिक दृष्टिकोण पर आधारित है जिसमें आप java.util.Properties ऑब्जेक्ट का उपयोग कर कुछ डिफ़ॉल्ट जानकारी को ओवरराइड कर सकते हैं , जैसे कि मेल सर्वर का नाम, उपयोगकर्ता नाम, पासवर्ड और अन्य जानकारी जो हो सकती है आपके पूरे एप्लिकेशन को साझा किया गया।
सत्र वर्ग के लिए कंस्ट्रक्टर निजी है । इसलिए सत्र वर्ग दो तरीके (नीचे सूचीबद्ध) प्रदान करता है जो सत्र वस्तु प्राप्त करते हैं ।
getDefaultInstance(): GetDefaultInstance () विधि का उपयोग करके सत्र ऑब्जेक्ट प्राप्त करने के दो तरीके हैं। यह डिफ़ॉल्ट सत्र लौटाता है।
public static Session getDefaultInstance(Properties props) public static Session getDefaultInstance(Properties props,Authenticator auth)
getInstance(): GetInstance () विधि का उपयोग करके सत्र ऑब्जेक्ट प्राप्त करने के दो तरीके हैं। यह नया सत्र लौटाता है।
public static Session getInstance(Properties props) public static Session getInstance(Properties props,Authenticator auth)
संदेश वर्ग
सत्र ऑब्जेक्ट के साथ हम अब एक संदेश बनाने के लिए आगे बढ़ते हैं जिसे भेजा जाएगा। संदेश का प्रकार javax.mail.Message होगा ।
संदेश एक सार वर्ग है। इसलिए इसका उपवर्ग javax.mail.internet.MimeMessage वर्ग ज्यादातर उपयोग किया जाता है।
संदेश बनाने के लिए, आपको MimeMessage क्लास कंस्ट्रक्टर में सत्र ऑब्जेक्ट पास करना होगा। उदाहरण के लिए:
MimeMessage message=new MimeMessage(session);
संदेश ऑब्जेक्ट बन जाने के बाद हमें उसमें जानकारी संग्रहीत करने की आवश्यकता होती है। संदेश वर्ग javax.mail.Part इंटरफ़ेस को लागू करता है जबकि javax.mail.internet। MimeMessage लागू करता है javax.mail.internet.MimePart। सामग्री को संग्रहीत करने के लिए आप या तो message.setContent () या mimeMessage.setText () का उपयोग कर सकते हैं।
MimeMessage वर्ग के सामान्य रूप से उपयोग किए जाने वाले तरीके हैं
तरीका विवरण सार्वजनिक शून्य सेटफ़ॉर्म (पता पता) हेडर फ़ील्ड से सेट करने के लिए उपयोग किया जाता है। सार्वजनिक शून्य addRecipients (Message.RecipientType प्रकार, स्ट्रिंग पते) प्राप्तकर्ता प्रकार में दिए गए पते को जोड़ने के लिए उपयोग किया जाता है। सार्वजनिक शून्य सेट करें विषय (स्ट्रिंग विषय) विषय हेडर फ़ील्ड सेट करने के लिए उपयोग किया जाता है। सार्वजनिक शून्य सेटटैक्स (स्ट्रिंग टेक्स्टस्मेज) पाठ / सादे MIME प्रकार का उपयोग करके संदेश सामग्री के रूप में पाठ को सेट करने के लिए उपयोग किया जाता है।
पता कक्षा
अब जब हमारे पास एक सत्र और संदेश (इसमें संग्रहीत सामग्री के साथ) ऑब्जेक्ट हैं, तो हमें एड्रेस ऑब्जेक्ट का उपयोग करके पत्र को संबोधित करना होगा ।
पता एक अमूर्त वर्ग है। इसलिए इसका उपवर्ग javax.mail.internet.InternetAddress वर्ग ज्यादातर उपयोग किया जाता है।
केवल पासिंग ईमेल एड्रेस द्वारा पता बनाया जा सकता है:
Address address = new InternetAddress("[email protected]");
पता बनाने का एक और तरीका है ईमेल पते को नाम के साथ पास करके:
Address address = new InternetAddress("[email protected]", Manisha);
आप नीचे दिए अनुसार To, From, CC, BCC फ़ील्ड्स भी सेट कर सकते हैं
message.setFrom(address)
message.addRecipient (प्रकार, पता)
तीन पूर्वनिर्धारित पते प्रकार इनमें से एक मान के साथ ऑब्जेक्ट हैं:
Message.RecipientType.TO
Message.RecipientType.CC
Message.RecipientType.BCC
प्रमाणक वर्ग
वर्ग प्रमाणक एक वस्तु का प्रतिनिधित्व करता है जो जानता है कि नेटवर्क कनेक्शन के लिए प्रमाणीकरण कैसे प्राप्त किया जाए। आमतौर पर, यह जानकारी के लिए उपयोगकर्ता को संकेत देकर ऐसा करेगा।
प्रमाणक एक अमूर्त वर्ग है। आप एक उपवर्ग बनाने PasswordAuthentication , इसके निर्माता के लिए एक उपयोगकर्ता नाम और पासवर्ड गुजर।
सत्र ऑब्जेक्ट बनाते समय आपको सत्र के साथ प्रमाणीकरणकर्ता को पंजीकृत करना होगा।
निम्नलिखित प्रमाणीकरण उपयोग का एक उदाहरण है :
Properties props = new Properties();
//Override props with any customized data
PasswordAuthentication auth = new PasswordAuthentication("manisha", "pswrd")
Session session = Session.getDefaultInstance(props, auth);
ट्रांसपोर्ट क्लास
संदेश परिवहन तंत्र के रूप में परिवहन वर्ग का उपयोग किया जाता है। यह वर्ग आम तौर पर संदेश भेजने के लिए एसएमटीपी प्रोटोकॉल का उपयोग करता है।
यह एक अमूर्त वर्ग है।
आप केवल स्थैतिक भेजने () विधि को कॉल करके कक्षा के डिफ़ॉल्ट संस्करण का उपयोग कर सकते हैं :
Transport.send(message);
संदेश भेजने का दूसरा तरीका आपके प्रोटोकॉल के लिए सत्र से एक विशिष्ट उदाहरण प्राप्त करना है, उपयोगकर्ता नाम और पासवर्ड के साथ पास करें (यदि अनावश्यक हो तो), संदेश भेजें, और कनेक्शन बंद करें:
message.saveChanges(); // implicit with send() //Get transport for session Transport transport = session.getTransport("smtp"); //Connect transport.connect(host, username, password); //repeat if necessary transport.sendMessage(message, message.getAllRecipients()); //Done, close the connection transport.close();
स्टोर क्लास
एक अमूर्त वर्ग जो संदेशों को संग्रहीत करने और पुनर्प्राप्त करने के लिए एक संदेश स्टोर और इसके एक्सेस प्रोटोकॉल को मॉडल करता है। उपवर्ग वास्तविक कार्यान्वयन प्रदान करते हैं। स्टोर सेवा वर्ग का विस्तार करता है, जो दुकानों के नामकरण, दुकानों से जुड़ने और कनेक्शन घटनाओं को सुनने के लिए कई सामान्य तरीके प्रदान करता है।
डेटाबेस स्टोर प्रोटोकॉल को लागू करने वाले स्टोर ऑब्जेक्ट को प्राप्त करके ग्राहक मैसेज स्टोर तक पहुंच प्राप्त करते हैं। अधिकांश मैसेज स्टोर को एक्सेस की अनुमति देने से पहले उपयोगकर्ता को प्रमाणित करने की आवश्यकता होती है। कनेक्ट विधि प्रमाणीकरण करती है।
Store store = session.getStore("pop3");
store.connect(host, username, password);
फोल्डर क्लास
फ़ोल्डर एक अमूर्त वर्ग है जो मेल संदेशों के लिए एक फ़ोल्डर का प्रतिनिधित्व करता है। उपवर्ग प्रोटोकॉल विशिष्ट फ़ोल्डरों को लागू करते हैं। फ़ोल्डरों में सबफ़ोल्डर के साथ-साथ संदेश भी हो सकते हैं, इस प्रकार एक पदानुक्रमित संरचना प्रदान की जा सकती है।
स्टोर से कनेक्ट होने के बाद, आप एक फ़ोल्डर प्राप्त कर सकते हैं, जिसे इससे पहले कि आप संदेश पढ़ सकें, उसे खोलना होगा।
Folder folder = store.getFolder("INBOX");
folder.open(Folder.READ_ONLY);
Message message[] = folder.getMessages();
GetFolder (स्ट्रिंग नाम) एक फ़ोल्डर वस्तु के लिए विधि नामित सबफ़ोल्डर देता है। मेल पढ़ने के बाद स्टोर और फोल्डर कनेक्शन दोनों को बंद करें।
हम स्टोर और फोल्डर को नीचे की छवि के संबंध में देख सकते हैं:
जैसा कि हम देख सकते हैं, प्रत्येक उपयोगकर्ता खाते के लिए, सर्वर में एक स्टोर होता है जो उपयोगकर्ता के संदेशों का भंडारण होता है। स्टोर फ़ोल्डर में विभाजित है, और "इनबॉक्स" फ़ोल्डर मुख्य रूप से फ़ोल्डर है जिसमें ई-मेल संदेश शामिल हैं। एक फ़ोल्डर में संदेश और उप-फ़ोल्डर दोनों हो सकते हैं।