第一天:dj 基础

创建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')
<QueryDict: {'a': ['1', '2'], 'c': ['3']}>

通过fromkeys实例化QueryDict (1.11新增)

classmethod QueryDict.fromkeys(iterable, value=”, mutable=False, encoding=None)

示例

>>> QueryDict.fromkeys(['a', 'a', 'b'], value='val')
<QueryDict: {'a': ['val', 'val'], 'b': ['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", "rock@51reboot.com", "123456")

创建管理员

>>> python manage.py createsuperuser --username=reboot --email=reboot@51reboot.com

修改密码

  • 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"),
)
  1. 配置时区
TIME_ZONE = ’Asia/Shanghai’
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值