生成密钥安装证书
邮件的加密与解密需要证书。首要任务是生成证书。我们使用.jks生成证书。所以需要创建.jks文件。通过以下命令生成:
keytool -genkey -alias test -keyalg RSA -validity 1825
-keystore "testmail.jks"
-storetype JKS -dname "CN=Pavan Solapure,O=Opencodez"
-ext san=email:user2@testmail.com
-keypass 123456 -storepass 123456
之后便是生成证书。同时证书需要被本机所认证。我们使用上述生成的.jks文件生成证书并进行安装,使得本机认证生成的证书。这样当发送加密文件的时候,邮件客户端能够正确的证书和密钥。
keytool -importkeystore -srckeystore "testmail.jks"
-destkeystore "testmail.p12" -srcstoretype JKS
-deststoretype PKCS12 -srcstorepass 123456
-deststorepass 123456 -srcalias test -destalias test
-srckeypass 123456 -destkeypass 123456 -noprompt
生成证书后,双击testmail.p12,你将被引导安装文件。之后生成的证书将被本机所认证。
引入jar包
读取证书(MailEncryptionUtil.class)
首先我们先获取证书。
private static X509Certificate getRecipientPublicCertificate(MimeMessage message) throws Exception{
ClassLoader classLoader = MailEncryptionUtil.class.getClassLoader();
File file = new File(classLoader.getResource("testmail.p12").getFile());
FileInputStream fis = new FileInputStream(file);
KeyStore ks = KeyStore.getInstance("PKCS12");
ks.load(fis, "123456".toCharArray());
X509Certificate recipientCert = (X509Certificate) ks.getCertificate("test");
return recipientCert;
}
对邮件信息进行加密
public static MimeMessage encryptMessage(MimeMessage message) throws Exception{
Security.addProvider(new BouncyCastleProvider());
SMIMEEnvelopedGenerator gen = new SMIMEEnvelopedGenerator();
X509Certificate recipientCert = getRecipientPublicCertificate(message);
gen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(recipientCert).setProvider("BC"));
MimeBodyPart msg = new MimeBodyPart();
msg.setContent(message.getContent(), message.getContentType());
MimeBodyPart mp = gen.generate(msg, new JceCMSContentEncryptorBuilder(CMSAlgorithm.RC2_CBC).setProvider("BC").build());
message.setContent(mp.getContent(), mp.getContentType());
message.saveChanges();
return message;
}
首先我们将BouncyCastle作为安全提供者。之后是获取证书。之后是生成可以用于发送了邮件消息类。
邮件的发送(EmailService.class)
public void sendPlainTextMail(Email email){
String host = "localhost";
Properties properties = System.getProperties();
properties.setProperty("mail.smtp.host", host);
Session session = Session.getDefaultInstance(properties);
try {
MimeMessage message = new MimeMessage(session);
BodyPart messageBodyPart = new MimeBodyPart();
message.setFrom(new InternetAddress(email.getFrom()));
message.addRecipient(Message.RecipientType.TO, new InternetAddress(email.getToAsList()));
message.setSubject(email.getSubject());
messageBodyPart.setText(email.getMessage());
Multipart multipart = new MimeMultipart();
multipart.addBodyPart(messageBodyPart);
message.setText(email.getMessage());
//Transport.send(message);
Transport.send(MailEncryptionUtil.encryptMessage(message));
System.out.println("Sent message successfully.");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
首先我们要在Session服务器中配置邮件服务器的基本信息。之后指定邮件的发送发、接收方、主题和内容等信息。之后是用之前写的MailEncryptionUtil对邮件信息进行加密并发送。
在主类中指定发送邮件的基本信息
public static void main(String[] args) {
String from = "rhf0410@testmail.com";
String to = "user2@testmail.com";
String subject = "Java mail which has been encrypted";
String message = "Hello encrypted mail.";
Email email = new Email(from, to, subject, message);
//Sent email
emailService.sendPlainTextMail(email);
}
网友评论