我需要通过HTTP获取excel电子表格,然后将其作为附件发送到我的Java Spring服务器上的电子邮件。
我发现的问题是MultiPartEmail.attach()只接受java.net.URL实例,我无法弄清楚如何确保请求在其标头中有一定的Cookie用于身份验证。
url = new URL(urlString);
email.attach(url, "test.xls", "File");
email.send();
我试图手动请求并创建一个工作簿,但后来我很难将工作簿本身附加到MultiPartEmail。
HttpClient client = new HttpClient();
GetMethod method = new GetMethod(queryString);
method.setRequestHeader("Cookie", cookie);
client.executeMethod(method);
InputStream stream = method.getResponseBodyAsStream();
Workbook workbook = Workbook.getWorkbook(stream);
email.attach(workbook, "report.xls", "forecasting report");
我需要一些方法来解决这些限制。
提前感谢您的时间。
答案 0 :(得分:1)
由于您使用的是Spring,因此您可以使用其内置的电子邮件支持来发送电子邮件。因此,无论您如何从磁盘或其他位置检索文件。您可以使用MimeMessageHelper发送带附件的电子邮件,并在邮件主机上指定帐户的用户名和密码,以进行身份验证,如下所示:
public class EmailNotifier {
private JavaMailSenderImpl mailSender;
public void setMailSender(JavaMailSenderImpl mailSender) {
this.mailSender = mailSender;
}
public void sendMail(InternetAddress fromAddress, InternetAddress toAddress, String subject, String msg) {
MimeMessage message = mailSender.createMimeMessage();
try {
// use the true flag to indicate you need a multipart message
MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setFrom(fromAddress);
helper.setTo(toAddress);
helper.setSubject(subject);
helper.setText(msg);
// let's attach the infamous windows Sample file (this time copied to c:/)
FileSystemResource file = new FileSystemResource(new File("c:/test.xls"));
helper.addAttachment("test.xls", file);
mailSender.send(message);
} catch (MessagingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
并在bean配置文件中配置JavaMailSenderImpl bean。这是通过Gmail发送电子邮件。
的beans.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="host" value="smtp.gmail.com" />
<property name="port" value="587" />
<property name="username" value="adminxxxx" />
<property name="password" value="password" />
<property name="javaMailProperties">
<props>
<prop key="mail.smtp.auth">true</prop>
<prop key="mail.smtp.starttls.enable">true</prop>
</props>
</property>
</bean>
<bean id="emailNotifier" class="com.examples.EmailNotifier">
<property name="mailSender" ref="mailSender" />
</bean>
</beans>
这仅用于测试:
public class MailApp {
public static void main( String[] args )
{
ApplicationContext context =
new ClassPathXmlApplicationContext("beans.xml");
EmailNotifier emailNotifier = (EmailNotifier) context.getBean("emailNotifier");
try {
emailNotifier.sendMail(new InternetAddress("adminxxxx@gmail.com"),
new InternetAddress("recipientxxxx@gmail.com"),
"Email Alert!",
"Hello User, This is a test email \n No response required.");
} catch (AddressException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}