


Menghantar E-mel Menggunakan Java
Isu:
Ralat berlaku apabila cuba menghantar e-mel menggunakan Java disebabkan sambungan masalah dengan localhost SMTP pelayan.
Soalan:
Bolehkah kod yang disediakan digunakan untuk menghantar e-mel?
Jawapan:
Kod yang disediakan untuk menghantar e-mel menggunakan Java, yang menggunakan tetapan lalai untuk pelayan mel, mungkin tidak berfungsi dalam semua kes. Khususnya, pelayan SMTP localhost tidak mungkin berfungsi secara lalai.
Penyelesaian:
Untuk menghantar e-mel dengan pasti menggunakan Java, pertimbangkan untuk menggunakan pelayan SMTP pihak ketiga seperti sebagai Google Mail. Berikut ialah coretan kod yang menunjukkan cara menghantar e-mel melalui pelayan SMTP Google menggunakan API dan pengesahan oAuth2 mereka:
import com.google.api.client.auth.oauth2.Credential; import com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver; import com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow; import com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets; import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport; import com.google.api.client.http.HttpTransport; import com.google.api.client.json.gson.GsonFactory; import com.google.api.client.util.store.FileDataStoreFactory; import com.google.api.services.gmail.Gmail; import com.google.api.services.gmail.model.Message; import java.io.File; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; import java.security.GeneralSecurityException; import java.util.HashSet; import java.util.Properties; import java.util.Set; import javax.mail.MessagingException; import javax.mail.Session; import javax.mail.internet.InternetAddress; import javax.mail.internet.MimeMessage; public class GoogleMail { private static final GsonFactory JSON_FACTORY = GsonFactory.getDefaultInstance(); private static final HttpTransport HTTP_TRANSPORT; private static final File DATA_STORE_DIRECTORY = getGmailDataDirectory(); static { try { HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport(); } catch (GeneralSecurityException | IOException e) { throw new RuntimeException(e); } } private static Gmail getGmailService(Credential credential) throws IOException { return new Gmail.Builder(HTTP_TRANSPORT, JSON_FACTORY, credential).setApplicationName("My Gmail App").build(); } private static File getGmailDataDirectory() { return new File(org.yccheok.jstock.gui.Utils.getUserDataDirectory() + "authentication" + File.separator + "gmail"); } public static void sendEmail(String to, String subject, String message) throws MessagingException, IOException { // Get the email account from saved credentials String email = loadEmail(DATA_STORE_DIRECTORY); if (email == null) { // If no credentials saved, request user authorization Pair<pair string>, Boolean> credentials = authorizeGmail(); if (!credentials.second) { throw new RuntimeException("Failed to get credentials from user"); } email = credentials.first.second; // Save the email address for future use saveEmail(DATA_STORE_DIRECTORY, email); } // Create a MIME message Properties props = new Properties(); Session session = Session.getDefaultInstance(props, null); MimeMessage emailMessage = new MimeMessage(session); // Set the sender's email address InternetAddress sender = new InternetAddress(email); emailMessage.setFrom(sender); // Set the recipient's email address InternetAddress recipient = new InternetAddress(to); emailMessage.addRecipient(Message.RecipientType.TO, recipient); // Set the subject and the message body emailMessage.setSubject(subject); emailMessage.setText(message); // Get the authorized credentials Credential credential = credentialsPair.first.first; // Create a Gmail service object Gmail gmailService = getGmailService(credential); // Create a message object and send the email Message messageObject = createMessageWithEmail(emailMessage); gmailService.users().messages().send("me", messageObject).execute(); } private static Message createMessageWithEmail(MimeMessage emailMessage) throws MessagingException, IOException { ByteArrayOutputStream baos = new ByteArrayOutputStream(); emailMessage.writeTo(baos); String encodedEmail = Base64.encodeBase64URLSafeString(baos.toByteArray()); return new Message().setRaw(encodedEmail); } private static Pair<pair string>, Boolean> authorizeGmail() throws IOException { // Load client secrets from a resource file GoogleClientSecrets clientSecrets = GoogleClientSecrets.load(JSON_FACTORY, new InputStreamReader(GoogleMail.class.getResourceAsStream("/client_secrets.json"))); // Define the OAuth 2.0 scopes to request Set<string> scopes = new HashSet(); scopes.add(GmailScopes.GMAIL_SEND); // Build the Google Authorization Code Flow object GoogleAuthorizationCodeFlow flow = new GoogleAuthorizationCodeFlow.Builder( HTTP_TRANSPORT, JSON_FACTORY, clientSecrets, scopes) .setDataStoreFactory(new FileDataStoreFactory(DATA_STORE_DIRECTORY)) .build(); // Request the user's authorization return new MyAuthorizationCodeInstalledApp(flow, new LocalServerReceiver()).authorize("user"); } } // Call the sendEmail method to send the email GoogleMail.sendEmail("recipient@example.com", "Subject", "Message");</string></pair></pair>
Nota Tambahan:
- The authorizeGmail( ) kaedah melaksanakan pengesahan oAuth2 dan mengembalikan sepasang Kredensial dan an alamat e-mel.
- Untuk meminta kebenaran pengguna, kelas MyAuthorizationCodeInstalledApp digunakan, memaparkan antara muka pengguna yang mudah.
- Kaedah sendEmail() menghantar e-mel menggunakan perkhidmatan Gmail dan mesej MIME.
- Untuk mengelakkan pengekodan keras maklumat sensitif, pertimbangkan untuk menggunakan pembolehubah persekitaran atau pengurus rahsia untuk rahsia pelanggan dan lain-lain kelayakan.
Atas ialah kandungan terperinci Bolehkah saya menghantar e-mel menggunakan Java dengan pelayan SMTP localhost tanpa sebarang konfigurasi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Java digunakan secara meluas dalam aplikasi peringkat perusahaan kerana kemerdekaan platformnya. 1) Kemerdekaan platform dilaksanakan melalui Java Virtual Machine (JVM), supaya kod itu dapat dijalankan di mana -mana platform yang menyokong Java. 2) Ia memudahkan proses penyebaran dan pembangunan silang platform, memberikan kelonggaran dan skalabiliti yang lebih besar. 3) Walau bagaimanapun, adalah perlu untuk memberi perhatian kepada perbezaan prestasi dan keserasian perpustakaan pihak ketiga dan mengamalkan amalan terbaik seperti menggunakan kod Java tulen dan ujian silang platform.

JavaPlaysasignificantroleiniotduetoitsplatformindant.1) itAllowscodetobewrittenceandondrariousdevices.2) Java'secosystemprovidesuseFullibrariesforiot.3)

ThesolutionToHandleFilePathsacrossWindowsandLinuxinjavaistousePaths.get () dariTheJava.nio.FilePackage.1) UsePaths.get () WithSystem.GetProperty ("user.dir")

Java'splatformindectiveissignificantantbecauseitallowsdeveloperstowritecodeonceandrunitonanyplatformwithajvm.This "writeonce, runanywhere" (wora) dearflofers: 1) cross-platformcompatuibility, enablingdeploymentacsdifferentoswithoutoSesen)

Java sesuai untuk membangunkan aplikasi web cross-server. 1) Falsafah "Tulis Sekali, Di Mana -mana" Java membuat kodnya dijalankan di mana -mana platform yang menyokong JVM. 2) Java mempunyai ekosistem yang kaya, termasuk alat seperti Spring dan Hibernate, untuk memudahkan proses pembangunan. 3) Java melaksanakan dengan baik dalam prestasi dan keselamatan, menyediakan pengurusan memori yang cekap dan jaminan keselamatan yang kuat.

JVM melaksanakan ciri-ciri Wora Java melalui tafsiran bytecode, API bebas platform dan pemuatan kelas dinamik: 1. Bytecode ditafsirkan sebagai kod mesin untuk memastikan operasi silang platform; 2. Perbezaan sistem operasi abstrak API standard; 3. Kelas dimuatkan secara dinamik pada masa runtime untuk memastikan konsistensi.

Versi terbaru Java berkesan menyelesaikan masalah khusus platform melalui pengoptimuman JVM, penambahbaikan perpustakaan standard dan sokongan perpustakaan pihak ketiga. 1) Pengoptimuman JVM, seperti ZGC Java11 meningkatkan prestasi pengumpulan sampah. 2) Penambahbaikan perpustakaan standard, seperti sistem modul Java9 yang mengurangkan masalah berkaitan platform. 3) Perpustakaan pihak ketiga menyediakan versi yang dioptimumkan platform, seperti OpenCV.

Proses pengesahan bytecode JVM termasuk empat langkah utama: 1) Periksa sama ada format fail kelas mematuhi spesifikasi, 2) mengesahkan kesahihan dan ketepatan arahan bytecode, 3) melakukan analisis aliran data untuk memastikan keselamatan jenis, dan 4) mengimbangi ketelitian dan prestasi pengesahan. Melalui langkah -langkah ini, JVM memastikan bahawa hanya selamat, bytecode yang betul dilaksanakan, dengan itu melindungi integriti dan keselamatan program.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.
