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 ...
随机推荐
- C/C++ 字符串分割: strtok 与 strsep 函数说明
函数原型: char *strtok(char *s, const char *delim); char *strsep(char **s, const char *delim); 功能:strtok ...
- js操作链接url
使用js对当前的URL进行操作,可以使用内置对象window.location: window.location有以下属性: window.location.href:取得当前地址栏中的完整URL,可 ...
- python表单验证封装
在Web程序中往往包含大量的表单验证的工作,如:判断输入是否为空,是否符合规则. <!DOCTYPE html><html><head lang="en&quo ...
- 通过Jersey客户端API调用REST风格的Web服务
Jersey 客户端 API 基础 要开始使用 Jersey 客户端 API,你首先需要创建一个 com.sun.jersey .api.client.Client 类的实例.下面是最简单的方法: i ...
- MySQL--lsblk命令查看块设备
lsblk命令用于列出所有可用块设备的信息,而且还能显示他们之间的依赖关系,但是它不会列出RAM盘的信息.块设备有硬盘,闪存盘,cd-ROM等等. lsblk命令包含在util-linux-ng包中, ...
- 使用OASGraph 暴露rest 接口为graphql api
OASGraph 是loopback 团队开发的方便将rest api 暴露为graphql 的工具, 这个也是loopback 4 的一个新特性类似的有些团队提出了binding 以及stitch ...
- dgraph cluster docker-compose 安装
dgraph 是一款基于golang 的图数据库,使用了graphql+ 的查询方式 集群的安装官方也提供了对应的模版,比较简单 docker-compose 文件 我做了一些简单修改(数据存储的问题 ...
- tomcat和servlet关系
https://blog.csdn.net/weixin_30531261/article/details/78574410 图不错:https://www.cnblogs.com/fengli999 ...
- mybatis 生成 映射文件生成工具 mybatisGenerator 使用
第一:新建 generatorConfig.xml 文件 ,写入下面的 内容 <?xml version="1.0" encoding="UTF-8"?& ...
- 深入理解ASP.NET MVC(4)
系列目录 DataTokens和Areas机制 到目前为止Route对象只剩下DataTokens属性没有涉及,事实上这个Areas机制的核心. DataTokens实际上也是一个RouteValue ...