利用Django搭建python web项目(简单登录)

发布时间:2024年01月23日

1.概述

目前市面上web项目大多数是由java语言开发(结合spring框架),但这并不意味着只有java语言能够开发web项目,python语言、go语言同样可以做到。本文将利用Django框架(由python语言开发的web框架)来搭建一个简单的web项目,并实现简单登录功能。

2.实现过程

2.1 Django框架简介

2.1.1 Django框架优点

Django遵循MVC(Model-View-Controller)设计模式,提供了许多较为强大和便捷的工具来帮助开发。它的优势主要体现在以下几个方面:

  • 易于扩展:Django框架提供丰富的插件和模块,可以轻松地进行扩展和定制,例如:Django Fluent Dashboard、Python social auth等;
  • 安全性较高:Django框架内置了XSS(跨站点脚本)防护、CSRF(跨站点请求伪造)保护、密码哈希加密等;
  • 模块独立化:Django框架基于松耦合的设计原则,内部高度模块化,不同的模块可以独立编写、调测,极大地提高编写和测试的灵活性;
  • 自带后台:Django框架自带了一个丰富的后台管理系统,可以轻松实现一些内容管理;
  • 内置ORM框架:内置ORM,简单几行代码就可以连接数据库,并执行sql语句。

2.1.2 Django Web框架基础组件

Django的组件主要分为四个部分,模型(Model)、视图(View)、模版(Template)、路由(URLconf),具体解释如下:

  • 模型(Model):主要负责数据的存储和操作,和MVC中M层作用一致;
  • 视图(View):负责处理HTTP请求并返回HTTP相应,和MVC中的V层作用一致;
  • 模板(Template):负责渲染数据并生成HTML页面展示,类似于MVC中的C层;
  • URL路由(URLconf):负责将HTTP请求分发给相应的视图函数。

2.1.3 Django项目目录

  1. urls.py:网址入口,关联到对应的views.py中的一个函数(或generic类),访问网址就对应一个函数。

  2. views.py:处理用户发出的请求,与urls.py对应, 通过渲染templates中的网页可以将显示内容,如登陆后的用户名,用户请求的数据等输出到网页。

  3. models.py:与数据库操作相关,存入或读取数据时用到,用不到数据库时可以不使用。

  4. forms.py:表单,用户在浏览器上输入数据提交,对数据的验证工作以及输入框的生成等工作,也可以不使用。

  5. templates文件夹:views.py中的函数渲染templates中的html模板,得到动态内容的网页,可以用缓存来提高速度。

  6. admin.py:后台,可以用很少的代码就拥有一个强大的后台。

  7. settings.py:Django 的配置文件,如 DEBUG 的开关,静态文件的位置等。

2.2 搭建web项目

2.2.1 安装django

常用pip指令进行安装,如下:

pip install django

由于国内有墙,可以指定一些国内源即可:

pip install django -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com

安装完成后,可以通过以下命令来验证是否成功安装:

django-admin version

如果出现版本信息,则表明安装成功,如下:
在这里插入图片描述

2.2.2 创建项目

在这里插入图片描述

创建成功后目录结构如下:
在这里插入图片描述

setting:项目的配置文件,可以配置APP、数据库、中间件、模版等诸多信息;
urls:路由分发配置;
init:启动文件,会配置一些特殊信息;
manage:项目的管理文件;
wsgi:web服务器和Django交互的入口。

2.2.2 运行测试

1.利用以下指令启动项目

python manage.py runserver

在控制台中运行上述指令,启动成功后控制台会输出以下内容:
在这里插入图片描述
访问地址http://127.0.0.1:8000,会出现以下界面:
在这里插入图片描述

2.3 开发登录模块

2.3.1 创建项目

通过以下指令来创建python web项目,用于实现登录模块创建:

python manage.py startapp system

上述指令中的system就是登录模块名称。

2.3.2 注册应用程序

在根目录的setting.py文件中,将上述登录模块添加至INSTALLED_APPS 列表中,如下:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'system'
]

2.3.3 配置连接数据库

本文测试所使用的数据库为MySQL,在根目录的setting.py文件中,在DATABASES中配置MySQL连接信息,如下所示:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test',
        'HOST': '128.71.104.132',
        'PORT': '3306',
        'USER': 'root',
        'PASSWORD': '123456'
    }
}

同时在根目录的_init_.py文件中添加如下配置,否则在启动时会报一些连接异常:

import pymysql
pymysql.install_as_MySQLdb()

2.3.4 定义模型

在Django 中,数据模型中使用Python类来定义,我们需要在应用程序(system)的 models.py 文件中定义数据模型,本文以用户Account类来定义:

 # Create your models here.
class Account(models.Model):
    password = models.CharField(max_length=200)
    name = models.CharField(max_length=20)
    email = models.CharField(max_length=20)
    mobile = models.CharField(max_length=20)
    id = models.IntegerField(primary_key=True)

上述代码中定义了一个Account数据模型,包含id,mobile,email,name,password等属性,max_length指定的是最大长度。建立完成数据模型后,需要生成对应表到数据库中,运行以下指令:

#指令1
python manage.py makemigrations
 
#指令2
python manage.py migrate

运行指令1会生成一个新的迁移文件夹migrations,将模型映射到数据库的文件将会被放在这个文件夹下。如下图所示:
在这里插入图片描述
运行指令2会将模型信息映射到数据库中并生成表。

2.3.5 编写视图函数

在 Django 中,视图函数用于处理 HTTP 请求并生成 HTTP 响应。因此在登录模块的views.py文件中,编写如下视图函数:

from django.shortcuts import render, HttpResponse, redirect, reverse
from system.models import Account


def login(request):
    if request.method == 'POST':
        print("进入页面")
        name = request.POST['username']
        password = request.POST['password']
        print(name+":"+password)
        #根据name查询数据库,获取列表中第一个元素
        corr_user = Account.objects.filter(name=name).first()
        print(dir(corr_user))
        print("获取到信息")
        if password == corr_user.password:
            print('登录成功')
            return HttpResponse('登录成功')

    return render(request, './system/login.html')


def logon(request):
    return HttpResponse('logon')


def logout(request):
    return redirect(reverse('login'))


def index(request):
    print("进入index")
    return redirect(reverse('login'))

在上面的例子中,我们定义了名为 login、logon、logout 、index的视图函数。在login函数中,我们校验了账号和密码信息,如果成功则返回登录成功页面,否则重新返回登录页面。

2.3.6 创建html登录页面

定义一个登录页面,包含登录账号和密码等字段,该html放置在template文件夹下,如下所示:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title> 登陆 </title>
</head>
<body>
<div class="demo form-bg">
    <div class="container">
        <div class="row">
            <div class="col-md-offset-4 col-md-4 col-sm-offset-3 col-sm-6">
                <form class="form-horizontal" action="{% url 'login' %}" method="post">
                    <div class="heading">登陆</div>
                    <div class="form-group">
                        <i class="fa fa-user"></i><input required name="username" type="text"
                                                         class="form-control" placeholder="Username"
                                                         id="username">
                    </div>
                    <div class="form-group">
                        <i class="fa fa-lock"></i><input required name="password" type="password"
                                                         class="form-control" placeholder="password"/>
                    </div>
                    <div class="form-group">
                        <div class="form_btn">
                            <button type="submit">登录</button>
                        </div>
                    </div>
                </form>
            </div>
        </div>
    </div>
</div>
</body>
</html>

2.3.7 配置URL

在登录模块的urls.py文件中定义URL映射信息,具体如下:

from system.views import logout, logon, login
from django.urls import path

urlpatterns = [
    path('login/', login, name='login'),
    path('logon/', logon, name='logon'),
    path('logout/', logout, name='logout'),
]

我们分别将login、logon和logout映射到对应处理函数中。

2.3.8 测试验证

在这里插入图片描述
正确输入账号和密码信息后会出现以下页面:
在这里插入图片描述
同时控制台会打印如下信息:
在这里插入图片描述

2.3.9 注意事项

在同一台机器上启动项目,由前端直接访问python项目可能会出现跨域问题,因此需要添加如下配置:

ALLOWED_HOSTS = ['*']
# DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
CSRF_TRUSTED_ORIGINS = ['http://127.0.0.1']

3.小结

1.本文利用Django创建了一个python web项目,用于验证Django框架的便捷性,功能较为简单,并发和安全等相关性能需加强;
2.本文登录案例仅作为演示,需要进一步丰富各类入参校验,网关验证用户合法性等。

4.参考文献

1.https://www.cnblogs.com/fuchangjiang/p/17854807.html
2.https://www.djangoproject.com/

5.附录

https://gitee.com/Marinc/python-web.git

文章来源:https://blog.csdn.net/qq_33479841/article/details/135576447
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。