web系统中常见的密码加密方式

本文探讨了web系统中用户密码加密的重要性,详细介绍了MD5信息摘要算法,包括其在MySQL中的应用和加盐策略。接着讨论了bcrypt加密算法,指出其每次加密结果不同,更适用于增强安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 用户密码加密

1.1 为什么对用户密码加密

        大多数web系统都有登录的功能,传统的登录方式是采用用户名+密码的形式进行,下面的截图就是CSDN的登录界面。

        在登录界面我们输入的肯定是明文,比如密码是123456,在密码的输入框内肯定也是输入同样的123456。输入框输入的是123456,但是在数据库是不会直接存储这一字符串的。在一个成熟系统中,数据库不会存储明文,它存储的通常是加密后的密文。比如以bcrypt加密后的密文字符串是这样的。

$2a$10$mWTEg1Byt3u/dAQl6GdJ5.UjVozRzCpxG4R64IvIvkwrJkwlfT5NG

        在数据库中存储加密后的密文自然是为了安全,因为这些密码密文存在于数据库中,就算数据由于各种原因导致数据库数据泄露,其他人拿到了用户名与密码的密文也不能够通过系统进行登录。

1.2 登录逻辑简介        

        在系统的页面中,无论是注册或登录模块,用户输入的密码都是明文,而数据库存储密码通常是密文。程序在处理登录时是走的这样的流程:

        现有一个用户拥有用户名为zhangsan,密码为123456的账号。在登录时,前端去调用后端的登录接口,并传入zhangsan与123456作为参数;后端接口中,会根据zhangsan这一用户名去查询数据库的用户表,查询出的内容会包括密码,查询出的密码是密文,要与密文进行对比自然需要将明文也加密成密文,所以这里将从

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值