eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaBiblioteka MQTT i dziwny kod w CRe: Biblioteka MQTT i dziwny kod w C
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!3.eu.feeder.erj
    e.net!feeder.erje.net!weretis.net!feeder8.news.weretis.net!newsreader4.netcolog
    ne.de!news.netcologne.de!peer02.ams1!peer.ams1.xlned.com!news.xlned.com!peer02.
    ams4!peer.am4.highwinds-media.com!news.highwinds-media.com!newsfeed.neostrada.p
    l!unt-exc-02.news.neostrada.pl!unt-spo-a-01.news.neostrada.pl!news.neostrada.pl
    .POSTED!not-for-mail
    Date: Tue, 9 Aug 2022 10:53:41 +0200
    MIME-Version: 1.0
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101
    Thunderbird/91.12.0
    Subject: Re: Biblioteka MQTT i dziwny kod w C
    Content-Language: pl
    Newsgroups: pl.misc.elektronika
    References: <62f14473$0$544$65785112@news.neostrada.pl>
    <62f1ecee$0$464$65785112@news.neostrada.pl>
    <62f20076$0$566$65785112@news.neostrada.pl>
    <62f217dc$0$498$65785112@news.neostrada.pl>
    From: Atlantis <m...@w...pl>
    In-Reply-To: <62f217dc$0$498$65785112@news.neostrada.pl>
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    Lines: 28
    Message-ID: <62f22095$0$561$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 83.27.21.205
    X-Trace: 1660035221 unt-rea-b-01.news.neostrada.pl 561 83.27.21.205:60058
    X-Complaints-To: a...@n...neostrada.pl
    X-Received-Bytes: 2679
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:773706
    [ ukryj nagłówki ]

    On 09.08.2022 10:16, JDX wrote:

    > Jak dla mnie to ta funkcja to jakieś totalne, niedorobione gówno.
    > Prowizorka znaczy się. Tutaj bym szukał błędu. Kody stanów w switch-u
    > zakodowane na twardo, a nie za pomocą enumów/makr - jak mniemam chodzi o
    > kody wymienione w enum-ie na początku. Stany zmieniane za pomocą
    > m_state++ czy m_state=3 zamiast m_state=NAZWA_KOLEJNEGO_STANU - aż się
    > prosi o kłopoty. Nie chce mi się analizować tego kodu, ale wydaje mi
    > się, że nie wszystkie stany są obsługiwane.

    Też się skłaniam ku tej hipotezie. Będę musiał przyjrzeć się temu
    bliżej, bo na razie wygląda na to, że ta funkcja nie jest kompatybilna z
    wiadomością CONNACK i po natrafieniu na nią nie czyta wszystkiego, a
    jedynie pobiera dwa pierwsze bajty.
    Autor nie zauważył tego, bo przez przypadek tak się złożyło, że w
    switch/case sprawdzał wartość komórki pamięci, która zawsze miała
    wartość 0x00, więc zawsze wyglądało to tak, jakby połączenie zostało
    autoryzowane. Najwyraźniej nie przetestował nigdy działania biblioteki z
    błędnym loginem/hasłem.

    Generalnie i tak prościej będzie usunąć z tego błędy o trochę wyczyścić
    kod, niż pisać swoją własną bibliotekę albo portować inną pod stos
    TCP/IP MLA od Microchipa...

    To prawdopodobnie nie będzie ostatnia rzecz, bo w Wiresharku widzę
    jeszcze jakieś retransmisje przy zamykaniu połączenia TCP po zakończonej
    transmisji, ale najpierw chciałem się uporać z problemem z autoryzacją,

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: