ajax json用法 上传文件 登录
json 是一种数据结构 跨平台跨语言
1. python中json数据的转换
1.数据类型
字符串 数字 布尔值 列表 字典 None
2. 序列化 python的数据类型 ——》 json字符串
json.dumps(python的数据类型)
json.dump(python的数据类型,f)
3. 反序列化 json字符串 ——》 python的数据类型
json.loads(json字符串)
json.load(json字符串,f)
2. js中json数据的转换
1.数据类型
字符串 数字 布尔值 数组 对象 null
2. 序列化 js的数据类型 ——》 json字符串
JSON.stringify(js的数据类型)
3. 反序列化 json字符串 ——》 JS的数据类型
JSON.parse(json字符串)
3. from django.http import JsonResponse 一般用来转换成字符串 字典就用这种方法
JsonResponse({})
JsonResponse([],safe=False) 传列表加这个参数
2. ajax上传文件 及登录
视图代码:
# 上传文件
def upload(request):
if request.is_ajax():
with open(f1.name, 'wb') as f:
for i in f1.chunks():
f.write(i)
<input type="file" id="my_file">
<button id="b1">上传</button>
$('#b1').click(
function () {
var form_obj = new FormData();
form_obj.append('f1', $('#my_file')[0].files[0]);
url: '/upload/',
type: 'post',
data: form_obj,
processData: false,
contentType: false,
success: function (res) {
console.log(res)
}
})
}
)
# 登陆
from django.views import View
from django.http import JsonResponse
class Log(View):
return render(request,'log.html')
# 传一个字典
ret={'status':0,'msg':''}
user=request.POST.get('user')
pwd=request.POST.get('pwd')
# 找到第一个 不要用[0] 来取
obj=models.User.objects.filter(name=user,pwd=pwd).first()
if obj:
# 给字典添加一个 登陆状态 及跳转网址
ret['url']='/upload/'
# 因为是字典新式 用JsonResponse
return JsonResponse(ret)
else:
# 给字典添加 1为和设置用户密码错误
ret['status']=1
ret['msg'] = '用户名或密码错误'
return JsonResponse(ret)
<p>
用户名:<input type="text" id="user">
</p>
<p>
密码:<input type="password" id="pwd">
</p>
<button id="b1">登录</button>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script>
$('#b1').click(function () {
$.ajax({
url:'/log/',
type:'post',
data:{
user:$('#user').val(),
pwd:$('#pwd').val()
},
success:function (res) {
{#res 是调回来的对象 #}
if (res.status ==0){
{# res.url 相当于取字典里的值#}
location.href = res.url
}
else {
alert(res.msg)
}
}
})
})
ajax json用法 上传文件 登录的更多相关文章
- H5 FormData对象的使用——进行Ajax请求并上传文件
XMLHttpRequest Level2 添加了一个新的接口——FormData .[ 主要用于发送表单数据,但也可以独立使用于传输键控数据.与普通的Ajax相比,它能异步上传二进制文件 ] 利用F ...
- jQuery Ajax使用FormData上传文件和其他数据,后端web.py获取
参考博文: 通过jQuery Ajax使用FormData对象上传文件 方法一:使用<form>表单初始化FormData对象方式上传文件 前端(JQuery): <form enc ...
- HTML5+AJAX原生分块上传文件的关键参数设置
processData:false 这是jquery.ajax的一个参数.默认值为true,表示会将非字符串对象自动变成k1=v1&k2=v2的形式,例如一个数组参数{d:[1,2]},到服务 ...
- Ajax 无刷新上传文件插件 uploadify 的使用
在表单中无法直接使用 Ajax 上传文件,解决的思路可以是使用插件无刷新地上传文件,返回文件上传后的地址,然后把该地址作为 Ajax 的参数传递给服务器端进行数据库处理.可以使用 uploadify ...
- ajax:html5上传文件,上传之前可以实现本地预览
本主题主要涉及两个新内容: 1.上传文件(主要使用了FormData) 2.本地预览(主要使用了FileReader) html5的FormData其实就是平时的Form表单,只是html5可以直接新 ...
- 使用FormData,进行Ajax请求并上传文件
前段时间做了个手机端的图片上传,为了用户体验,用ajax交互,发现了FromData对象,这里有详细解释https://developer.mozilla.org/zh-CN/docs/Web/API ...
- Ajax通过FormData上传文件
1.使用<form>表单初始化FormData对象方式上传文件 HTML代码 <form id="uploadForm" enctype="multip ...
- Springboot第三篇:与前端fetch通信(关于前端传输json数据上传文件等等前后端的处理)
关于前端接口传递的方法,推荐按以下使用: 若要在服务器上创建资源,推荐使用POST方法 若要检索某个资源,推荐使用GET方法 若要更新资源,推荐使用PUT方法 若要删除某个资源,推荐使用DELETE方 ...
- ajax无刷新上传文件
网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用ajax上传文件来做到这一点.只有ajax还不行,还需要JavaS ...
随机推荐
- Windows 7 64bit Python 2 Install
安装 setuptools 出现 UnicodeDecodeError 文件 Lib/mimetypes.py 中的 bug, 通过以下 patch 修复: Index: Lib/mimetypes. ...
- uva1482:Playing With Stones (SG函数)
题意:有N堆石子,每次可以取一堆的不超过半数的石子,没有可取的为输. 思路:假设只有一堆,手推出来,数量x可以表示为2^p-1形式的必输. 但是没什么用,因为最后要的不是0和1,而是SG函数:所以必输 ...
- Mac无法上网
今天mac突然无法上网了, 家里的大部分设备, 都出现了重启后无法上网的问题, 猜测可能是dns有问题了. 于是乎, 在mac中添加了如下DNS 114.114.114.114 8.8.8.8 1.1 ...
- 【正则表达式】java应用正则表达式
一:简单应用 /** * * ' * & * ' * & * & * ' * ' * ' * sources=sdcg'hde&xyz'dfa&&ad' ...
- window.open()与window.showModalDialog
弹出窗口两种方式: 1.window.showModalDialog: var feature = "dialogWidth:615px;dialogHeight:505px ...
- 转 sql 优化
1.关于SQL查询效率,100w数据,查询只要1秒,与您分享: 机器情况p4: 2.4内存: 1 Gos: windows 2003数据库: ms sql server 2000目的: 查询性能测试, ...
- Linux下的Nginx部署禅道
基本思路:先安装好nginx和mysql和php,上传禅道的源码.把禅道的源码包扔到 nginx/apache 的工程路径内或者nginx/apache内的配置文件指向nginx的路径,然后将ngin ...
- linux ssh公钥免密码登录
ssh 无密码登录要使用公钥与私钥.linux下可以用用ssh-keygen生成公钥/私钥对,下面我以CentOS为例. 一.SSH公钥登录原理 在平时工作中我们经常要远程登录服务器,这就要用到SSH ...
- C# ObjectArx AutoCAD二次开发(转帖)
http://www.cnblogs.com/houlinbo/p/3325898.html 1.开发基本资料准备 用Vs2010进行Autocad 2010开发,首先下载ObjectArx 2010 ...
- IONIC 页面之间传递参数
HomePage 定义goToMyPage方法,传递id和name MyPage接收参数