DRF项目之实现用户密码加密保存
Posted chao666
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DRF项目之实现用户密码加密保存相关的知识,希望对你有一定的参考价值。
在DRF项目的开发中,我们通过直接使用序列化器保存的用户信息时,用户的密码是被明文保存到数据库中。
代码实现:
def create(self, validated_data): ‘‘‘重写create方法实现,将密码加密后保存‘‘‘ # 将密码加密后保存 user = User.objects.create_user(**validated_data) return user
我们只需要在序列化器中,重写create方法,并将保存数据的方法由原来的create方法修改成create_user方法即可。
案例代码:
class UserAddSerializers(serializers.ModelSerializer): ‘‘‘增加用户的序列化器‘‘‘ class Meta: # 指定模型类 model = User # 指定模型字段 fields = [‘username‘,‘password‘,‘mobile‘,‘email‘] # 为序列化器字段添加约束 extra_kwargs = { ‘username‘: { ‘max_length‘: 20, ‘min_length‘: 5 }, ‘password‘: { ‘max_length‘: 20, ‘min_length‘: 8, ‘write_only‘: True }, } def create(self, validated_data): ‘‘‘重写create方法实现,将密码加密后保存‘‘‘ # 将密码加密后保存 user = User.objects.create_user(**validated_data) return user
以上是关于DRF项目之实现用户密码加密保存的主要内容,如果未能解决你的问题,请参考以下文章
Express实战 - 应用案例- realworld-API - 路由设计 - mongoose - 数据验证 - 密码加密 - 登录接口 - 身份认证 - token - 增删改查API(代码片段