web全栈架构师[笔记] — 02 数据交互
数据交互
一、http协议
- 基本特点
- 1、无状态的协议
- 2、连接过程:发送连接请求、响应接受、发送请求
- 3、消息分两块:头、体
- http和https
二、form
- 基本属性
- action——提交到哪儿
- method——GET/POST/PUT/DELETE/HEAD
- GET:获取数据、把数据放在url里面传输、数据量很小、有缓存
- POST:发送数据、把数据放在body里面传输、数据量大、不会缓存
- PUT:发送数据
- DELETE:删除数据
- HEAD:让服务器之发送头回来就行(不需要内容)
- name:提交数据的名字
- enctype
application/x-www-form-urlencoded
:默认值,适合发送小数据,结构名字=值&名字=值&...
multipart/form-data
:文件上传、大数据,结构分块
text/plain
三、ajax
原理
XMLHttpRequest
,不兼容IE6- 1.创建对象
- 2.连接
- 3.发送
- 4.接受
function ajax (){
2 // 1.创建对象
3 let xhr = new XMLHttpRequest();
4 // 2.连接
5 /*
6 * open(method,url,async):规定请求的类型、URL 以及是否异步处理请求
7 * method:请求的类型;GET 或 POST
8 * url:文件在服务器上的位置
9 a * sync:true(异步)或 false(同步)
10 */
11 xhr.open('GET','./data/1.txt',true);
12 // 3.发送
13 /*
14 * send(string):将请求发送到服务器
15 * string:仅用于 POST 请求
16 *
17 * setRequestHeader(header,value):向请求添加 HTTP 头
18 * header: 规定头的名称
19 * value: 规定头的值
20 */
21 xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
22 xhr.send(null)
23 // 4.接受
24 /*
25 * responseText:获得字符串形式的响应数据
26 * responseXML:获得 XML 形式的响应数据
27 *
28 * onreadystatechange:存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数
29 *
30 * readyState:存有 XMLHttpRequest 的状态。从 0 到 4 发生变
31 * 0: 请求未初始化
32 * 1: 服务器连接已建立
33 * 2: 请求已接收
34 * 3: 请求处理中
35 * 4: 请求已完成,且响应已就绪
36 *
37 * status
38 * 200: "OK"
39 * 404: 未找到页面
40 */
41 xhr.onreadystatechange = function () {
42 if (xhr.readyState == 4) {
43 if (xhr.status>=200 && xhr.status<300 || xhr.status == 304) {
44 alert(xhr.responseText)
45 }else{
46 alert('error:'+xhr.status)
47 }
48 }
49 }
50 }原生ajax
优点
- 用户体验好
- 性能高
安全
- 前台没有安全性,后台才有问题(注入)
- xss——跨站脚本攻击
ajax 2.0
- FormData
- 文件上传、上传进度监控
- CORS跨域
四、jsonp
- 原理
五、websocket
web全栈架构师[笔记] — 02 数据交互的更多相关文章
- web全栈架构师[笔记] — 03 html5新特性
HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...
- web全栈架构师[笔记] — 01 ECMAScript6新特性
ES6新特性 一.变量 var:重复定义不报错:没有块级作用域:不能限制修改 let:变量,不能重复定义,有块级作用域 const:常量,不能重复定义,有块级作用域 二.函数/参数 箭头函数——简写: ...
- 2019最新WEB全栈架构师第八期视频教程
下载链接:https://www.yinxiangit.com/117.html
- 22期老男孩Ptython全栈架构师视频教程
老男孩Ptython全栈架构师视频教程 Python最新整理完整版22期视频教程 超60G课程容量<ignore_js_op> <ignore_js_op> <ignor ...
- 添物零基础到大型全栈架构师 Java实战及解析(实战篇)- 概述
实战篇是在基础之上,进一步提升的内容.通过实战篇可以深入理解Java相关框架和库的使用,能够独立开发小模块,或者按照架构师的指导进行代码编写和完善. 主要讲解核心框架和库的使用和使用场景介绍.通过 ...
- Kubernetes全栈架构师(基本概念)--学习笔记
目录 为什么要用Kubernetes? K8s控制节点-Master概念 K8s计算节点-Node概念 什么是Pod? 为什么要引入Pod? 创建一个Pod 零宕机发布应用必备知识:Pod三种探针 零 ...
- Kubernetes全栈架构师(Kubeadm高可用安装k8s集群)--学习笔记
目录 k8s高可用架构解析 Kubeadm基本环境配置 Kubeadm系统及内核升级 Kubeadm基本组件安装 Kubeadm高可用组件安装 Kubeadm集群初始化 高可用Master及Token ...
- Kubernetes全栈架构师(资源调度上)--学习笔记
目录 Replication Controller和ReplicaSet 无状态服务Deployment概念 Deployment的创建 Deployment的更新 Deployment的回滚 Dep ...
- Kubernetes全栈架构师(二进制高可用安装k8s集群部署篇)--学习笔记
目录 二进制高可用基本配置 二进制系统和内核升级 二进制基本组件安装 二进制生成证书详解 二进制高可用及etcd配置 二进制K8s组件配置 二进制使用Bootstrapping自动颁发证书 二进制No ...
随机推荐
- Eclipse 中打包插件 Fat Jar 的安装与使用
Eclipse可以安装一个叫Fat Jar的插件,用这个插件打包非常方便,Fat Jar的功能非常强大. 首先要下载Fat Jar,下载地址:https://sourceforge.net/proje ...
- Linux - 日志文件简介
Linux日志文件绝大多数存放在/var/log目录,其中一些日志文件由应用程序创建,其他的则通过syslog来创建. Linux系统日志文件通过syslog守护程序在syslog套接字/dev/lo ...
- javascript 最全面的数组操作合集
一.数组添加.删除.替换.截取操作 1.arr.unshift(1) 在数组头部添加一个元素 1 (直接改变原数组,返回值为添加元素后数组的length) 2.arr.shift() 在数组的头部删除 ...
- Liferay平台开发使用详细PPT演示文稿
主要章节: 概述 功能和使用 开发扩展 安全.认证 高可用 Demo 独立流程演示工程: Liferay集成Activiti开发工程: PPT演示文稿下载 Demo程序分2部分: 独立流程演示工程:h ...
- go http.Handler
http1 package main import ( "log" "net/http" "fmt" ) func main() { db: ...
- 四:理解Page类的运行机制(例:基于PageStatePersister的页面状态存取)
有人说类似gridview datalist这样的控件最好不要用在高并发,IO大的网站中企业应用中为了快速开发到可以用一用因为这是一类"沉重"的组件我们姑且不谈这种看法的正确性(我 ...
- cropper实现图片剪切上传
一.引入文件 <script src="jquery.min.js"></script> <link rel="stylesheet&quo ...
- Codeforces/TopCoder/ProjectEuler/CodeChef 散题笔记 (持续更新)
最近做到了一些有趣的散题,于是开个Blog记录一下吧… (如果有人想做这些题的话还是不要看题解吧…) 2017-03-16 PE 202 Laserbeam 题意:有一个正三角形的镜子屋,光线从$C$ ...
- Java并发编程笔记之SimpleDateFormat源码分析
SimpleDateFormat 是 Java 提供的一个格式化和解析日期的工具类,日常开发中应该经常会用到,但是由于它是线程不安全的,多线程公用一个 SimpleDateFormat 实例对日期进行 ...
- Java并发编程笔记之ConcurrentLinkedQueue源码探究
JDK 中基于链表的非阻塞无界队列 ConcurrentLinkedQueue 原理剖析,ConcurrentLinkedQueue 内部是如何使用 CAS 非阻塞算法来保证多线程下入队出队操作的线程 ...