16-1 djanjo介绍

一 web框架的本质

1用户的浏览器(socket客户端) 和 网站的服务器(socket服务端)之间


2 HTTP协议:
  1.1 请求(request)

  1.2. 响应(response)

3 web框架本质

  a. 收发socket消息 web服务器

web应用程序

  b. 根据不同的请求执行不同的函数返回不同的内容
  c. 字符串替换

二 关于wsgi协议

1 Django开发阶段使用 wsgiref 模块来处理socket消息

2 Django部署到线上使用 uWsgi/gunicorn 模块来处理socket消息


3 Python中 web服务器程序和Web应用程序之间传递消息:
WSGI协议

三 Python里面Web框架的分类

  1. 自己实现b和c,使用第三方的a:
  Django框架
  2. 自己实现b,使用第三方的a和c:
  Flask
  3. 自己实现ac:
  Tornado

四 djanjo的安装和创建djanjo项目

1 安装

pip3 install django==1.11.11

pip3 list 查看当前Python解释器安装了哪些第三方包

pip3 install django==1.11 -i https://pypi.tuna.tsinghua.edu.cn/simple    #  -i指定源

pip3 uninstall django   #卸载

2 创建djanjo项目

2.1 命令行创建(不常用)

先选择一个目录,然后运行下面命令

 django-admin startproject s21django
在当前目录下创建一个名为 s21django 的Django项目

2.2 用pycharm创建

---》1新建项目

---》2指定项目路径和选择环境变量

--》指定app名字

---> 要在新的窗口打开

3 启动djanjo项目

1.1 pyhcarm启动方法,注意不能右键运行启动!

2.1 命令行启动(不常用)

  --》1. 切换到项目目录下!
  --》2. python manage.py runserver
    python manage.py runserver 127.0.0.1:8090 #指定ip和端口
    python manage.py runserver 8091

4 创建app

1.1 在PyCharm创建(见创建项目图,只能创建一个)

2.1 在命令行创建
1. 切换到项目目录下!
2. python manage.py startapp app名字
3. 在settings.py里面注册你新创建的那个app,如下

 1 # 当前Django项目安装的app都有哪一些
 2 INSTALLED_APPS = [
 3     'django.contrib.admin',
 4     'django.contrib.auth',
 5     'django.contrib.contenttypes',
 6     'django.contrib.sessions',
 7     'django.contrib.messages',
 8     'django.contrib.staticfiles',
 9     'app01.apps.App01Config',
10     'app02'  # 将我们创建的app02在Django项目注册一下
11 ]

5. Django项目使用静态文件的配置
--》1. 在项目目录下新建一个保存静态文件的文件夹
--》2. 告诉Django你去我上面新建的路径去找静态文件
  settings.py中 加上相应的配置项:如下:


STATIC_URL = '/static/'
# 静态文件实际保存的目录是哪一些
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]
 

-->3 在html页面引入刚才配置的静态文件js和bootstrap

<link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css">

五 MVC和MTV (了解即可)

1. MVC --> Model View Control
2. MTV --> Model Template views

六 基本路由系统 (urls.py)

1. 路由是一个有顺序的列表,从上到下去匹配
2. 路由的路径是根据正则表达式来匹配的

七. 基本视图函数(views.py)
1. 基础必会三件套
from django.shortcuts import HttpResponse, render
1. HttpResponse('字符串')
2. render(request, 'xx.html')
3. redirect 调转到一个新的页面

例子:

   # 跳转到index页面,让用户的浏览器去访问新的页面(index页面)
     return redirect("/index/")     
      return HttpResponse("登录失败")
    # 给用户返回一个页面 用来做登录
    return render(request, 'login.html')

 八 基本模板引擎(templates/xx.html)

2. 常用语法:
1. {{ 变量名 }}
2. {{ 变量名.key }}

3. for循环
{% for x in xx %}
{{x}}
{% endfor %}
4. if判断
{% if 条件 %}
...
{% else %}
...
{% endif %}

九 使用orm连接数据库

https://www.cnblogs.com/liwenzhou/articles/8276526.html orm具体介绍

 连接实例:

1 在setting.py里面设置要连接的数据库

 1 DATABASES = {
 2     'default': {
 3         'ENGINE': 'django.db.backends.mysql',  # 引擎
 4         'NAME': 's21hao',  # 数据库名
 5         'HOST': '127.0.0.1',  # 主机
 6         'PORT': 3306,  # 端口
 7         'USER': 'root',  # 用户名
 8         'PASSWORD': ''  # 密码
 9     }
10 }

2 告诉Django用pymysql连接MySQL数据库
在跟项目同名的文件夹下面的__init__里面添加

 1 import pymysql

2 pymysql.install_as_MySQLdb() 

3 models.py里面用orm写数据库语句,创建数据库

1 class Publisher(models.Model):
2     id=models.AutoField(primary_key=True)
3     name=models.CharField(max_length=32)
4 
5     def __str__(self):
6         return self.name

4 点开pycharm里面的terminal,然后运行

 1 python manage.py makemigrations --> 将models.py的改动记录在小本本上

2 python manage.py migrate  

5 建立数据库表结构成功!可以去数据库里查看

6 如果你想删除,则吧models.py里面的数据注释掉,然后再次运行第四项的两条语句即可

十 使用orm语句进行对数据库单表的增删改查

 1      1. 查询
 2             models.Publisher.objects.all()               --> 查询所有的出版社数据
 3             models.Publisher.objects.get(id=1)           --> 查询id=1的那个出版社
 4         2. 增加
 5             models.Publisher.objects.create(name='xx')   --> 创建一个名为xx的出版社
 6         3. 删除
 7             models.Publisher.objects.get(id=2).delete()  --> 删除id=2的那个出版社
 8         4. 编辑
 9             obj = models.Publisher.objects.get(id=2)     --> 找到要编辑的对象
10             obj.name = "新值"                             --> 修改
11             obj.save()                                   --> 将修改同步到数据库

十一 request相关知识点

 1     1. request.method  --> 获取用户请求的方法
 2         - GET          --> 表示用户向我要一个页面这种操作
 3         - POST         --> 表示用户向我发送一些数据
 4     2. request获取URL中的参数
 5         /xx/?name=alex&age=9000
 6         request.GET                        --> 大字典
 7             - request.GET['name']          --> 不推荐
 8             - request.GET.get("name")      --> 推荐
 9     3. request.POST                        --> 一个大字典,存的是用户post发过来的数据
10         1. request.POST['key']             --> 不推荐
11         2. request.POST.get('key', '默认值')

十二 djanjo里面前后端交互的流程(登录页面)

0 djanjo目录介绍

1 mysite/
2 ├── manage.py  # 管理文件
3 └── mysite  # 项目目录
4     ├── __init__.py
5     ├── settings.py  # 配置
6     ├── urls.py  # 路由 --> URL和函数的对应关系
7     └── wsgi.py  # runserver命令就使用wsgiref模块做简单的web server

1 定义url在url.py文件里面

from app01 import views
urlpatterns = [
    
    url(r'^login/', views.login),
]

2 然后去views里面写login函数(views.py)

 1 def login(request):
 2 
 3     if request.method=="POST":
 4         print(request.POST)
 5         username=request.POST.get("username","") #这里的username必须和html里面的name的值一致
 6         pwd=request.POST.get("password","")
 7         print(username,pwd)
 8         if username=="hu" and pwd=="123":
 9             return redirect("/index/")
10         else:
11             return HttpResponse("登录失败")
12     else:
13         return render(request,'login.html')

3 在templates目录下面写个login.html网页,还要引入bootstrap等样式

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>登录页面</title>
 6     <link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css">
 7 </head>
 8 <body>
 9 <div class="container" style="margin-top: 80px">
10     <div class="row">
11     <form class="form-horizontal" action="login.html" method="post">
12       <div class="form-group">
13         <label for="inputEmail3" class="col-sm-2 col-sm-offset-2 control-label">用户名</label>
14         <div class="col-sm-4" >
15           <input type="text" name="username" class="form-control" id="inputEmail3" placeholder="用户名">
16         </div>
17       </div>
18       <div class="form-group">
19         <label for="inputPassword3" class="col-sm-2 col-sm-offset-2 control-label">密码</label>
20         <div class="col-sm-4 ">
21           <input type="password" name="password" class="form-control" id="inputPassword3" placeholder="密码">
22         </div>
23       </div>
24 
25       <div class="form-group">
26         <div class="col-sm-offset-5 col-sm-10">
27           <button type="submit" class="btn btn-default">登录</button>
28         </div>
29       </div>
30     </form>
31     </div>
32 </div>
33 
34 </body>
35 </html>

4 要把bootstrap下载下来放到static目录下,并且需要在settings.py里面设置静态文件目录

STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]

5 在settings.py里面要把 # 'django.middleware.csrf.CsrfViewMiddleware', 暂时注释掉,否则不能提交

原文地址:https://www.cnblogs.com/huningfei/p/9427502.html