Variable completely messes up echoed string2019 Community Moderator ElectionAppend variable string to itselfTake output field data string into variableBash perform variable expansion of stringCombining a variable value and string to form another variableprintf escape %q string vs variablecompare variable with string bashPrinting variable value prints string Shell scriptingDo not expand string inside variablePrepare arguments containing quoted string in variableSSH terminal messes multiline commands

Probably overheated black color SMD pads

Describing a chess game in a novel

Do ranged attacks with improvised weapons get the bonus from the archery fighting style?

While on vacation my taxi took a longer route, possibly to scam me out of money. How can I deal with this?

Constant Current LED Circuit

Could this Scherzo by Beethoven be considered to be a fugue?

Why is a polar cone a closed set?

Deletion of copy-ctor & copy-assignment - public, private or protected?

How does one measure the Fourier components of a signal?

PTIJ What is the inyan of the Konami code in Uncle Moishy's song?

Using Leaflet inside Bootstrap container?

How to get the n-th line after a grepped one?

The average age of first marriage in Russia

Does multi-classing into Fighter give you heavy armor proficiency?

Is there a term for accumulated dirt on the outside of your hands and feet?

How are passwords stolen from companies if they only store hashes?

usage and meaning of Up

How can I wire 7 outdoor posts correctly?

Recruiter wants very extensive technical details about all of my previous work

How could an airship be repaired midflight?

Why is there so much iron?

Is it correct to say "which country do you like the most?"

What favor did Moody owe Dumbledore?

What is the plural TO OF sth



Variable completely messes up echoed string



2019 Community Moderator ElectionAppend variable string to itselfTake output field data string into variableBash perform variable expansion of stringCombining a variable value and string to form another variableprintf escape %q string vs variablecompare variable with string bashPrinting variable value prints string Shell scriptingDo not expand string inside variablePrepare arguments containing quoted string in variableSSH terminal messes multiline commands










1















So I really have no idea how to better describe this than the title.



So I discovered this website called pwnedpasswords, where you can apparently check to see if your password's sha1 hash has been leaked somewhere. So I made a script to automate the process, here's my script:



#!/bin/bash

read -s -p "Input your password: " your_pw
echo
your_hash=$(printf "$your_pw"|sha1sum|tr '[:lower:]' '[:upper:]'|head -c40)
hash_head=$(printf "$your_hash"|head -c5)
hash_tail=$(printf "$your_hash"|tail -c35)

pwned_count=$(curl https://api.pwnedpasswords.com/range/$hash_head 2> /dev/null|grep "$hash_tail"|awk -F ':' 'print $2')
echo "Your password has been pwned $your_pw times"
echo "Your password has been pwned $pwned_count times"


And I used as a test password 1, and this is the output:



[me@my_compuuter aaa8]$ ./was_your_password_pwned.sh
Input your password:
Your password has been pwned 1 times
timesassword has been pwned 197972


Notice how when I echo "Your password has been pwned $your_pw times"
it gives me the correct format ($your_pw is just the password itself), but when I echo "Your password has been pwned $pwned_count times" it gives me this weird format where it takes the times from the end and somehow overlaps it in the beginning... I have no clue what's going on...



Can somebody figure it out?










share|improve this question


























    1















    So I really have no idea how to better describe this than the title.



    So I discovered this website called pwnedpasswords, where you can apparently check to see if your password's sha1 hash has been leaked somewhere. So I made a script to automate the process, here's my script:



    #!/bin/bash

    read -s -p "Input your password: " your_pw
    echo
    your_hash=$(printf "$your_pw"|sha1sum|tr '[:lower:]' '[:upper:]'|head -c40)
    hash_head=$(printf "$your_hash"|head -c5)
    hash_tail=$(printf "$your_hash"|tail -c35)

    pwned_count=$(curl https://api.pwnedpasswords.com/range/$hash_head 2> /dev/null|grep "$hash_tail"|awk -F ':' 'print $2')
    echo "Your password has been pwned $your_pw times"
    echo "Your password has been pwned $pwned_count times"


    And I used as a test password 1, and this is the output:



    [me@my_compuuter aaa8]$ ./was_your_password_pwned.sh
    Input your password:
    Your password has been pwned 1 times
    timesassword has been pwned 197972


    Notice how when I echo "Your password has been pwned $your_pw times"
    it gives me the correct format ($your_pw is just the password itself), but when I echo "Your password has been pwned $pwned_count times" it gives me this weird format where it takes the times from the end and somehow overlaps it in the beginning... I have no clue what's going on...



    Can somebody figure it out?










    share|improve this question
























      1












      1








      1








      So I really have no idea how to better describe this than the title.



      So I discovered this website called pwnedpasswords, where you can apparently check to see if your password's sha1 hash has been leaked somewhere. So I made a script to automate the process, here's my script:



      #!/bin/bash

      read -s -p "Input your password: " your_pw
      echo
      your_hash=$(printf "$your_pw"|sha1sum|tr '[:lower:]' '[:upper:]'|head -c40)
      hash_head=$(printf "$your_hash"|head -c5)
      hash_tail=$(printf "$your_hash"|tail -c35)

      pwned_count=$(curl https://api.pwnedpasswords.com/range/$hash_head 2> /dev/null|grep "$hash_tail"|awk -F ':' 'print $2')
      echo "Your password has been pwned $your_pw times"
      echo "Your password has been pwned $pwned_count times"


      And I used as a test password 1, and this is the output:



      [me@my_compuuter aaa8]$ ./was_your_password_pwned.sh
      Input your password:
      Your password has been pwned 1 times
      timesassword has been pwned 197972


      Notice how when I echo "Your password has been pwned $your_pw times"
      it gives me the correct format ($your_pw is just the password itself), but when I echo "Your password has been pwned $pwned_count times" it gives me this weird format where it takes the times from the end and somehow overlaps it in the beginning... I have no clue what's going on...



      Can somebody figure it out?










      share|improve this question














      So I really have no idea how to better describe this than the title.



      So I discovered this website called pwnedpasswords, where you can apparently check to see if your password's sha1 hash has been leaked somewhere. So I made a script to automate the process, here's my script:



      #!/bin/bash

      read -s -p "Input your password: " your_pw
      echo
      your_hash=$(printf "$your_pw"|sha1sum|tr '[:lower:]' '[:upper:]'|head -c40)
      hash_head=$(printf "$your_hash"|head -c5)
      hash_tail=$(printf "$your_hash"|tail -c35)

      pwned_count=$(curl https://api.pwnedpasswords.com/range/$hash_head 2> /dev/null|grep "$hash_tail"|awk -F ':' 'print $2')
      echo "Your password has been pwned $your_pw times"
      echo "Your password has been pwned $pwned_count times"


      And I used as a test password 1, and this is the output:



      [me@my_compuuter aaa8]$ ./was_your_password_pwned.sh
      Input your password:
      Your password has been pwned 1 times
      timesassword has been pwned 197972


      Notice how when I echo "Your password has been pwned $your_pw times"
      it gives me the correct format ($your_pw is just the password itself), but when I echo "Your password has been pwned $pwned_count times" it gives me this weird format where it takes the times from the end and somehow overlaps it in the beginning... I have no clue what's going on...



      Can somebody figure it out?







      bash






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked 55 mins ago









      user323587user323587

      222




      222




















          1 Answer
          1






          active

          oldest

          votes


















          3














          The list returned by that site has lines terminated by CR/LF. A CR (r) will move the caret/cursor to the beginning of the line:



          printf 'good r times'
          times





          share|improve this answer























          • Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

            – user323587
            40 mins ago











          • @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

            – ilkkachu
            31 mins ago










          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "106"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f506865%2fvariable-completely-messes-up-echoed-string%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          3














          The list returned by that site has lines terminated by CR/LF. A CR (r) will move the caret/cursor to the beginning of the line:



          printf 'good r times'
          times





          share|improve this answer























          • Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

            – user323587
            40 mins ago











          • @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

            – ilkkachu
            31 mins ago















          3














          The list returned by that site has lines terminated by CR/LF. A CR (r) will move the caret/cursor to the beginning of the line:



          printf 'good r times'
          times





          share|improve this answer























          • Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

            – user323587
            40 mins ago











          • @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

            – ilkkachu
            31 mins ago













          3












          3








          3







          The list returned by that site has lines terminated by CR/LF. A CR (r) will move the caret/cursor to the beginning of the line:



          printf 'good r times'
          times





          share|improve this answer













          The list returned by that site has lines terminated by CR/LF. A CR (r) will move the caret/cursor to the beginning of the line:



          printf 'good r times'
          times






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 42 mins ago









          Uncle BillyUncle Billy

          6907




          6907












          • Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

            – user323587
            40 mins ago











          • @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

            – ilkkachu
            31 mins ago

















          • Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

            – user323587
            40 mins ago











          • @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

            – ilkkachu
            31 mins ago
















          Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

          – user323587
          40 mins ago





          Wow thanks! I just added |tr 'r' 'n' to the end of the pwned_count variable and now it works properly, thanks!

          – user323587
          40 mins ago













          @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

          – ilkkachu
          31 mins ago





          @user323587, tr -d 'r' would be more common, it actually removes the carriage return. Changing it to a newline of course works in your case, too, since the command substitution removes all trailing newlines.

          – ilkkachu
          31 mins ago

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f506865%2fvariable-completely-messes-up-echoed-string%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          名間水力發電廠 目录 沿革 設施 鄰近設施 註釋 外部連結 导航菜单23°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.7113923°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.71139計畫概要原始内容臺灣第一座BOT 模式開發的水力發電廠-名間水力電廠名間水力發電廠 水利署首件BOT案原始内容《小檔案》名間電廠 首座BOT水力發電廠原始内容名間電廠BOT - 經濟部水利署中區水資源局

          格濟夫卡 參考資料 导航菜单51°3′40″N 34°2′21″E / 51.06111°N 34.03917°E / 51.06111; 34.03917ГезівкаПогода в селі 编辑或修订