Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

rtavix

Dúvida relacionada a utilização do Serviço windows

Recommended Posts

Estou com a seguinte dúvida, tenho um serviço windows, e nele após ler o arquivo eu movo esse arquivo para uma outra pasta, porém caso algum código de barras que existe dentro desse arquivo não estiver cadastrado na minha base de dados, eu não irei inserir numa outra determinada tabela, estou explicando somente o processo.

 

Agora minha dúvida:

No log gerado, eu informo esse código de barras que não foi inserido por esse motivo, porém gostaria de saber como eu poderia fazer para informar a pessoa responsável, que o código de barras tal não foi inserido na determinada tabela do banco por não esta cadastrado, existe uma forma de enviar um email informando esse código de barras e solicitando para que a mesma cadastre o mesmo? como eu poderia fazer a códificação para o e- mail?

 

//Método InsertLog
private static void InsertLog(string linha)
        {
            //Cria Pasta de Log, Caso não exista
            if (!Directory.Exists(PastaArquivoLog))
            {
                Directory.CreateDirectory(PastaArquivoLog);
            }

            //Cria Arquivo de Log, Caso não exista
            string FullPath = PastaArquivoLog+ "\\Log de Processamento de comprovantes.txt";
            if (!File.Exists(FullPath))
            {
                using (File.Create(FullPath)) ;
            }

            //Escreve no arquivo de LOG
            using (StreamWriter file = new StreamWriter(FullPath,true))
            {
                file.WriteLine(linha);
                file.Dispose();
            }
        }





//Aqui eu busco todos os proc_inter da tabela sdpj_proc_interessado 
//que possui o código de barras lido no arquivo, somente para vocês entenderem aonde quero chegar.
private static string GetCodProcInter(string CodBarra)
        {            
            using (DB db = new DB())
            {
                string SQL = string.Format(@"SELECT T0.cod_proc_inter FROM sdpj_proc_inter T0 WHERE T0.cod_barras_banestes = '{0}'",CodBarra);
                var dados = db.ExecutaComandoComRetorno(SQL);

                if(dados.Read())
                {
                    return dados["cod_proc_inter"].ToString();
                }                
            }

            return "";
        }



//Esse método, eu utilizo para mover os arquivos lidos.
private static void MoveFile(string FileName)
        {
            try
            {
                PastaArquivosImportados += "\\" + FileName;
                PastaArquivosPendentes += "\\" + FileName;
                File.Move(PastaArquivosPendentes, PastaArquivosImportados);
            }
            catch (Exception)
            {
                throw;
            }

        }



//Nesse método eu percorro todas as linhas, até eu encontrar as informações que
//eu necessido ler e gravar.

private static void ProcessaArquivo(string FullPathFile, string FileName)
        {
            try
            {

                bool Mover = true;

                string[] StringLinha = System.IO.File.ReadAllLines(FullPathFile);
                string CodBarra = "";

                for (int line = 0; line < StringLinha.Length; line++)
                {
                    string DtAgendamento = "";
                    string VlrDocumento = "";
                    string Protocolo = "";
                    string Registro = "";
                    string Emissao = "";

                    #region Recupera o Código de Barra

                    if (StringLinha[line].Contains("Cod. Barras:"))
                    {
                        CodBarra += StringLinha[line].Replace("Cod. Barras:", "");
                        line += 2;
                    }
                    if (CodBarra != "")
                    {
                        CodBarra += StringLinha[line];
                        CodBarra = CodBarra.Replace(" ", "");
                    }

                    #endregion

                    if (CodBarra == "")
                        continue;

                    line += 6;

                    #region Data de Agendamento

                    if (StringLinha[line].Contains("Dt.Agendamento:"))
                    {
                        DtAgendamento += StringLinha[line].Replace("Dt.Agendamento:", "").Replace(" ", " ");
                    }

                    #endregion

                    line += 2;

                    #region Valor do Documentos

                    if (StringLinha[line].Contains("Vlr.Documento:"))
                    {
                        VlrDocumento += StringLinha[line].Replace("Vlr.Documento:", "").Replace(" ", "");
                    }

                    #endregion

                    line += 2;

                    #region Protocolo

                    if (StringLinha[line].Contains("Protocolo:"))
                    {
                        Protocolo += StringLinha[line].Replace("Protocolo:", "").Replace(" ", "");
                    }

                    #endregion

                    line += 12;

                    #region Registro

                    if (StringLinha[line].Contains("Registro:"))
                    {
                        Registro += StringLinha[line].Replace("Registro:", "");
                    }

                    #endregion

                    line += 2;

                    #region Emissao

                    if (StringLinha[line].Contains("Emissao.:"))
                    {
                        Emissao += StringLinha[line].Replace("Emissao.:", "");
                    }

                    #endregion

                    //Busca Código de Barra 
                    string CodProcInter = GetCodProcInter(CodBarra);

                    if (!string.IsNullOrEmpty(CodProcInter))
                    {
                        if(!CodBarraJaInserido(CodBarra))
                        {
                            //Insere Código de Barra
                            bool inserido = InsereDadosBanco(CodProcInter,CodBarra,DtAgendamento,VlrDocumento,Protocolo,Registro,Emissao);
                        }
                        else
                        {
                            //Código de Barra já Inserido
                            InsertLog("\n Já Existe -> " + CodBarra);
                        }
                    }
                    else
                    {
                        //Código de Barra não esta disponível na tabela -> sdpj_proc_inter
			//caso ele não esteja disponivel, devo comunicar a pessoa responsável, enviando o numero do código de barras para essa pessoa, como fazer?
                        Mover = false;
                        InsertLog("\n Cód. Barra Não disponível -> " + CodBarra);
                    }

                    //Limpar Variaveis
                    CodBarra = "";
                }

                if (Mover)
                {
                    MoveFile(FileName);
                }

            }
            catch (Exception)
            {
                throw;
            }
        }

 

Nessa parte do código mora a minha dúvida.

 

if (!string.IsNullOrEmpty(CodProcInter))
                    {
                        if(!CodBarraJaInserido(CodBarra))
                        {
                            //Insere Código de Barra
                            bool inserido = InsereDadosBanco(CodProcInter,CodBarra,DtAgendamento,VlrDocumento,Protocolo,Registro,Emissao);
                        }
                        else
                        {
                            //Código de Barra já Inserido
                            InsertLog("\n Já Existe -> " + CodBarra);
                        }
                    }
                    else
                    {
                        //Código de Barra não esta disponível na tabela -> sdpj_proc_inter
			//caso ele não esteja disponivel, devo comunicar a pessoa responsável, enviando o numero do código de barras para essa pessoa, como fazer?
                        Mover = false;
                        InsertLog("\n Cód. Barra Não disponível -> " + CodBarra);
                    }

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 08/08/2018 at 08:56, quintelab disse:

Tem varios artigos na internet explicando como enviar e-mail, aqui e um exemplo: http://www.technical-recipes.com/2018/how-to-send-an-e-mail-via-google-smtp-using-c/

Oi quintelab, obrigado pela sugestão, comecei implementar algo no meu código relacionado ao envio do email para a pessoa responsavel por esses comprovantes, porém estou com problemas de passar o log dentro da mensagem nessa parte do meu código, poderia por gentileza me informa como eu poderia estar resolvendo esse problema:

 

 private static void ProcessaArquivo(string FullPathFile, string FileName)
        {
            try
            {

                bool Mover = true;

                string[] StringLinha = System.IO.File.ReadAllLines(FullPathFile);
                string CodBarra = "";

                for (int line = 0; line < StringLinha.Length; line++)
                {
                    string DtAgendamento = "";
                    string VlrDocumento = "";
                    string Protocolo = "";
                    string Registro = "";
                    string Emissao = "";

                    #region Recupera o Código de Barra

                    if (StringLinha[line].Contains("Cod. Barras:"))
                    {
                        CodBarra += StringLinha[line].Replace("Cod. Barras:", "");
                        line += 2;
                    }
                    if (CodBarra != "")
                    {
                        CodBarra += StringLinha[line];
                        CodBarra = CodBarra.Replace(" ", "");
                    }

                    #endregion

                    if (CodBarra == "")
                        continue;

                    line += 6;

                    #region Data de Agendamento

                    if (StringLinha[line].Contains("Dt.Agendamento:"))
                    {
                        DtAgendamento += StringLinha[line].Replace("Dt.Agendamento:", "").Replace(" ", " ");
                    }

                    #endregion

                    line += 2;

                    #region Valor do Documentos

                    if (StringLinha[line].Contains("Vlr.Documento:"))
                    {
                        VlrDocumento += StringLinha[line].Replace("Vlr.Documento:", "").Replace(" ", "");
                    }

                    #endregion

                    line += 2;

                    #region Protocolo

                    if (StringLinha[line].Contains("Protocolo:"))
                    {
                        Protocolo += StringLinha[line].Replace("Protocolo:", "").Replace(" ", "");
                    }

                    #endregion

                    line += 12;

                    #region Registro

                    if (StringLinha[line].Contains("Registro:"))
                    {
                        Registro += StringLinha[line].Replace("Registro:", "");
                    }

                    #endregion

                    line += 2;

                    #region Emissao

                    if (StringLinha[line].Contains("Emissao.:"))
                    {
                        Emissao += StringLinha[line].Replace("Emissao.:", "");
                    }

                    #endregion

                    //Busca Código de Barra 
                    string CodProcInter = GetCodProcInter(CodBarra);

                    if (!string.IsNullOrEmpty(CodProcInter))
                    {
                        if(!CodBarraJaInserido(CodBarra))
                        {
                            //Insere Código de Barra
                            bool inserido = InsereDadosBanco(CodProcInter,CodBarra,DtAgendamento,VlrDocumento,Protocolo,Registro,Emissao);
                        }
                        else
                        {
                            //Código de Barra já Inserido
                            InsertLog("\n Já Existe -> " + CodBarra);
                            
                        }
                    }
                    else
                    {
                        //Código de Barra não esta disponível na tabela -> sdpj_proc_inter
                        Mover = false;
                        InsertLog("\n O arquivo não foi importado, pois o Cód. Barra  -> " + CodBarra + " não estar disponivel na tabela processo interessado");
                        string from = "noreplylocal@teste.com.br"; // E-mail de remetente
                        string to = "teste@teste.com.br";   // E-mail do destinatário
                        MailMessage message = new MailMessage(from, to, InsertLog("\n O arquivo não foi importado, pois o Cód. Barra  -> " + CodBarra + " não estar disponivel na tabela processo interessado"));

                        using (SmtpClient smtp = new SmtpClient("s3a614", 465))
                        {

                            smtp.Send(message);
                        }

                        Console.WriteLine("Mensagem enviada com sucesso!");
                        Console.Read();
                    }

                    //Limpar Variaveis
                    CodBarra = "";
                }

                if (Mover)
                {
                    MoveFile(FileName);
                }



            }
            catch (Exception)
            {
                throw;
            }
        }

 

Meu problema esta nessa parte do código:

else
                    {
                        //Código de Barra não esta disponível na tabela -> sdpj_proc_inter
                        Mover = false;
                        InsertLog("\n O arquivo não foi importado, pois o Cód. Barra  -> " + CodBarra + " não estar disponivel na tabela processo interessado");
                        string from = "teste@teste.com.br"; // E-mail de remetente
                        string to = "teste@teste.com.br";   // E-mail do destinatário
                        MailMessage message = new MailMessage(from, to, InsertLog("\n O arquivo não foi importado, pois o Cód. Barra  -> " + CodBarra + " não estar disponivel na tabela processo interessado")); 

                        using (SmtpClient smtp = new SmtpClient("s3a614", 25))
                        {

                            smtp.Send(message);
                        }

                        Console.WriteLine("Mensagem enviada com sucesso!");
                        Console.Read();
                    }

 Que em:

MailMessage message = new MailMessage(from, to, InsertLog("\n O arquivo não foi importado, pois o Cód. Barra  -> " + CodBarra + " não estar disponivel na tabela processo interessado"));

é apresentado a seguinte mensagem de erro em New MailMessage :

 

There is no argument given that corresponds to the required formal parameter 'body'  of 'MailMessage.MailMessage(string, string, string, string)

 

Estou tentando enviar o log por email, porém esta dando esse erro.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Por que esta chamando InsertLog no momento de enviar o e-mail ?

Acho que deveria ser:
 

MailMessage message = new MailMessage(from, to, " O arquivo não foi importado, pois o Cód. Barra -> " + CodBarra + " não estar disponivel na tabela processo interessado");

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por mr22robot
      Ola caros amigos. 
      Estou com uma dúvida aqui que embora nao tenho achado ainda uma resposta, acredito que haja.
      Estou estudando a tão sonhada linguagem de programação asp.net core mvc. Linguagem essa que demorei 5 anos pra iniciar os estudos rsrs.
      Mas estou agarrado em uma situação. 
      Estou usando como base de dados nos meus estudos um banco Oracle. Que já tem algumas informações nele. Utilizei o SCAFFOLD para criar as classes e o contexto baseado no banco e tabelas existentes. 
      Porem agora na fase das consultas, estou perdido em como utilizar o IN que eu utilizo no oracle; no LINQ.
      Ex: 
      SELECT CODPROD,DESCRICAO FROM PRODUTO WHERE CODPROD IN(1,2,3,4,5,6) Como eu utilizo esse filtro com uma restrição de códigos de produtos? no caso o where codprod in(1,2,3,4,5,6) ?.
      Desde já obrigado pela ajuda.
    • Por luis0101010
      1.      Programe uma função que recebe um número inteiro e verifica se todos os dígitos deste número são iguais ou diferente e liste eles em ordens crescentes.
      Obs: Código fonte com no mínimo de 10 dígitos.
       
      Como exemplo, os números 456, −235, e 5 satisfazem esta condição, enquanto que o número 6 não.
       
      2.      Crie também a função main que recebe o valor do número digitado pelo usuário e exibe na tela uma mensagem informando se os dígitos deste número são iguais.
       
      Exemplo:
      --Exemplo 1:
      Informe um número:
      -555
      Numero informado possui todos os dígitos iguais
      --Exemplo 2:
      Informe um número:
      67
      Número informado não possui todos os dígitos iguais
    • Por Rafael Massula
      Boa noite pessoal, 
      Tenho o seguinte código em .Net que faz a comparação de uma senha que foi criptografada e salva no banco com a senha comum que o usuário conhece. O algoritmo que desenvolvi foi esse da image.png porem preciso converter essa verificação para JavaScript pela seguinte necessidade, será uma aplicação em electron e ela poderá funcionar offline então não terei como mandar a verificação para o servidor. Existe alguma possibilidade? Desde já agradeço. 

    • Por TheLord23
      ESTOU COMEÇANDO AGORA NA PROGRAMAÇÃO COM VISUALG E TERIA QUE COLOCAR ESTE CODIGO EM UM LAÇO DE REPETIÇÃO.
      POREM NÃO ESTOU CONSEGUINDO PODERIAM ME AJUDAR ?
       
      SÓ PENSANDO QUE O USUÁRIO IRA DIGITAR O TAMANHO DO VETOR, APOS ISSO CADA OPÇÃO QUE ELE ESCOLHER E ELA SER EXECUTADA DE FORMA CORRETA ELE VOLTARA PARA O MEUNU PRINCIPAL DAS OPÇÕES ATE QUE ELE SELECIONE A OPÇÃO "F"
       
      POREM TENTEI ESCREVELO USANDO ENQUANTO MAS ACABOU QUE EU NÃO CONSIGO PREVINIR OS ERROS DO USUÁRIO QUANDO ELE COLOCA AS INFORMAÇÕES
       
      TIPO:
      -ARMAZENAR UM NÚMERO NO VETOR E ESSE NÚMERO NÃO SER SOBRESCREVIDO ATE QUE O PROGRAMA SEJA ENCERRADO
      -SE ELE DIGITAR PRA BUSCAR OU INSERIR O NÚMERO ZERO O PROGRAMA INFORMAR QUE O VALOR É INVÁLIDO
       
      TENTEI USAR PROCEDIMENTOS E FUNÇÕES MAS OS ERROS CONTINUARAM.
       
       
       
      Algoritmo "DESAFIO"
      Var
         AUX,CONTADOR,BUSCAR:INTEIRO
         POSICAO,AUX_TEMP:INTEIRO
         OPCAO:CARACTERE
         RESULT_BUSCA: LOGICO
         SOMA_VET:REAL
         NUMERO:VETOR[1..500]DE INTEIRO
      Inicio
         ESCREVAL("*********************************")
         ESCREVAL("* CADASTRO DE VETORES - DESAFIO *")
         ESCREVAL("*********************************")
         ESCREVA("DIGITE O TAMANHO DO VETOR A SER CADASTRADO: ")
         LEIA(AUX)
         NUMERO[AUX] <- AUX
         ESCREVAL("A - Cadastrar um novo número;")
         ESCREVAL("B - Buscar um número")
         ESCREVAL("C - Excluir um número;")
         ESCREVAL("D - Listar os números cadastrados;")
         ESCREVAL("E - Exibir a soma dos números do vetor;")
         ESCREVAL("F - Sair do sistema.")
         LEIA(OPCAO)
         OPCAO <- MAIUSC(OPCAO)
         ESCOLHA OPCAO
         CASO "A"
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVA("DIGITE O VALOR QUE SERÁ ARMAZENADO NA",CONTADOR,"ª POSIÇÃO DO VETOR: ")
               LEIA(NUMERO[CONTADOR])
            FIMPARA
         CASO "B"
            ESCREVA("QUAL NÚMERO DESEJA ENCONTRAR: ")
            LEIA(BUSCAR)
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               SE NUMERO[CONTADOR] = BUSCAR ENTAO
                  RESULT_BUSCA <- VERDADEIRO
                  POSICAO <- CONTADOR
               FIMSE
            FIMPARA
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVAL(NUMERO[CONTADOR])
            FIMPARA
            ESCREVAL("")
            ESCREVAL("---------")
            SE RESULT_BUSCA = VERDADEIRO ENTAO
               ESCREVAL("O NÚMERO",BUSCAR,"FOI ENCONTRADO E ESTA NA POSIÇÃO",POSICAO)
            SENAO
               ESCREVAL("O NÚMERO NÃO FOI ENCONTRADO !")
            FIMSE
         CASO "C"
            escreval("QUAL NÚMERO DESEJA EXCLUIR DO VETOR: ")
            leia(BUSCAR)
            SE NUMERO[CONTADOR] = BUSCAR ENTAO
               NUMERO[CONTADOR] <- 0
               ESCREVAL("O NÚMERO",BUSCAR,"NA POSIÇÃO",POSICAO,"DO VETOR FOI EXCLUIDO !")
            FIMSE
            PARA CONTADOR DE 1 ATE NUMERO[AUX]
               PARA AUX DE CONTADOR + 1 ATE AUX FACA
                  SE NUMERO[AUX] > NUMERO[CONTADOR]
                     AUX_TEMP <- NUMERO[AUX]
                     NUMERO[AUX] <- NUMERO[CONTADOR]
                     NUMERO[CONTADOR] <- AUX_TEMP
                  FIMPARA
               FIMPARA
               ESCREVA("VALROES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "D"
               ESCREVA("VALORES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "E"
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  SOMA_VET <- SOMA_VET + NUMERO[CONTADOR]]
               FIMPARA
               ESCREVAL("")
               ESCREVA("A SOMA DO VETOR É:",SOMA_VET)
               
            CASO "F"
               ESCREVAL("ENCERRANDO SISTEMA...")
            OUTROCASO
               ESCREVAL("OPÇÃO INVÁLIDA !")
            FIMESCOLHA
      Fimalgoritmo
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.