Java-программа - IP-адрес для проверки связи и отправки электронной почты - PullRequest
0 голосов
/ 17 января 2019

относительный новичок в программировании. Я пытаюсь написать программу, которая пингует IP-адрес. Когда хост находится в сети, он ничего не делает, а в автономном режиме отправляет электронное письмо получателю. Тем не менее, отправка электронной почты каждый раз - онлайн и офлайн! Я знаю, что я довольно близко, любая помощь будет отличной! Фрагмент кода ...

    final String username = "myemail@gmail.com";
    final String password = "Password";    

    Properties props = new Properties();
    props.put("mail.smtp.auth", "true");
    props.put("mail.smtp.starttls.enable", "true");
    props.put("mail.smtp.host", "smtp.gmail.com");
    props.put("mail.smtp.port", "587");
    Session session = Session.getInstance(props,
            new javax.mail.Authenticator() {
                protected PasswordAuthentication getPasswordAuthentication() {
                    return new PasswordAuthentication(username, password);
                }
            });    


    InetAddress i = InetAddress.getByName(ipAddress);
    System.out.println("Sending Ping Request to " + ipAddress);
    if (i.isReachable(5000)) //5 second limit
        System.out.println("Host is online \n");
    else
        System.out.println("HOST IS OFFLINE\n");

    try {


        Message message = new MimeMessage(session);
        message.setFrom(new InternetAddress("myemail@gmail.com"));
        message.setRecipients(Message.RecipientType.TO,
            InternetAddress.parse("receiveremail@hotmail.com"));
        message.setSubject("Project Test Mail");
        message.setText("Test Mail,"
            + "\n\n Sent From sendMail.java application");

        Transport.send(message);

        System.out.println("Mail Sent to receiveremail@hotmail.com " 
         +     ipAddress);

    } catch (MessagingException e) {
        throw new RuntimeException(e);
    }
} 

Ответы [ 2 ]

0 голосов
/ 17 января 2019

Ваш блок try не связан с оператором if. Хорошей практикой в ​​java всегда является использование фигурных скобок для блоков if / else, если фигурные скобки не используются, будет выполнена только первая строка кода относительно ответа if / else.

Например, в следующем коде

if(someTest())
  doSomething();
  doSomethingElse();

doSomethingElse() ВСЕГДА будет выполняться.

и в этом коде:

if(someTest()){
  doSomething();
  doSomethingElse();
 }

doSometingElse () будет выполняться, только если someTest () имеет значение true

0 голосов
/ 17 января 2019

Ваша часть сообщения не входит в сферу действия вашего оператора else. если вы не используете фигурные скобки для if / else / for / и т. д., будет рассмотрена только следующая строка. просто положи его в {}

        final String username = "myemail@gmail.com";
        final String password = "Password";    

        Properties props = new Properties();
        props.put("mail.smtp.auth", "true");
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.host", "smtp.gmail.com");
        props.put("mail.smtp.port", "587");
        Session session = Session.getInstance(props,
                new javax.mail.Authenticator() {
                    protected PasswordAuthentication getPasswordAuthentication() {
                        return new PasswordAuthentication(username, password);
                    }
                });    


        InetAddress i = InetAddress.getByName(ipAddress);
        System.out.println("Sending Ping Request to " + ipAddress);
        if (i.isReachable(5000)) //5 second limit
            System.out.println("Host is online \n");
        else {
            System.out.println("HOST IS OFFLINE\n");

        try {


            Message message = new MimeMessage(session);
            message.setFrom(new InternetAddress("myemail@gmail.com"));
            message.setRecipients(Message.RecipientType.TO,
                InternetAddress.parse("receiveremail@hotmail.com"));
            message.setSubject("Project Test Mail");
            message.setText("Test Mail,"
                + "\n\n Sent From sendMail.java application");

            Transport.send(message);

            System.out.println("Mail Sent to receiveremail@hotmail.com " 
             +     ipAddress);

        } catch (MessagingException e) {
            throw new RuntimeException(e);
        }
    } 
}
...