第一天:Django 基础

第一天: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’

你可能感兴趣的:(第一天:Django 基础)