जावामेल एपीआई - कोटा प्रबंधन
जावामेल में एक कोटा एक ईमेल स्टोर में सीमित या निश्चित संख्या या संदेशों की मात्रा है। प्रत्येक मेल सेवा अनुरोध JavaMail API कॉल कोटा की ओर गिना जाता है। एक ईमेल सेवा निम्नलिखित मानदंड लागू कर सकती है:
अटैचमेंट सहित आउटगोइंग मेल संदेशों का अधिकतम आकार।
संलग्नक सहित आने वाले मेल संदेशों का अधिकतम आकार।
संदेश का अधिकतम आकार जब एक व्यवस्थापक प्राप्तकर्ता होता है
कोटा प्रबंधन के लिए JavaMail में निम्न वर्ग हैं:
कक्षा | विवरण |
---|---|
सार्वजनिक वर्ग कोटा | यह वर्ग दिए गए कोटा रूट के लिए कोटा के एक सेट का प्रतिनिधित्व करता है। प्रत्येक कोटा रूट में संसाधनों का एक समूह होता है, जिसे कोटा.स्रोत वर्ग द्वारा दर्शाया गया है। प्रत्येक संसाधन का एक नाम है (उदाहरण के लिए, "स्टोरेज"), एक वर्तमान उपयोग और एक उपयोग सीमा। यह केवल एक विधि सेट है ।ResourceLimit (स्ट्रिंग नाम, लंबी सीमा) । |
सार्वजनिक स्थिर वर्ग कोटा। स्रोत | कोटा रूट में एक व्यक्तिगत संसाधन का प्रतिनिधित्व करता है। |
सार्वजनिक इंटरफ़ेस QuotaAwareStore | भंडार द्वारा कार्यान्वित एक इंटरफ़ेस जो कोटा का समर्थन करता है। GetQuota और setQuota तरीकों कोटा मॉडल IMAP कोटा विस्तार से परिभाषित किया समर्थन करते हैं। GmailSSLStore, GmailStore, IMAPSSLStore, IMAPStore इस इंटरफ़ेस की ज्ञात कार्यान्वयन कक्षाएं हैं। |
हमें निम्न अनुभागों में देखते हैं और उदाहरण देते हैं जो मेल स्टोरेज नाम, सीमा और इसके उपयोग के लिए जाँच करता है।
जावा क्लास बनाएं
एक जावा वर्ग फ़ाइल बनाएँ QuotaExampleकी सामग्री इस प्रकार है:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Quota;
import javax.mail.Session;
import javax.mail.Store;
import com.sun.mail.imap.IMAPStore;
public class QuotaExample
{
public static void main(String[] args)
{
try
{
Properties properties = new Properties();
properties.put("mail.store.protocol", "imaps");
properties.put("mail.imaps.port", "993");
properties.put("mail.imaps.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
// emailSession.setDebug(true);
// create the IMAP3 store object and connect with the pop server
Store store = emailSession.getStore("imaps");
//change the user and password accordingly
store.connect("imap.gmail.com", "[email protected]", "*****");
IMAPStore imapStore = (IMAPStore) store;
System.out.println("imapStore ---" + imapStore);
//get quota
Quota[] quotas = imapStore.getQuota("INBOX");
//Iterate through the Quotas
for (Quota quota : quotas) {
System.out.println(String.format("quotaRoot:'%s'",
quota.quotaRoot));
//Iterate through the Quota Resource
for (Quota.Resource resource : quota.resources) {
System.out.println(String.format(
"name:'%s', limit:'%s', usage:'%s'", resource.name,
resource.limit, resource.usage));
}
}
} catch (Exception e)
{
e.printStackTrace();
}
}
}
यहाँ IMAP (imap.gmail.com) सर्वर के माध्यम से जीमेल सेवा के लिए कनेक्शन हैं, क्योंकि IMAPStore QuotaAwareStore को लागू करता है। एक बार जब आप स्टोर ऑब्जेक्ट प्राप्त करते हैं, तो कोटा सरणी प्राप्त करें और इसके माध्यम से पुनरावृत्त करें और संबंधित जानकारी प्रिंट करें।
संकलित करें और चलाएँ
अब जब हमारी कक्षा तैयार हो गई है, तो हम उपरोक्त वर्ग को संकलित करें। मैंने निर्देशिका के लिए QuotaExample.java वर्ग को बचाया है:/home/manisha/JavaMailAPIExercise। हम जार की आवश्यकता होगी javax.mail.jar और activation.jar classpath में। वर्ग को संकलित करने के लिए नीचे दिए गए आदेश को निष्पादित करें (दोनों जार कमांड प्रॉम्प्ट से / होम / मनीषा / निर्देशिका में रखे गए हैं:
javac -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: QuotaExample.java
अब जब क्लास संकलित है, चलाने के लिए नीचे दिए गए कमांड को निष्पादित करें:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: QuotaExample
आउटपुट सत्यापित करें
आपको कमांड कंसोल पर एक समान संदेश देखना चाहिए:
imapStore ---imaps://abc%[email protected]
quotaRoot:''
name:'STORAGE', limit:'15728640', usage:'513'