1.分頁
設(shè)置url
user->urls:添加
url(r'^manager/',views.manager,name='manager')
在views中創(chuàng)建manager函數(shù)
使用Paginator對(duì)數(shù)據(jù)進(jìn)行分組
def manager(request):
if request.method=='GET':
# 獲取路徑中page的數(shù)值
page_number=int(request.GET.get('page',1))
# managers=Users.objects.all()[3*(page_number-1):3*page_number]
managers=Users.objects.all()
# 使用Paginator將數(shù)據(jù)切割,下列是3個(gè)為一組
paginator=Paginator(managers,3)
# 返回第幾組數(shù)據(jù)
page=paginator.page(page_number)
return render(request,'manager.html',{'page':page})
創(chuàng)建manager.html并設(shè)計(jì)網(wǎng)頁
{% extends 'base_main.html' %}
{% block title %}
用戶管理頁面
{% endblock %}
{% block content %}
<p>當(dāng)前注冊(cè)的賬號(hào)</p>
<table>
<thead>
<th>id</th>
<th>用戶名</th>
<th>創(chuàng)建時(shí)間</th>
<th>修改時(shí)間</th>
</thead>
<tbody>
{% for manager in page %}
<tr>
<td>{{manager.id}}</td>
<td>{{manager.username}}</td>
<td>{{manager.create_time }}</td>
<td>{{manager.operate_time }}</td>
</tr>
{% endfor %}
</tbody>
</table>
<p>當(dāng)前頁:{{page.number}}</p>
<p>頁碼:
{% for i in page.paginator.page_range %}
<a href="{% url 'user:manager' %}?page={{i}}">{{i}}</a>
{% endfor %}
</p>
<p>
{% if page.has_previous %}
<a href="{% url 'user:manager' %}?page={{page.previous_page_number}}">上一頁</a>
{% endif %}
{% if page.has_next %}
<a href="{% url 'user:manager' %}?page={{page.next_page_number}}">下一頁</a>
{% endif %}
</p>
{% endblock %}
2圖像等文件傳輸
1)文件的添加和查詢路徑
- djg1->settings:末尾添加
MEDIA_URL='/media/'
MEDIA_ROOT=os.path.join(BASE_DIR,'media')
- 創(chuàng)建于djg1同級(jí)的文件夾media
- 在djg1->urls:末尾添加靜態(tài)路由和路徑
urlpatterns+=static(settings.MEDIA_URL,document_root=settings.MEDIA_ROOT)
2)文件添加
- 在user->models->Users中添加:
icon=models.ImageField(upload_to='upload',null=True,verbose_name='頭像')
- templates->register.html
將enctype="multipart/form-data"添加進(jìn)
<form action="" method="post" enctype="multipart/form-data">
在表單種添加
<p>頭像:<input type="file" name="icon"></p>
- user->views.py->register函數(shù):添加如下
將request.FILES添加進(jìn)
form=UserForm(request.POST,request.FILES)
將icon=request.FILES.get('icon')加進(jìn)
Users.objects.create(username=form.cleaned_data['username'],
password=password,
icon=request.FILES.get('icon'))
user->forms.py->UserForm:中添加
icon=forms.ImageField(required=True,
error_messages={
'required':'文件未傳'
})
3)文件查詢
- user->urls->urlpatterns:中添加
url(r'^manager/',views.manager,name='manager')
- 在templates->index.html->content中添加
<p>圖片:<img src="/media/{{user.icon}}"></p>
3.session校驗(yàn)
- 用session給cookie設(shè)值,給user_ticket表設(shè)值
request.session['user_id'] = user.id
- 設(shè)值session過期時(shí)間
方法一:在djg2->settings:末尾添加
SESSION_SERIALIZER='django.contrib.sessions.serializers.PickleSerializer'
在user->views->login中添加
request.session.set_expiry(timedelta(days=2))
該方法針對(duì)天數(shù)
方法二:
在user->views->login中添加
request.session.set_expiry(100)
該方法只針對(duì)秒
- 使用request.session['user_id']完成裝飾器的功能
def is_login(func):
def check(request):
try:
# 獲取session中已保存的user_id值
request.session['user_id']
except:
# 跳轉(zhuǎn)到登錄
return HttpResponseRedirect(reverse('user:login'))
return func(request)
return check
- 刪除session和cookie
方法一:
request.session.flush()
方法二:
session_key=request.session.session_key
request.session.delete(session_key)
4.csrf_token
在templates->login中使用{% csrf_token %}
能防止403錯(cuò)誤,在不注釋'django.middleware.csrf.CsrfViewMiddleware',的情況下