Как отправить письмо из контактной формы в R Shiny - PullRequest
0 голосов
/ 24 января 2020

Я реализовал контактную форму в приложении Shiny и использую пакет «blastula» и его функцию «smtp_send» для отправки сообщения на адрес электронной почты, указанный отправителем. Код:

library(shiny)
library(blastula)
library(shinyAce)

ui = fluidPage(
  fluidPage(
    wellPanel(
      textInput("from"   , "From:"   , value="...@..."),
      textInput("to"     , "To:"     , value="...@..."),
      textInput("subject", "Subject:", value="This is the subject"),

      p("Message", style="font-weight: bold;"),
      aceEditor("msg", value="This is the message"),
      br(),
      actionButton("send", "Send email!")
    )
  )   
)

server <- function(input, output)
{
  observe(
  {
    if(is.null(input$send) || input$send==0) return(NULL)

    Email = compose_email(body = input$msg, header = NULL, footer = NULL, title = NULL)
    Credentials = creds_anonymous(host = "smtp...", port = 25, use_ssl = TRUE)

    smtp_send(email = Email, to = input$to, from = input$from, subject = input$subject, credentials = Credentials)
  })
}

shinyApp(ui = ui, server = server)

Локальный запуск этого сценария и использование порта = 25 выдает сообщение об ошибке: «Предупреждение: Ошибка в curl :: curl_fetch_memory: сбой RCPT: 550».

Использование port = 465 или port = 587 выдает сообщение об ошибке: «Предупреждение: ошибка в curl :: curl_fetch_memory: истекло время ожидания: [smtp ...: 465] Время ожидания соединения истекло через 10000 миллисекунд».

При запуске сценария на сервере с использованием порта = 25 выдается сообщение об ошибке: «Ошибка в curl :: curl_fetch_memory: Ошибка Recv: сброс соединения по пиру».

Я проверил адрес сервера smtp , это должно быть правильно. Это сервер, который не требует учетной записи.

Кто-нибудь имеет представление, почему код не работает?

1 Ответ

1 голос
/ 24 января 2020

Я извлек способ управления проблемами электронной почты с моим приложением - способ gmail работает для Outlook, я не уверен, так как я не проверял его некоторое время.

Замените детали своим собственным, сначала прокомментируйте способ gmail.

Код ниже, и игнорируйте неровность между ними. Они также некоторые проверки, когда кто-то может отправить и по электронной почте и если адрес правильный и так далее ...

Это может помочь ..

РЕДАКТИРОВАТЬ: проблема должна быть определена и ваш адрес электронной почты адрес должен быть gmail.com.

library(shiny)
# library (RDCOMClient)
Sys.setenv(JAVA_HOME='C:\\Program Files\\Java\\jre1.8.0_241/') 
library(mailR)
library(shinythemes)
library(shinyjs)

ui = fluidPage(
  useShinyjs(),
  fluidPage(
    br(),
    fluidRow(
      column(12,align="center",
             h1(icon("envelope", lib = "font-awesome"))),
      br(),
      column(12,align="center",
             textInput("telo", "Problem statement","", width = "400px",
                       placeholder= "obvezno izpolnite!"),
             br(),
             textInput("kontakt","Your working email - necessary!","",
                       placeholder = 'ime.priimek@gmail.com'),
             helpText("Test email= Thorin@gmail.si"),
             actionButton("send", "Send",icon("fas fa-arrow-up", lib = "font-awesome")),
             br())),
    br(),
    fluidRow(
      column(12,
             br()))
  )



)   


server <- function(input, output,session)
{
  disable("send")
  ###################################################################################### pošlji email, telo strani
  testek11<-function(failed = FALSE) {
    modalDialog(
      title="",
      fluidRow(column(12,align="center",
                      "SEND.")),
      br(),
      easyClose = FALSE,
      footer=fluidRow(column=12,align="center",
                      modalButton("OK",icon=icon("fas fa-check-circle"))
      )
    )
  } 

  observeEvent(input$send,{
    #showModal(testek21())
    shinyjs::disable("send")
    shinyjs::disable("nazaj2")
    shinyjs::disable("telo")
    shinyjs::disable("kontakt")


    ## gmail way
    Sys.sleep(2)

    # send.mail(from = paste(input$username,"@domain.com",sep=""),
    #           to = c("test99@gmail.com"),
    #           subject = paste("Aplikacija NNP: Problem:",input$kontakt,sep=" OD "),
    #           body =  paste(input$telo,input$username,sep=" // OD // "),
    #           smtp = list(host.name = "smtp.gmail.com", port = 465,
    #                       user.name = "test99@gmail.com",
    #                       passwd = "pass", ssl = TRUE),
    #           authenticate = TRUE,
    # send = TRUE)


    ## outlook way -- possibly outdated

    # OutApp <- COMCreate("Outlook.Application")
    # outMail = OutApp$CreateItem(0)
    # outMail[["To"]] = "ur email adrres to where you want to send -- you can make it reactive"
    # outMail[["subject"]] = "subject"
    # outMail[["body"]] <- "body"
    # outMail$Send()
    # 
    shinyjs::enable("send")
    shinyjs::enable("nazaj2")
    shinyjs::enable("telo")
    shinyjs::enable("kontakt")
    showModal(testek11())
    updateTextInput(session,"telo",value="",placeholder = "Obvezno izpolnite!")
    updateTextInput(session,"kontakt",value="",placeholder = 'ime.priimek@gmail.si')
  })

  ##### enabling maile pa to kdaj lahko klikne send

  mailhelp <- reactiveValues(hmm=FALSE)
  mailhelp2 <- reactiveValues(hmm2=FALSE)



  observeEvent(input$telo,{
    if(input$telo != ""){
      isolate(mailhelp$hmm <- TRUE)
    }
    else{
      isolate(mailhelp$hmm <- FALSE)
    }
  })

  observeEvent(input$kontakt,{
    if(grepl("@gmail.com",input$kontakt) |grepl("@GMAIL.CON",input$kontakt) ){
      isolate(mailhelp2$hmm2 <- TRUE)
    }
    else{
      isolate(mailhelp2$hmm2 <- FALSE)
    }
  })

  observe({
    if(mailhelp2$hmm2 & mailhelp$hmm){
      shinyjs::enable("send")
    }
    else{
      shinyjs::disable("send")
    }
  })
}

shinyApp(ui = ui, server = server)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...