第一天:Django 基础
创建django项目
django-admin startproject devops
Django项目目录结构介绍
devops/
|-- manage.py
`-- devops
|-- __init__.py
|-- settings.py
|-- urls.py
`-- wsgi.py
最外层的devops/目录只是你项目的一个容器
manage.py 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互
内层
devops/ 目录是你项目中的实际Python包。通过它你可以导入它里面的任何东西
devops/__init__.py: 一个空文件,告诉Python该目录是一个Python包
devops/settings.py: 该Django项目的配置文件
devops/urls.py: 该Django项目的 URL 声明
devops/wsgi.py: 一个WSGI兼容的Web服务器的入口
起动服务
cd devops
python manage.py runserver
指定端口起动服务
python manage.py runserver 8000
指定ip与端口起动服务
python manage.py runserver 0.0.0.0:8000
新建Django app
1: 新建一个名为dashboard的app
python manage.py startapp dashboard
2: 配置url
from django.conf.urls import include, url
urlpatterns = [
... url(r'^dashboard/', include("dashboard.urls")),
]
3: 激活app
INSTALLED_APPS = (
……
’dashboard',
)
Hello world
step 1: 编写视图
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello world !!!")
step 2: 配置url
from django.conf.urls import include, url
from . import views
urlpatterns = [
url(r'^$', views.index, name='index'),
]
HttpRequest对象
由django创建
属性:
HttpRequest.scheme
HttpRequest.body
HttpRequest.path
HttpRequest.method
HttpRequest.encoding
HttpRequest.GET
HttpRequest.POST
HttpRequest.META
方法:
HttpRequest.get_host()
HttpRequest.get_port()
HttpRequest.get_full_path()
HttpRequest.is_secure()
HttpRequest.is_ajax()
HttpResponse对象
传递一个字符串作为页面的内容到 HttpResponse 构造函数
>>> from django.http import HttpResponse
>>> response = HttpResponse("Here's the text of the Web page.")
>>> response = HttpResponse("Text only, please.", content_type="text/plain")
属性:
HttpResponse.content
HttpResponse.charset
HttpResponse.status_code
HttpResponse.reason_phrase
方法:
HttpResponse.__init__(content=”, content_type=None, status=200, reason=None, charset=None)
JsonResponse 对象
JsonResponse(data, encoder=DjangoJSONEncoder, safe=True, json_dumps_params=None, **kwargs)
示例:
>>> from django.http import JsonResponse
>>> response = JsonResponse({'foo': 'bar'})
>>> response.content
b'{"foo": "bar"}'
>>> response = JsonResponse([1, 2, 3], safe=False)
加载模版
django.template.loader 这个模块提供了两种方法加载模板
get_template(template_name, using=None)
加载指定模板并返回Template对象
select_template(template_name_list, using=None)
它与get_template类似,它尝试每个名称并返回第一个存在的模板
从文件加载内容
from django.template import Context, loader
def index(request):
t = loader.get_template("test.html")
context = {"name": "hello reboot !!!"}
return HttpResponse(t.render(context, request))
快捷方式:render()
from django.shortcuts import render
def index(request):
context = {'name': "reboot"}
return render(request, 'test.html', context)
GET与POST请求
GET请求与传参
POST请求与数据提交
QueryDIct对象
在HttpRequest 对象中,GET 和POST 属性是django.http.QueryDict 的实例,它是一个自定义的类似字典的类,用来处理同一个键带有多个值。这个类的需求来自某些HTML 表单元素传递多个值给同一个键
request.POST 和request.GET 的QueryDict 在一个正常的请求/响应循环中是不可变的。若要获得可变的版本,需要使用.copy()。
实例化QueryDict
QueryDict.__init__(query_string=None, mutable=False, encoding=None)
示例
>>> QueryDict('a=1&a=2&c=3')
通过fromkeys实例化QueryDict (1.11新增)
classmethod QueryDict.fromkeys(iterable, value=”, mutable=False, encoding=None)
示例
>>> QueryDict.fromkeys(['a', 'a', 'b'], value='val')
QueryDict方法:
QueryDict.get(key, default=None)
QueryDict.setdefault(key, default=None)[source]
QueryDict.update(other_dict)
QueryDict.items()
QueryDict.values()
QueryDict.copy()
QueryDict.getlist(key, default=None)
QueryDict.setlist(key, list_)[source]
QueryDict.appendlist(key, item)
QueryDict.setlistdefault(key, default_list=None)
QueryDict.lists()
QueryDict.pop(key)
QueryDict.popitem()
QueryDict.dict()
QueryDict.urlencode(safe=None)
实战用户登陆
1. 配置django 数据库
2. 同步数据
3. Django API 创建用户
4. 执行用户登录
5. 深入解析用户登录过程
配置数据库
opsweb/settings.py是一个普通的python模块,每项配置都是一对key/value数据库的配置是以dict的形式存放在这个模块中,key名为:DATABASES
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '127.0.0.1',
'PORT': 3306,
}
}
同步数据
使用django的命令行工具同步数据库
python manage.py migrate
创建用户
使用django shell 创建普通用户:创建users最直接的方法是使用create_user()辅助函数
>>> from django.contrib.auth.models import User
>>> user = User.objects.create_user("rock", "[email protected]", "123456")
创建管理员
python manage.py createsuperuser --username=reboot [email protected]
修改密码
Django不会在user模型上存储原始的(明文)密码,而只是一个哈希。因为这个原因,不要尝试直接操作user的password属性。这也是为什么创建一个user时要使用辅助函数。
>>> from django.contrib.auth.models import User
>>> u = User.objects.get(username='rock')
>>> u.set_password('654321')
>>> u.save()
用户登陆
执行用户登陆
用户登陆过程详解
Django 配置
1. 配置静态文件
STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "static"),
)
2. 配置时区
TIME_ZONE = ’Asia/Shanghai’