昨日回顾
1)、django的目录介绍
-urls.py 路由和视图函数的映射关系
-views.py 视图函数
-models.py 数据库相关操作
-settings.py 配置文件
2)、app是什么?
-项目中独立的功能,通常做成一个app
-python3 manage.py startapp app的名字
3)、django项目的启动方式
-命令行:python3 manage.py runserver 127.0.0.1:8080
-pycharm中启动,点绿色箭头
4)、配置文件
-是否是调试模式:开发阶段都是True,上线时False
-注册app
-中间件
-数据库链接配置
-静态文件
5)、静态文件
-1、项目根路径先创建目录(static)
-2、在settings.py中配置
STATIC_URL='/static/'
STATICFILES_DARS=[os.path.join(BASE_DIR,'static'),]
-3、static文件夹中创建目录
-js
-css
-img
-其他第三方模块
-4、模板文件中使用
-/static/js/jquery.min.js
6)、路由配置
-url(r'^login',views2.login),
7)、视图
-请求对象
-request.method----------->get post
-request.GET 当作字典用
-request.POST post形式请求传递的参数
-post请求也可以在请求地址中携带数据
-响应对象
-HttpResponse 返回字符串(其他形式返回的数据走的都是这个模式)
-render(request,'模板名字') 返回模板
-redirect('/index或者http://www.baidu.com') 返回重定向
8)、登录小案例
今日内容
1、登录功能,链接MySQL
路由
url(r'^login',views.login),
url(r'^index',views.index),
url(r'^test',views.test)
视图函数
def index(request):
return render(request, 'index2.html')
def login(request):
if request.method == 'GET':
return render(request, 'login.html')
else:
name = request.POST.get('name')
password = request.POST.get('password')
# 创建一个数据库链接
conn = pymysql.connect(host='127.0.0.1', user='root', password='123', database='userinfo', port=3306, )
# 拿到一个游标
cursor = conn.cursor()
# 执行sql
cursor.execute('select * from user where name=%s and password=%s ', (name, password))
# 获取结果
ret = cursor.fetchone()
print(ret)
if ret:
return redirect('/index')
else:
return HttpResponse('用户名或密码错误')
2、MTV与MVC
1)、django是MTV架构,本质也是MVC
-M:model,数据库相关操作
-T:template,模板文件(就是mvc的v层)
-V:view,视图,(路由+v视图函数=MVC的控制器)
2)、MVC架构:主流的web框架都是mvc
-web应用分为模型(M),控制器(c)和视图(V)
-M:model,数据库相关
-C:controler控制器,逻辑相关,逻辑代码
-V:视图,模板文件
3、django请求生命周期
0)、近几年python中的几个web框架,sanic,fastapi(异步框架)
1)、python中的web服务器都符合wsgi协议
2)、web服务器,任何语言都会有一个web服务器,负责把HTTP请求转成这门语言的变量,
-python:wsgiref(性能很低),uwsgi(c语言写的),200多并发量
-java:tomcat,jboss(300对并发量)
-PHP:PHP服务器
4、虚拟环境讲解,pycharm配置
1)、虚拟环境作用:隔离项目,每个项目有自己以来的模块和包,不同模块和包的版本就不会相互影响。
2)、pycharm中配置虚拟环境
5、orm概述
1)、orm:对象关系映射(跟语言无关)
数据库中的表-----------》对应程序的一个类
数据库中的一行数据------》对应程序中的一个对象
数据库中的字段对应的值-----》对应对象点属性
2)、python中常见的orm框架
-django的orm框架
-splachemy orm框架
3)、java:(扩展),Java中些web项目
ssh框架:spring+struts(有漏洞)+hibernate(orm框架)
ssm框架:spring+springmvc+mybatis(orm框架,可以写原生sql)
springboot:sb框架,tomcat内置进去了
springcloud:微服务
4)、orm能干的事
-创建表(不能创建数据库,手动创建数据库)
-增加删除表内字段
-增删查改数据
6、pycharm链接sqlite/MySQL
7、django中orm的使用
0)、sqlite:也是一个数据库,文件数据库,一个库就是一个文件,不需要单独安装
- 咱们现在在用,也要用到关系型数据库,不想装MySQL,就可以使用sqlite
-移动开发本地存储数据,存在sqlite中
1)、创建个UserINFO表,在models中写一个类
2)、表中有字段(类属性),字段有属性
第一步在models中写一个类
class UserINFO(models.Model):
#字段属性--》后面哪个对象决定的
#改字段自增,并且是主键
id=models.AutoField(primary_key=True)
#改字段是varchar类型,长度为32(唯一约束,是否是索引,默认值是,时候可以为空)
name=models.CharField(max_length=32)
#密码字段
password=models.CharField(max_length=64)
第二步,把表创建出来(执行两个命令)
-python3 manage.py makemigrations #这条名ing会在migrations创建一条记录,数据库变更记录
-python3 manage.pyy migrate #把更改同步到数据库