Pular para o conteúdo principal

Postagem em destaque

BlackTDN :: LeetCode :: Zigzag Conversion: Implementando Soluções em xBase (Harbour) e TL++

_Créditos das imagens: ChatGPT_ ### LeetCode :: Zigzag Conversion: Implementando Soluções em xBase (Harbour) e TL++ A ["Zigzag Conversion"](https://leetcode.com/problems/zigzag-conversion/description/) é um problema popular do LeetCode que desafia desenvolvedores a transformar uma string em um padrão zigzag com base no número de linhas especificado, para então reconstruir a string seguindo a leitura linha a linha do padrão. Aqui, apresento soluções desenvolvidas em Harbour (XBase) e TL++ com melhorias e detalhes adicionais. --- ### **O Problema** Dado uma string e um número de linhas, distribua os caracteres em um padrão zigzag. Leia as linhas do padrão sequencialmente para obter o resultado: Exemplo: **Input:** String: "PAYPALISHIRING" Linhas: 3 **Padrão Zigzag:** ``` P A H N A P L S I I G Y I R ``` **Output:** "PAHNAPLSIIGYIR" --- ### **Implementação em Harbour** As soluções estão organizadas em dois arquivos principai...

Exibindo as Senhas no Protheus 10


Fala Aeee Galera...
Estava eu no meu dia-a-dia de trabalho normal,
quando me solicitaram um desenvolvimento o qual eu nunca tinha precisado
fazer...
Me solicitaram para fazer um Job para gravar em uma tabela (Z alguma coisa)
todos os dados dos usuários.
Bom até ai tranquilo teria varias formas de fazer isso, AllUsers(), Psw Functions (PswOrder, PswSeek, PswRet) SPF_GETFIELDS....
Fiz o Job como solicitaram porem me pediram para gravar nessa tabela a senha do usuário também... (Ai a P#$% ficou seria)
Depois de algum tempo procurando uma forma de fazer isso eis que consigui, e resolvi compartilhar com vocês.
Segue abaixo.:


Utilizei a Função PwsgetSession que retorna o Id da sessão que é composto de:           
                - data e hora (servidor)
                - nome do usuário
                - Senha               
                - database do sistema
                - se o atributo oApp:cNumEmp estiver preenchido oApp:cNumEmp+Space(14) do contrario space(14)
                - se a função SenhaPNumber() retornar algum valor esse valor do contrario space(8)
                - com base de todas essas informações ele faz uma a utilização de uma função chamada PoliEncript que faz uma reposição de caracteres com base na string informada e uma outra string de chave utilizando o asc de cada um
                - com base nessa string "policriptografada" ele criptografa mais uma vez em hexadecimal concatenando isso Chr(30)+Chr(1)+Chr(2) na string antes de criptografar e retorna

                * Teoricamente essa função deveria receber um cId de parametro e quando não fosse informado-o ele pegaria oApp:cUserId, Porém na minha base mesmo passando o ID ele sempre pegava o oApp:cUserId

Com essa string de sessão passo para a função PswInfoSession que retorna um array com as informações da sessão (as mesmas que ele criptografou) mas o que me interessa é somente a posição 2 do array
com essa informação chamo via StaticCall a função __Descript(SIGAPSW) passando essa informação como parametro

E esse é o resultado.:
















Isso funcionou bem na versão 10 já na versão 11 não funciona pois o retorno da função PswInfoSession está diferente tanto a posição quanto o conteúdo estarei fazendo novos testes e assim que conseguir para a versão 11 postarei novamente...

Bom galera é isso aí,  espero que seja útil....
Abs,
Nando...

Comentários

  1. ...agora vc pisou no calo da Tontvs.
    Nova Lib já em produção e sua rotina nao irá mais funcionar.

    O naldo sabe, eu sei, muitos sabem, algumas coisas devem ser mantidas no sigilo. Mesmo que seu ego grite e se contorça para externar... algumas coisas nao devem sair...

    No mais, ficou mto bom.
    Boa descoberta!

    ResponderExcluir

Postar um comentário

Postagens mais visitadas