Отправка сообщения приводит к исключению - PullRequest
0 голосов
/ 19 января 2010

Я пытаюсь отправить сообщение, используя Javamail API, с tomcat в качестве веб-сервера, но следующий код приводит к большому исключению, когда я пытаюсь отправить сообщение без файла и вложения.Хотя он работает с сообщениями как вложения.

public static String send(String to,String body,Stringsubject,String file,String from)throws Exception{

                  if(file!=null||file!=" "){    

        File file1=new File(file);
        MimeBodyPart mb=new MimeBodyPart();
        FileDataSource f=new FileDataSource(file1.getCanonicalPath());
        mb.setDataHandler(new DataHandler(f));
        mb.setFileName(f.getName());
        mm.addBodyPart(mb);
        }

        mb1.setText(body);
        mm.addBodyPart(mb1);
                  message.setFrom(new InternetAddress(from));
        Address[] add={ new InternetAddress(to) };

              message.setRecipients(Message.RecipientType.TO,add);
              message.setSubject(subject);
              message.setContent(mm);
            //message.setText(body);
              Transport.send(message);
           return "Message sent";
}

Исключение:

javax.mail.MessagingException: IOException while sending message;
  nested exception is:
    java.io.FileNotFoundException: C:\Program Files\Apache Software Foundation\Tomcat 6.0 (Access is denied)
    at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:779)
    at javax.mail.Transport.send0(Transport.java:191)
    at javax.mail.Transport.send(Transport.java:120)
    at foo.SendMessage.send(SendMessage.java:57)
    at foo.Mail.doPost(Mail.java:39)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
    at java.lang.Thread.run(Thread.java:619)
Caused by: java.io.FileNotFoundException: C:\Program Files\Apache Software Foundation\Tomcat 6.0 (Access is denied)
    at java.io.FileInputStream.open(Native Method)
    at java.io.FileInputStream.<init>(FileInputStream.java:106)
    at javax.activation.FileDataSource.getInputStream(FileDataSource.java:82)
    at javax.activation.DataHandler.writeTo(DataHandler.java:290)
    at javax.mail.internet.MimeBodyPart.writeTo(MimeBodyPart.java:1381)
    at javax.mail.internet.MimeBodyPart.writeTo(MimeBodyPart.java:852)
    at javax.mail.internet.MimeMultipart.writeTo(MimeMultipart.java:452)
    at com.sun.mail.handlers.multipart_mixed.writeTo(multipart_mixed.java:98)
    at javax.activation.ObjectDataContentHandler.writeTo(DataHandler.java:869)
    at javax.activation.DataHandler.writeTo(DataHandler.java:302)
    at javax.mail.internet.MimeBodyPart.writeTo(MimeBodyPart.java:1381)
    at javax.mail.internet.MimeMessage.writeTo(MimeMessage.java:1742)
    at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:737)
    ... 18 more

У меня вопрос, я использовал условие в приведенном выше коде, прежде чем сделатьлюбой файл как вложение, тогда почему я получаю это исключение?

Ответы [ 3 ]

4 голосов
/ 19 января 2010

if(file!=null||file!=" ") неверно.Я подозреваю, что вы хотите if (file != null && !file.trim().isEmpty()).

В частности, сказать if (file != null || file != " ") - это то же самое, что сказать if (true), потому что вы использовали оператор ИЛИ, и поскольку file не может иметь значение "" и ноль одновременно, одно из этих условий выполняетсяоценить истину, сделав все выражение правдой.

Кстати, file != " " - плохая форма.При тестировании на равенство с попытками всегда следует использовать метод equals(), а не операторы == и !=.

0 голосов
/ 19 января 2010

Хитрость является вложенным исключением:

Причина: java.io.FileNotFoundException: C: \ Program Files \ Apache Software Foundation \ Tomcat 6.0 (доступ запрещен)

Это означает, что вам не разрешено открывать ресурс в виде файла.

Дополнительно, ваш тест:

if(file!=null||file!=" "){    
    File file1=new File(file);
    …
}

не проверяет, существует ли файл на самом деле или нет, он только проверяет, не является ли имя пустым или не является строковым литералом. Гораздо лучший способ сделать это будет:

if(file!=null && !file.isEmpty()){    
    File file1=new File(file);
    …
}

В общем, использование == для сравнения строк в Java является неправильным действием .

Для получения более значимой информации, вы можете заключить посылку в блок try / catch, чтобы распечатать дополнительную информацию в этот момент:

try{
    Transport.send(message);
} catch (IOException e) {
   throw new Exception("Debug: file:'" + file + "' from:'" + from + "'", e); 
}
0 голосов
/ 19 января 2010

Вложенное исключение:

java.io.FileNotFoundException: C:\Program Files\Apache Software Foundation\Tomcat 6.0 (Access is denied)

То есть вы не можете получить доступ к C:\Program Files\Apache Software Foundation\Tomcat 6.0. Я предлагаю проверить ваши права доступа к этому файлу. Вы также должны сообщить нам, каковы аргументы send() при получении этого исключения.

...