Django自定义用户模型与认证系统实战

0 下载量 36 浏览量 更新于2024-08-30 收藏 49KB PDF 举报
本篇文章主要介绍了如何在Django框架中实现一个结合数据库、AJAX、JavaScript、Django表单以及认证系统的Web页面。首先,我们将深入探讨数据模型的扩展,然后是路由设置,最后是视图功能的实现。 **数据模块**: 在这个部分,作者扩展了Django默认的`AbstractUser`模型,创建了一个名为`UserInfo`的自定义用户模型,以满足特定需求。`UserInfo`类新增了两个字段:`phone`(用于存储用户的电话号码,类型为CharField,最大长度为11)和`gender`(表示用户性别,同样为CharField,最大长度为2)。这样,用户注册时除了用户名和密码外,还可以提供手机号码和性别信息。 **路由系统**: 路由配置是Web应用的核心,定义了URL与视图函数之间的映射关系。文章中列出了以下URL模式: 1. `/admin/`:指向Django管理界面。 2. `/register/`:用户注册页面的URL。 3. `/login/`:登录页面的URL。 4. `/home/`:可能代表用户主页或登录后展示的默认页面。 5. `/logout/`:用户注销的URL。 6. `/modify_pwd/`:用户修改密码的URL。 7. `/$`:通常处理根URL,这里的`views.home`可能为默认主页或重定向。 **视图系统**: 视图函数是业务逻辑的核心,处理用户请求并返回响应。关键的部分包括: - `register(request)`函数:接收用户注册请求,实例化`Reg_form`表单,并根据请求方法(POST或GET)处理表单提交。如果请求方式为POST,则验证表单数据并进行相应的操作,如保存用户到数据库。 - `login_view`、`logout_view`和`modify_pwd`:这些视图分别负责用户的登录、登出和密码修改,可能涉及认证、登录状态检查以及使用`authenticate`、`login`和`logout`等Django内置函数。 - `home`视图:可能是默认的首页,也可能是登录后的用户主页,可能会有登录状态检查并根据用户是否登录返回不同的页面。 此外,文中还提到了`JsonResponse`,表明视图可能返回JSON格式的数据,以及`login_required`装饰器,用于保护需要用户已登录才能访问的视图。 总结来说,这篇文章展示了如何在Django中构建一个具有用户认证功能的Web应用,包括用户数据模型的定制、URL路由的设置以及与之相关的视图函数设计。开发者可以通过阅读和学习这些内容,掌握在实际项目中实现类似功能的关键步骤和技术细节。