Jump to content
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);
                    }

 

 

 

Share this post


Link to post
Share on other 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.

Share this post


Link to post
Share on other 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");

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By guiarodrigues1
      Alguém poderia me ajudar em como colocar calculo de dilatação linear / superficial / volumétrica e de sólidos no DevC?
      Não estou conseguindo sair do lugar.
       
      Caso alguém queira mais informações segue em anexo link para baixar.
      Grato.
      Baixar PDF.
    • By Neto Dinizz
      Olá Neto Nível: InicianteMINHA CONTA Perfil Minha Assinatura Meus Cursos Favoritos Logout  Indique um amigo Mostrar menu WebAPI CRUD .NET
      11/06/2019
      1
      Entity Framework.NETASP.NET Web APIC#CRUD
      Boa noite,

      Tenho uma aplicação webapi c# utilizando entity framework CRUD, utilizando o models para montar meu json, como no models só trago os campos que vem da tabela, Tenho dúvida em como receber um parâmetro que não existe na minha tabela via parâmetro ex:

      Localhost/api/clientes?id=2&idcat=4&nome=teste

      Onde (nome) seria um parâmetro que não tenho em minha tabela, porém se existir os 2 primeiros parâmetros irei fazer um POST na tabela.

      Muito obrigado
    • By Neto Dinizz
      Bom dia,

      Poderiam me dar uma ajuda por favor,

      Estou com uma dúvida, tenho um método GET que espera o id do cliente pela url http://localhost/api/cliente/(codigo_cliente)
      estou com um problema para acessar um cliente pelo id, através de um select, gostaria de receber o id e fazer um select no banco trazendo os dados do cliente, poderiam me ajudar a incrementar o códido abaixo por favor, segue meu GET:

      // GET: api/Cliente/5
      [ResponseType(typeof(Cliente))]
      public IHttpActionResult GetCliente(int id)
      {
      Cliente cliente = db.Clientes.Find(id);
      if (cliente == null)
      {
      return NotFound();
      }

      return Ok(cliente);
    • By guiarodrigues1
      Faça uma procedure que recebe, por parâmetro, um valor N e calcula e escreve a tabuada de 1 até N. Mostre a tabuada na forma:

      1 x N = N 2 x N = 2N ... N x N = N2
       
      Alguém me salva ai? Grato.
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.