一,启动Django运用
1、start project
在命令行输入 django-admin startproject test
, 系统会自动在当前文件夹下生成一个django文件夹。包含主要的配置文件。
2、start app 新建一个应用
在命令行输入django-admin startapp blog
, 系统会生成一个名为blog的应用文件夹,我们主要的工作就是在这进行的。
3、在主目录下,新建前端相关文件夹
为了后续使用模板以及css、js等相关内容,需要在主目录下新建如下文件夹:templates、static。其中,在static文件夹中,继续新建两个文件夹:css、js。所有都生成好后,文件夹结构如下:
文件夹结构
4、相关设置
在主文件test内,有一个setting.py文件,我们需要修改这个文件的相关配置:
1)、添加应用:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog',
]
2)、配置文件夹路径:
STATIC_URL = '/static/'
STATICFILES_DIRS=[
os.path.join(BASE_DIR, 'static')
]
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'static')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
二,Model
modles 常用数据类型
一)、用户模型
用户模型建议使用Django自带的User model, 这样可以方便注册、登录管理。
二)、文章模型
在models.py文件中作如下修改
from django.contrib.auth.models import User #引用系统自带的User模型
class Blog(models.Model):
title = models.CharField(max_length = 128)
tags = models.CharField(max_length = 128)
content = models.TextField()
create_time = models.DateTimeField(auto_now = True) #auto_now为每次修改自动保存时间
creator = models.ForeignKey(User, on_delete = models.CASCADE) #设置外键为User模型
def __str__(self):
return self.title
三,Views
在views.py文件中修改
注册
from django.contrib import auth
from django.contrib.auth.models import User
def register(request):
if request.method == 'GET':
return render(request, 'register.html')
elif request.method == 'POST':
username = request.POST.get('username',None)
password = request.POST.get('password',None)
user = User.objects.create_user(username) #注册用户
user.set_password(password) #设置密码,此函数会将密码加密,存储在数据库中
user.save() # 保存新建的用户
userlogin = auth.authenticate(username = username,password = password)
auth.login(request,userlogin) #用该用户登录登录
return redirect(index)
登录
def login(request):
if request.method == 'GET':
return render(request, 'login.html')
elif request.method == 'POST':
username = request.POST.get('username',None)
password = request.POST.get('password',None)
user = auth.authenticate(username=username,password=password)
if user is not None: #若用户名错误,user为None
if user.is_active: # 若密码正确,user.is_active为True,否则为False
auth.login(request,user)
return redirect(index)
else:
return render(request, 'login.html') # 密码错误
else:
return render(request, 'login.html') # 用户名错误
使用requests.user
可以获取当前用户的信息;使用requests.user.is_authenticated确认用户是否登录;使用request.session
可以获取一个session,是一个dict类型的变量, 该session在用户登录期间可用。
退出登录
@login_required
def logout(request):
auth.logout(request)
return redirect(index)
首页
def index(request):
blogs = Blog.objects.all()
return render(request, 'index.html', {'blogs': blogs})
文章详情
def detail(request, id): #id为url中传入参数,具体配置见下方urls.py的参数传递
blog = Blog.objects.get(id = id)
return render(request, 'detail.html', {'blog': blog})
四,Url配置
from django.conf.urls import url
from django.contrib import admin
from blog import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^$', views.index), #首页
url(r'^register/$', views.register, name = 'register'), #注册
url(r'^login/', views.login, name = 'login'), # 登录
url(r'logout$', views.logout), #退出登录
url(r'detail/(?P<id>\d+)', views.detail, name='detail'), #文章详情,传递参数格式:(?P<parm>.+),.+是正则的表达方式,name参数用于在template中定位该url
]
五、权限管理
Django权限管理
六、Django template的使用
- 使用多个filter
{{blog.content|safe|slice:"150"}} #使用多个‘|’,其中safe可以关闭转义, slice:"150"表示保留150个字符
- 使用url
{% url 'detail' blog.id %} #格式为url name parm,name为在urls.py中配置的name,parm为要传递的参数
- 继承模板
{% extends 'base.html' %}
完整代码:
网友评论