Java web

基于Java的邮件加密解密

2020-02-20  本文已影响0人  BlueSkyBlue

生成密钥安装证书

邮件的加密与解密需要证书。首要任务是生成证书。我们使用.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);
}
上一篇下一篇

猜你喜欢

热点阅读