cookie 設置 讀取 加密 刪除html
#設置cook def seecook(request): response =HttpResponse('cook設置成功') response.set_cookie('cookiekey','setcook1',max_age=600) return response #讀取cook def readcook(request): name=request.COOKIES.get('cookiekey') return HttpResponse('cook讀取成功:{0}'.format(name)) #設置加密cook(set) def setmicook(request): response=HttpResponse('加密cook設置成功') response.set_signed_cookie('jiamicookie-key','jiamicookie-value',salt='python ok') return response #讀取加密cook(get) def readmicook(request): name=request.get_signed_cookie('jiamicookie-key',salt='python ok') return HttpResponse('獲取到的加密cook是:{0}'.format(name)) #刪除cook def deletecook(request): response=HttpResponse('cookie刪除成功!') response.delete_cookie('jiamicookie-key') return response
cookie 記錄帳戶名python
HTMLcookie
<input type="text" name="zhanghao" value="{{ zhanghao }}">
viewssession
#登陸成功 cookie記錄帳號名 def denglu(request): zhanghao=request.POST.get("zhanghao") mima=request.POST.get("mima") if zhanghao=='admin' and mima=='123': #驗證成功 重定向地址 response=HttpResponseRedirect('/zhuye/') response.set_signed_cookie("zhanghao",zhanghao,salt='python') response.set_signed_cookie("mima", mima, salt='python') return response else: try: zhanghao=request.get_signed_cookie("zhanghao",salt='python') return render(request,'login.html',{'zhanghao':zhanghao}) except: return render(request,'login.html')
cookie登陸成功記錄帳號app
Session 登陸成功記錄帳號 顯示在主頁post
<form method="post" action="/denglu/"> {% csrf_token %} <input type="text" name="zhanghao" value="{{ zhanghao }}"> <input type="password" name="mima"> <button>登陸</button> </form> **************************************************** {{ names }}的主頁 <a href="/tuichu/">退出</a>
def login(request): try: # 提取cookie帳號 zhanghao = request.get_signed_cookie("zhanghao", salt='python') return render(request, 'login.html', {'zhanghao': zhanghao}) except: return render(request,'login.html') def denglu(request): zhanghao=request.POST.get('zhanghao') mima = request.POST.get('mima') if zhanghao=='admin' and mima=='123': # 登陸成功寫入session request.session['names'] = zhanghao # 登陸成功寫入cookie response=HttpResponseRedirect('/zhuye/') response.set_signed_cookie("zhanghao", zhanghao, salt='python') return response else: return HttpResponseRedirect('/login/') def zhuye(request): # 登陸成功主頁提取session rec = request.session.get('names') if rec=='': return HttpResponseRedirect('/login/') else: return render(request,'zhuye.html',{'names':rec}) def tuichu(request): try: #退出刪除session del request.session['names'] return HttpResponseRedirect('/login/') except: return HttpResponseRedirect('/login/') pass
文件上傳ui
<form method="post" enctype="multipart/form-data" action="/shangchuan/"> {% csrf_token %} <input type="file" name="files"> <button type="submit">上傳</button> </form>
def wenjian(request): return render(request,'wenjian.html') def shangchuan(request): files=request.FILES.get('files') filedname=files.name print('\n文件上傳信息') print('文件名稱:{0}'.format(filedname)) print('文件大小:{0}'.format(files.size)) print('文件類型:{0}'.format(filedname.split('.')[-1])) print('*'*40) loadpath="app/static/file" if not os.path.exists(loadpath): os.mkdir(loadpath) print('文件夾首次建立成功') fileloadpath=loadpath+os.sep+filedname print('【系統】文件路徑:{0}'.format(fileloadpath)) try: with open(fileloadpath,'wb+') as fd: for chunk in files.chunks(): fd.write(chunk) print('【系統】文件寫入成功') return HttpResponse("<script> alert('文件上傳成功');location.herf='/wenjian/' </script>") except: return HttpResponse("<script> alert('文件上傳失敗');location.href='/wenjian/'</script>")
文件類型判斷加密
上傳照片回顯url
<head> <meta charset="UTF-8"> {% load static %} <title>文件</title> </head> <body> <form method="post" enctype="multipart/form-data" action="/shangchuan/"> {% csrf_token %} <input type="file" name="files"><br> <input type="file" name="files"> <button type="submit">上傳</button> {{ message }} </form> {% if imgurl %} <img src="{% static imgurl %}"> {% endif %} </body>
def wenjian(request): return render(request,'wenjian.html') def shangchuan(request): jiance=True fileslist=request.FILES.getlist('files') for files in fileslist: filedname = files.name filedtype=filedname.split('.')[-1] print('\n文件上傳信息') print('文件名稱:{0}'.format(filedname)) print('文件大小:{0}'.format(files.size)) print('文件類型:{0}'.format(filedname.split('.')[-1])) print('*' * 40) imgtypelist=['jpg','png','gif','bmp'] loadpath = "app/static/file" if filedtype not in imgtypelist: return render(request,'wenjian.html',{'message':'文件類型不符'}) if not os.path.exists(loadpath): os.mkdir(loadpath) print('文件夾首次建立成功') imgpre=str(uuid.uuid1()) filedname=imgpre+'.'+filedtype fileloadpath = loadpath + os.sep + filedname print('【系統】文件路徑:{0}'.format(fileloadpath)) try: with open(fileloadpath, 'wb+') as fd: for chunk in files.chunks(): fd.write(chunk) print('【系統】文件寫入成功') #return HttpResponse("<script> alert('文件上傳成功');location.herf='/wenjian/' </script>") content=dict() content['message']='圖片上傳成功' content['imgurl']='file/'+filedname return render(request,'wenjian.html',content) except: jiance=False