''' 解决版本共存 1. 用pycharm选择File点击NewProject然后选择virtualenv创建一个纯净环境 2. 打开下载的目录将venv文件夹下的所有文件(纯净的环境)copy到需要指定长期使用的文件夹下 3. 再次创建项目时,将该环境(指定长期使用的文件夹下Scripts文件夹中的python.exe文件)添加到pycharm环境选择(System Interpreter)中 4. 为该环境添加需要处理的版本共存包 '''
''' 路由匹配从上往下进行匹配,如果一轮都没有匹配成功,加/进行匹配 路由层: from django.urls import path, re_path urlpatterns = [ # 主页最上方配置 re_path('^$', root, name="root"), re_path('^index/$', index), re_path('^home/$', home), # 其他路由... # 404配在最下方 re_path('.*/$', error) ] 视图层: from django.shortcuts import render, redirect, reverse # 主页 def root(request): return render(request, 'root.html') def index(request): return redirect(reverse('root')) def home(request): return redirect(reverse('root')) # 404 def error(request): return render(request, 'error.html') '''
''' 1.无名称空间 主路由: path('app01/', include('app01.urls')) 子路由: path('test/', views.test) 2.有名称空间 有名称空间,与1版本不同,要将名称空间名和视图函数名放到一个数组中去 主路由: path('app01/', include(('app01.urls', 'app01'))), 子路由: path('test/', views.test, name='test') 模板层: {% url 'app01:test' %} '''
''' 动态页面:数据内容会发生变化的页面 静态页面:数据内容不会发生变化的页面 针对SEO(搜索引擎优化),静态页面更容易被搜索引擎网站收录 伪静态就是将动态页面伪装成静态页面,容易被搜索引擎网站收录,从而增加搜索概率,提高流量
通过.html来实现 ''' ''' #起了路由别名: 路由层: url('^index/$', views.index), url('^article/(?P<id>(d+)).html/$', views.article, name='article') 视图函数层: def index(request): return render(request, 'index.html') def article(request, id): return render(request, 'article.html', {'id': id}) 模板层: index.html <a href="{% url 'article' 1 %}">第一篇文章</a> <a href="{% url 'article' 2 %}">第二篇文章</a> <a href="{% url 'article' 3 %}">第三篇文章</a> article.html <h1>第{{ id }}篇文章</h1> #没有起路由别名: 路由层: url('^index/$', views.index), url('^article/(?P<id>(d+)).html/$', views.article) 视图函数层: def index(request): return render(request, 'index.html') def article(request, id): return render(request, 'article.html', {'id': id}) 模板层: index.html <a href="/article/1.html/">第一篇文章</a> <a href="/article/2.html/">第二篇文章</a> <a href="/article/3.html/">第三篇文章</a> article.html <h1>第{{ id }}篇文章</h1> '''
''' 请求/index/?abc=123 1. method: 请求方式 2. GET: 存放get的请求数据 结果:<QueryDict: {'abc': ['123']}> 3. POST: 存放post的请求数据(本质是从bdoy中取出来) 4. body: post提交的数据(不能直接查看) 5. path: 请求的路径,不带参数 结果:/index/ 6. request.get_full_path(): 请求路径,带参数 结果:/index/?abc=123 7. FILES: 文件数据 8. encoding: 编码格式 9. META: 数据大汇总的字典 10.is_ajax(): 是否是ajax请求 #False '''
''' FBV:function base views 函数方式完成视图响应 CBV:class base views 类方式完成视图响应 ''' ''' 注意:在settings.py下的中间件配置中找到含有csrf的那条代码,将它关闭这样就可以跳过post请求的安全认证
Python是一个面向对象的编程语言,如果只用函数来开发,有很多面向对象的优点就错失了(继承、封装、多态)。所以Django在后来加入了CBV。可以让我们用类写View。这样做的优点主要下面两种:
- 提高了代码的复用性,可以使用面向对象的技术,比如Mixin(多继承)
- 可以用不同的函数针对不同的HTTP方法处理,而不是通过很多if判断,提高代码可读性
请求/path/123 视图层: from django.shortcuts import HttpResponse from django.views import View class CBVView(View): def get(self, request,id): print('get请求!',id) #id=123 return render(request,'cbv.html') def post(self, request,id): print('post请求!',id) #id=456 print(request.POST.get('msg',None)) #获取提交的数据 return HttpResponse("响应post请求") 路由层: url('^path/(?P<id>d+)/$', views.CBVView.as_views()) 模板层: <form action="/path/456/" method="post"> <input type="text" name="msg"> <input type="submit"> </form> '''
''' 前端:upload.html页面 1.往自身路径发送post请求,要将第四个中间件注释 2.multipart/form-data格式允许发送文件 3.multiple属性表示可以多文件操作 <form action="" method="post" enctype="multipart/form-data"> <input type="file" name="files" multiple="multiple"> <input type="submit" value="上传"> </form> 后台:re_path('^upload/$', upload) def upload(request): if request.method == "GET": return render(request, 'upload.html') if request.method == "POST": # 如果一个key对应提交了多条数据,get取最后一个数据,getlist取全部数据 last_file = request.FILES.get('files', None) files = request.FILES.getlist('files', None) # import django.core.files.uploadedfile.TemporaryUploadedFile # file是TemporaryUploadedFile类型,本质是对系统file类封装,就是存放提交的文件数据的文件流对象,file.name就可以获得字符串类型的file的名字 for file in files: with open(file.name, 'wb') as f: for line in file: # 从file中去数据写到指定文件夹下的指定文件中,大文件用file.chunks() f.write(line) return HttpResponse('上传成功') 注意: ?拼接从get中拿数据,body中数据从post中拿 '''