43: Hashing and de-hashing data using PHP | PHP tutorial | Learn PHP programming

Поділитися
Вставка
  • Опубліковано 8 лис 2024

КОМЕНТАРІ • 136

  • @fitimzenuni5036
    @fitimzenuni5036 6 років тому +40

    De-hashing is imposible mathematicly that is why it is safe.
    Hashing uses functions that can't be inverted so when u use the first parameter that is the actual pass and the second parameter that is the same pass just hashted it grabs the first parameter hashes it and compares it to the second parameter and if that is true it returns "1",that is how i think password_verify() works,since hashing is not an invertable function.
    BTW still the greatest PHP tutorials on youtube.

    • @Dani_Krossing
      @Dani_Krossing  6 років тому +12

      You are absolutely right :) I explained the process wrong in this video.

    • @qendrimvrella9962
      @qendrimvrella9962 5 років тому +1

      Nice 😊

    • @MrNsaysHi
      @MrNsaysHi 4 роки тому

      But how come the password_hash() gives different outputs for the exact same input?
      It's not the same as using a sha1() function and then manually comparing it with the input.. Which is better? and why?

    • @malloumjr
      @malloumjr 4 роки тому

      @@MrNsaysHi For security dear, if he can't give different in any second, hacker can have solution to hack

    • @MrNsaysHi
      @MrNsaysHi 4 роки тому

      @@malloumjr
      But isn't hashing a one way function that always gives the same output for the same input?

  • @w3s_dev
    @w3s_dev 6 років тому +19

    I have been watching the series so far and I learned a lot since. Thank you for doing such well done tutorial and putting it on the web for free. Technology is powerful and its effectiveness is enhanced by people like you sir.

  • @wywlf6912
    @wywlf6912 2 роки тому +2

    literally the best video out there explaining hash and dehash without spending more than 10 minutes

  • @nebiyuyouhannes6047
    @nebiyuyouhannes6047 4 роки тому

    this is the best channel for learning front end and back end thank you for this

  • @NickYea
    @NickYea 4 роки тому +3

    This is an amazingly simple, informative and pleasurable video to watch, thanks for making it so well!

  • @lucasarif4387
    @lucasarif4387 7 років тому +23

    Active channel making php tutorials? Unheard of - and awesome

  • @maherhanna2432
    @maherhanna2432 2 роки тому

    Your tutorials are very good and simple to understand thank you very much

  • @mohammadabdulkarim7750
    @mohammadabdulkarim7750 7 років тому +6

    You are the best man .I suggest to make some project using all you learned to us such as inventory website or something like that .it will help us alot and you can make it payable and will buy it .
    I understand every word you said in HTML/CSS curse,PHP and OOP PHP .

    • @mmforyou
      @mmforyou 7 років тому +1

      Please make it free..

    • @GIGATHEBOT
      @GIGATHEBOT 6 років тому

      in HTML/CSS *"CURSE"*

    • @frosttree7236
      @frosttree7236 6 років тому +1

      Completely worth to buy! Please make some project tutorials!!!

  • @zziq0437
    @zziq0437 4 місяці тому

    THANKS HARITH FOR SHARING

  • @meruBB
    @meruBB 2 роки тому

    simple and easy. Thanks bro

  • @zz98456
    @zz98456 5 років тому

    Thanks! Used your video to learn how to do test assignment.

  • @mmelimahlobo7656
    @mmelimahlobo7656 Рік тому

    Hie Daniel your teaching is amazing have you considered creating on lengthy tutorial that we can purchase in Udemy?

  • @MB-zj3er
    @MB-zj3er 2 роки тому

    Very helpful video. Thank you!

  • @RichardSantos-bk9vz
    @RichardSantos-bk9vz 4 роки тому

    Thanks now i understand how to use this hash 😁

  • @scottguo195
    @scottguo195 7 років тому +51

    You don't mean that you can actually DE-hash a hashed string right? If a hash can be de-hashed, it's not a hash anymore.

    • @petertester915
      @petertester915 5 років тому +2

      I'd recommend watching the video to the end.

    • @lollisko
      @lollisko 4 роки тому +1

      No it doesnt dehash it at all. Theres a ”salt” at the beginning of gibberis marked with two dollar marks. It’s used on original hash (rest of the string) for making it more complex and random. Password_verify() uses that same salt for hashing now inputted password and combines it to hash picked from database, and if this matches - password was correct.

  • @bigywhile8164
    @bigywhile8164 3 роки тому

    I really appreciate your great help. Thank you really much!

  • @keanutype0896
    @keanutype0896 2 роки тому

    i have questions:
    1. so basically when i Password_Has the first input i have, it will encrypt the text....but whatever i input there(ex: Test123) it IS STILL "Test123"? just being randomize when you echo it?
    2. is Password_Verify() similar to If and AND comparison statement but it will decyper first the encrypted password?
    like in If statement, you are trying to compare it like:
    if($input == $hashedPwdInDb){ echo "1";}
    but unlike a regular If Statement, it has the function to decyper the hashed password then compare it to the $input?
    i hope i worded this correct. sorry english wasn't my first language. great tutorial!

  • @olegpristashkin9078
    @olegpristashkin9078 3 роки тому +1

    How can we apply hash when the quantum computer will be finished? So can we assume, that the password hashing will be only a temporary method of protection? Am I right if I say that a good method of protection, in this case, is to limit attempts to log in up to 3 times an hour to avoid brut force?

  • @alizaman5716
    @alizaman5716 7 років тому +3

    HELLO SIR..
    I M ASP.NET C# DEVELOPER. I LOVE UR TEACHING STYLE N CLAERLY I GET UR ALL PHP LECTURES. THANK YOU SOO MUCH FOR UR EFFORTS
    PLZ UPLOAD THE 41 42 VIDEOS IN THS SERIES... :)

  • @goddessgermanika2466
    @goddessgermanika2466 3 роки тому +2

    Hi Dani, thank you very much for all those tutorials! In regards to passwords, what is your opinion about salting passwords? I was told that certain companies add it to hashed passwords. Do you think it would be good idea? and if so... do you have a tutorial for it by any chance?

  • @robinsonenrique2466
    @robinsonenrique2466 6 років тому +1

    Is better use BCRYPT or password_Default ?

  • @magicalbhakuni
    @magicalbhakuni 7 років тому

    learned a lot from this video.

  • @1988proxy
    @1988proxy 5 років тому

    Thank you very much for your videos!!!

  • @amoghdatar2726
    @amoghdatar2726 6 років тому +1

    *Will you pls reply to tell which is the **_BEST_** and **_SAFEST_** method of hashing passwords? BCrypt, Hashing It Two Times, S256, etc.?*

    • @Dani_Krossing
      @Dani_Krossing  6 років тому +1

      No just use BCrypt once :) BCrypt is automatically updated if it becomes outdated, so it will always be safe.

  • @nsoftltd6878
    @nsoftltd6878 3 роки тому +1

    Tnx bro

  • @yukii_kamishiro
    @yukii_kamishiro 4 роки тому

    Thank you, this help me alot.

  • @gabrielfono844
    @gabrielfono844 3 роки тому

    thanks so much
    thanks so much

  • @filodox21
    @filodox21 7 років тому

    Hello, your channel is fantastic. Did you know how many php classes you have?

  • @CredixNetwork
    @CredixNetwork 7 років тому

    Hello Daniel! Can I ask you a quick question? What color syntax/theme you're using? Thanks for the answer and for the great tutorial!

  • @GerritforBazeja
    @GerritforBazeja 6 років тому +1

    You are wonderfull for me. I'm trying to make our website website with better inlog and more. All in php and mysqli.
    Your lessons are very helpfull. (I'm 60 years old now. first I did this all in dramweaver.
    grtGrrt

  • @abhikhan1313
    @abhikhan1313 3 роки тому

    hey hi dani the link you have given in your description is showing the video is private

  • @Mustafa-gd2rp
    @Mustafa-gd2rp 7 років тому +15

    I don't think password_verify actually dehashes, instead it hashes the input and uses an algorithm to see if it corresponds to the given hash (giving all the necessary like salt and cost)

    • @thelavina
      @thelavina 6 років тому +2

      each time you hash something its always different, so how would the password_verify function know in which exact way to hash the inputted password then?

    • @hechuan5075
      @hechuan5075 6 років тому +1

      its not always different, for example, MD5 you see when you download a file, if you MD5 that file, you will get the MD5 result, otherwise its pointless. say SHA256("nihao") will always yield the same result.

    • @wegvS
      @wegvS 6 років тому

      Actually it is never different. From Wikipedia: "A hash procedure must be deterministic-meaning that for a given input value it must always generate the same hash value"

    • @fitimzenuni5036
      @fitimzenuni5036 6 років тому +1

      a function with the same input can not produce more than one output else it is not a function at least i think i learned that on a calculus class.

  • @rohansaand2023
    @rohansaand2023 7 років тому

    very informative, Thanks :)

  • @yukihyo8394
    @yukihyo8394 7 років тому +3

    Is it also save to hash a password with sha512? And then for comparing them, instead of dehashing you hash the input and compare them with the database. Love this method as well tho :D

    • @gewoonpatatmayonais
      @gewoonpatatmayonais 7 років тому +3

      Nope, that is definitely not safe! Whenever a hackers steals the hashed passwords from your database, he can dehash it (with lookup tables) and get the full password from that one user.
      Bcrypt adds a randomized 'salt' to it so that it is (almost) impossible for the hacker to retrieve the original value.
      So, don't just hash passwords with sha or md5 and store them in a database.

    • @gewoonpatatmayonais
      @gewoonpatatmayonais 7 років тому

      For example, hash a password with sha512. Copy the value and paste it in the text area at this site: crackstation.net/
      For simple passwords, you can get the value back. More complex passwords, however, may not be found.

    • @yukihyo8394
      @yukihyo8394 7 років тому

      what if you hash it like 3 times? using sha512, so you are hashing a hash?

    • @gewoonpatatmayonais
      @gewoonpatatmayonais 7 років тому

      King Otten you can, doesnt make it more secure. Can still be looked up in a rainbow table, hence why the salting process in bcrypt

    • @Dani_Krossing
      @Dani_Krossing  7 років тому +1

      name is absolutely right here. You should not use either md5, sha256 or sha512, since hackers figured out how to solve these algorithms long time ago. Thats why bcrypt is so awesome, because if hackers somehow (which is very unlikely) figure out how to bypass it, then bcrypt will just get updated and yet again be safe to continue using.

  • @ВенциславИлиев-ъ5т

    When is the link to the login system tutorial? The link is not working for me?

  • @hanishaarora9590
    @hanishaarora9590 6 років тому

    super cool!!

  • @PHPRunnerTipsAndTricks
    @PHPRunnerTipsAndTricks 5 років тому

    So what is password_verify really doing? Could you test password_hash(input) with passwordinDb with an if statement?

  • @vikaspadaliya2606
    @vikaspadaliya2606 7 років тому +5

    Can't find no.41 and 42 , are they missing?

    • @ashkanahmadi
      @ashkanahmadi 4 роки тому

      ua-cam.com/play/PL0eyrZgxdwhwBToawjm9faF1ixePexft-.html

  • @marshal523
    @marshal523 7 років тому

    Please make a tutorial on how to create a contact form using php

    • @Dani_Krossing
      @Dani_Krossing  7 років тому

      Marshal Hembram I already did ;)

    • @marshal523
      @marshal523 7 років тому

      Kindly provide the link please :)

  • @westfield90
    @westfield90 6 років тому

    Superb

  • @pianoLee-sx9dx
    @pianoLee-sx9dx 6 років тому

    I forgot to ask.. do you still need to salt the password? I read somewhere that you still have to

  • @derxramos7906
    @derxramos7906 5 років тому

    Great tutorial :) I'd just like to ask how can I use that encrypted password to send email in PHPMailer? Thank you.

  • @hachij_
    @hachij_ 6 років тому

    is this updated video? cuz, last time i checked is different from this one pls explain which parts you updated?

    • @Dani_Krossing
      @Dani_Krossing  6 років тому

      This video is updated and the most recent version of data hashing.

  • @femaledeer
    @femaledeer 3 роки тому +1

    If two different users create the same user name and password, how does the correct user get verified when logging in? You said two different hashes would be produced when the user registers. Is there a magic trick to determine the correct user to validate?

    • @MB-zj3er
      @MB-zj3er 2 роки тому

      Don't allow duplicate user names when accounts are created. ;)

  • @pianoLee-sx9dx
    @pianoLee-sx9dx 5 років тому

    I don't think that you can get someone to enter a password and then check it in the database? I think once you hash the new password, it will always be different from the database and won't work...

  • @mariusmihailionte3359
    @mariusmihailionte3359 7 років тому

    are you uploading again videos that you posted in 2015?

  • @yanghyunmo1929
    @yanghyunmo1929 5 років тому

    Can I ask where is the full version of Login system tutorial? I remember you had it before in the tutorial.

    • @rashedulhasan5372
      @rashedulhasan5372 4 роки тому

      yap..link isn't working. Would be useful to see hashing in action

    • @Venezuelangel
      @Venezuelangel 4 роки тому

      It's been set to private. Probably the creator was catching a lot of heat for making it procedural instead object-oriented? I dunno. Maybe he wants to monetize it?

    • @gabrielvoss6251
      @gabrielvoss6251 4 роки тому

      @@Venezuelangel no it's just on another channel @ZbII

  • @MrBondSanjay1
    @MrBondSanjay1 3 роки тому

    Please Dani Can you help me ? Code not work with me .I am using Atom.

  • @nicolesantos603
    @nicolesantos603 Рік тому

    5:45 dehash

  • @willthe5135
    @willthe5135 5 років тому

    How can I hash with AES 256 bit encryption? Or is bCrypt already that strong?

  • @BeyondReality
    @BeyondReality Рік тому

    That doesn‘t work in my case. When I copy the hash and paste it into a variable, the verify method returns an invalid password 😢

  • @AugerHybrid
    @AugerHybrid 4 роки тому

    OMG it worked but sequence is "This video is private".

    • @ashkanahmadi
      @ashkanahmadi 4 роки тому

      ua-cam.com/video/LC9GaXkdxF8/v-deo.html

  • @abdulkarimalbaik3873
    @abdulkarimalbaik3873 5 років тому

    what is type of String after hashing (String , int or byte) ????

  • @kirilmladenov7852
    @kirilmladenov7852 6 років тому

    Guys, I am a little confused ( : What is the difference between hashing, real_escape function and prepared statements?

  • @jessm.sandler7187
    @jessm.sandler7187 Рік тому

    video on link is not available bro

  • @NoThoughtAllFeels
    @NoThoughtAllFeels 4 роки тому

    How did you get that index.php file in the first place

  • @dombiekong4733
    @dombiekong4733 4 роки тому

    what about random salt?

  • @carlbaiden191
    @carlbaiden191 4 роки тому

    The 43rd video is private...how can i get it pleas?

  • @ambdcot3828
    @ambdcot3828 4 роки тому

    Hey, video 44 is private, is this ok?

  • @isaiahdaniel2522
    @isaiahdaniel2522 5 років тому +1

    Please the password hash did not work when i type it, any help plz

  • @Akosiyawin
    @Akosiyawin 5 років тому

    I'm getting an error says 'call to undefined function password_hash()' Idk why I did exactly what you does, any thoughts about it?
    Edit:I'm using 1.8.2 version of xampp and 5.4.22 Php Version does it affect my program?

    • @Dani_Krossing
      @Dani_Krossing  5 років тому +1

      Yes, you should definitely upgrade. A lot of changes were made since then. PHP is all the way at 7.0+ in its version now. It should fix your undefined error.

    • @Akosiyawin
      @Akosiyawin 5 років тому

      @@Dani_Krossing yep thank you very much. That's exactly what I did, coz back on your tutorial I saw the version of your Xampp was compiled on 2015 while mine is 2013, didn't notice that I was using an old version of xampp hehe, Thank you sir, I'm almost finish with this tutorial, have a good day.

  • @AndyChamberlainMusic
    @AndyChamberlainMusic 4 роки тому

    link is broken

  • @devsabuj4818
    @devsabuj4818 3 роки тому

    is it possible decode password hash

  • @kestonsmith1354
    @kestonsmith1354 3 роки тому

    You made the login video private so I can't view it.

  • @adnanjan1298
    @adnanjan1298 5 років тому

    respected sir, i get a lot of knowledge from your lessons: now i have a problem, when i practice of password_hash function i receive this error message in chrome browser: {{{{{{Fatal error: Call to undefined function PASSWORD_HASH}}}} kindly help me.

  • @hachij_
    @hachij_ 7 років тому

    good

  • @randalfjohn9848
    @randalfjohn9848 2 роки тому

    This is lesson 43.. how can I get from lesson 1 to the end.. please 😭

  • @comfortbatcall
    @comfortbatcall 6 років тому

    Me it's always saying login=error in the url help how can it fix?

  • @cjvaans4484
    @cjvaans4484 4 роки тому

    You talk way too fast as if the words are stitched together. Still, I thank for you these free tutorial videos.

    • @ashkanahmadi
      @ashkanahmadi 4 роки тому

      You can turn on the subtitle and change the playback speed to 0.75. That should make it clearer for you

  • @michaellussem1777
    @michaellussem1777 4 роки тому

    Link to login-Tutorial isn‘t working

  • @aaammm1888
    @aaammm1888 4 роки тому +1

    44: vidoe on pvt whyyyyyyyy came so far

    • @ashkanahmadi
      @ashkanahmadi 4 роки тому

      ua-cam.com/video/LC9GaXkdxF8/v-deo.html

  • @xbond2089
    @xbond2089 3 роки тому

    it dose not work when stored in database

  • @anshultiwari2704
    @anshultiwari2704 5 років тому

    Suppose i have to store chat messages in my database in a secure and hashed format how can I dehash those text messages whenever it is displayed back to the user??
    Can someone tell me a better way to encrypt text messages in php and MySQL database

    • @Jack-vv7zb
      @Jack-vv7zb 4 роки тому +1

      You'll have to encrypt them instead of hash them. Encrypt means it uses a key and so they can be decrypted. It's less safe than hashing of course because if someone gets hold of the key then they can access everything.

  • @falconeye1594
    @falconeye1594 7 років тому

    42 is miss bro.

  • @renzjosefflacostales4015
    @renzjosefflacostales4015 6 років тому

    Sir is there any chance to view the normal password ni phpmyadmin coz i don't know to view the normal password in database.it will be hard especially when I forgot the password :( thanks in advance sir

    • @Dani_Krossing
      @Dani_Krossing  6 років тому

      No that would defeat the purpose of hashing it hehe. The point is that we SHOULD NOT be able to see the password in the database in case a hacker gains access.

  • @piotrpytkowski1542
    @piotrpytkowski1542 3 роки тому

    So about this Login system tutorial (link starts at hashing part): ua-cam.com/video/xb8aad4MRx8/v-deo.htmlm42s - the movie is private, is this will be avaible?

  • @Kuminlul
    @Kuminlul 6 років тому

    so how do i hash the username with the same method like with the password?

    • @definedbass
      @definedbass 5 років тому

      method is the same but why would you hash the username? Username is public in most scenarios

  • @riteshsingh214
    @riteshsingh214 5 років тому

    can you make a video on how to create a sub-domain dynamically through PHP i have done the same it is creating domain too but in root folder it is creating problem
    following is the code

    but in root folder it is creating not creating the folder of same name as entered by user it is creating folder named as'$domain.example.in'.
    Please help
    Thanks in advance.

  • @ΛέανδροςΚουρτίδης-κ6β

    link does not work!!!

  • @PabloGnesutta
    @PabloGnesutta 4 роки тому

    The login video in the description of this video is broken T_T

    • @ashkanahmadi
      @ashkanahmadi 4 роки тому

      ua-cam.com/video/LC9GaXkdxF8/v-deo.html

  • @JustinTheVlogger
    @JustinTheVlogger 3 роки тому

    Greate tutorial, but next please talk slow, cause some of your words are unhearable.

  • @ArifBillahOnGoogle
    @ArifBillahOnGoogle 3 роки тому

    The title is rather misleading. You don't "de-hash" with password_verify()

  • @moh.syafrianabie8899
    @moh.syafrianabie8899 3 роки тому

    2:00

  • @rahman_athu
    @rahman_athu 5 років тому

    Password verify always returning false

  • @connorgdev
    @connorgdev 7 років тому

    It thought the whole point of hashing was you can never "de-hash" it? You can only re-hash new information and compare with the saved/old hash... I thought it was encryption and decryption where you could get the information back

    • @inferno7181
      @inferno7181 7 років тому

      Connor Gaunt it doesn't. It just hashes the password with the same salt and compares it to the one given.

  • @boiski
    @boiski 4 роки тому

    I tried to crack the password. Did it in 3 seconds

  • @shaikansar1315
    @shaikansar1315 6 років тому

    when iam logging it takes any password and logging me in

  • @thezvid
    @thezvid 4 роки тому

    This Video is Private

  • @CabdacasiisCabdle
    @CabdacasiisCabdle Місяць тому

    kkkkkkk

  • @inzMBL
    @inzMBL 6 років тому

    You talk funny

  • @Sean.Q
    @Sean.Q 4 роки тому

    PAYWALLED Correct way ??? BS... UA-cam money isn't enough for you? You really need to fish for a buck a month on Patreon?

  • @adityachopra3759
    @adityachopra3759 6 років тому

    Stop using the term "DE-HASH". It is invalid. You can't DE-HASH.