( get请求方式没有编码格式和请求体)
index?useranme=&password=
参数直接在url地址的后面拼接着
form表单
Ajax
api工具
默认的编码格式:urlencoded
数据传输的形式:title=dasdas&price=2312&date=&publish=2&authors=3
把提交过来的数据都封装到了request.POST中
还可以提交form-data格式的
enctype:form-data # 提交文件数据
数据传输的形式:
title=dasdas&price=2312&date=&publish=2&authors=3
--------------binary-----------------------------
文件数据
普通数据还是在request.POST中
文件数据呢还是在request.FILES中
"""之所以你能够在POST和FILES中接收数据,是因为Django给你封装了,提交过来的数据并不是queryDICT"""
默认情况下,Ajax提交的数据后端还是在request.POST中接收的
默认的编码格式:urlencoded
需要修改contentType类型:json格式的
"""对于符合urlencoded格式的数据后端都是在request.POST中接收数据的"""
- """
- {"username":"kevin", "password":123} 它不符合urlencoded格式的数据
- """
- # 在Django后端肯定在request.POST中接收不到数据
- $.ajax({
- url:'',
- type:'post',
- data:JSON.stringify({a:1, b:2}), // 序列化的 "{"a":1, "b":2}"
- contentType:'application/json', // json格式的
- success:function (res) {
-
- }
- })
-
- def index(request):
- if request.method == 'POST':
- # request.POST只能接收post请求的符合urlencoded编码格式的数据 {}
- print(request.POST) #
- print(request.body) # b'{"a":1,"b":2}'
- json_bytes=request.body # 接收浏览器发过来的纯原生的数据,二进制,需要自己做封装处理
- # json_str=json_bytes.decode('utf-8') # {"a":1,"b":2}
- # print(json_str, type(json_str))
- import json
- # json_dict = json.loads(json_str)
- # print(json_dict, type(json_dict)) # {'a': 1, 'b': 2}
- json_dict=json.loads(json_bytes) # 最好不要省略
- print(json_dict, type(json_dict)) # {'a': 1, 'b': 2}
-
- return render(request, 'index.html')
-
- $(".btn").click(function (ev) {
- console.log(123);
- // 要获取到文件数据,
- {#console.log($("#myfile")[0].files[0]) // C:\fakepath\123.png#}
- // 提交文件数据需要借助于formdata对象
- var myFormDataObj = new FormData;
- var username = $("#username").val();
- var myfile = $("#myfile")[0].files[0];
- myFormDataObj.append('username', username);
- myFormDataObj.append('myfile',myfile);
-
- $.ajax({
- url: '',
- type: 'post',
- {#data: JSON.stringify({a: 1, b: 2}), // 序列化的 "{"a":1, "b":2}"#}
- data: myFormDataObj, // 序列化的 "{"a":1, "b":2}"
- {#contentType: 'application/json', // json格式的#}
- contentType:false, // 告诉浏览器不要给我的编码格式做任何的处理
- processData: false, //
- success: function (res) {
-
- }
- })
- })
- bulk_list = []
- for i in range(10000):
- user_obj=models.UserInfo(username='kevin%s' %i)
- bulk_list.append(user_obj)
- # 循环之后得到了一个列表,10000个对象
- # 数据库的优化, 同样的功能,不同的sql执行的效率差距很大
- # 优化查询速度的时候,首先想到的是,加索引、优化sql语句,有的sql走做引、有的sql不走索引
- models.UserInfo.objects.bulk_create(bulk_list)
divmod
- class Pagination(object):
- def __init__(self, current_page, all_count, per_page_num=2, pager_count=11):
- """
- 封装分页相关数据
- :param current_page: 当前页
- :param all_count: 数据库中的数据总条数
- :param per_page_num: 每页显示的数据条数
- :param pager_count: 最多显示的页码个数
- """
- try:
- current_page = int(current_page)
- except Exception as e:
- current_page = 1
-
- if current_page < 1:
- current_page = 1
-
- self.current_page = current_page
-
- self.all_count = all_count
- self.per_page_num = per_page_num
-
- # 总页码
- all_pager, tmp = divmod(all_count, per_page_num)
- if tmp:
- all_pager += 1
- self.all_pager = all_pager
-
- self.pager_count = pager_count
- self.pager_count_half = int((pager_count - 1) / 2)
-
- @property
- def start(self):
- return (self.current_page - 1) * self.per_page_num
-
- @property
- def end(self):
- return self.current_page * self.per_page_num
-
- @property
- def page_html(self):
- # 如果总页码 < 11个:
- if self.all_pager <= self.pager_count:
- pager_start = 1
- pager_end = self.all_pager + 1
- # 总页码 > 11
- else:
- # 当前页如果<=页面上最多显示11/2个页码
- if self.current_page <= self.pager_count_half:
- pager_start = 1
- pager_end = self.pager_count + 1
-
- # 当前页大于5
- else:
- # 页码翻到最后
- if (self.current_page + self.pager_count_half) > self.all_pager:
- pager_end = self.all_pager + 1
- pager_start = self.all_pager - self.pager_count + 1
- else:
- pager_start = self.current_page - self.pager_count_half
- pager_end = self.current_page + self.pager_count_half + 1
-
- page_html_list = []
- # 添加前面的nav和ul标签
- page_html_list.append('''
-
-
- ''')
- first_page = '
- 首页
' % (1) - page_html_list.append(first_page)
-
- if self.current_page <= 1:
- prev_page = '
- 上一页
' - else:
- prev_page = '
- 上一页
' % (self.current_page - 1,) -
- page_html_list.append(prev_page)
-
- for i in range(pager_start, pager_end):
- if i == self.current_page:
- temp = '
- %s
' % (i, i,) - else:
- temp = '
- %s
' % (i, i,) - page_html_list.append(temp)
-
- if self.current_page >= self.all_pager:
- next_page = '
- 下一页
' - else:
- next_page = '
- 下一页
' % (self.current_page + 1,) - page_html_list.append(next_page)
-
- last_page = '
- 尾页
' % (self.all_pager,) - page_html_list.append(last_page)
- # 尾部添加标签
- page_html_list.append('''
-
-
- ''')
- return ''.join(page_html_list)