ajax跨域访问问题

  1. 什么是跨域访问

    从一个域名去访问另一个域名的资源

    或者从一个站点去访问另一个站点的资源

  2. 哪些请求方式可以发送跨域请求

    • 超链接

    • form表单

    • 传统js代码

    • javascript标签加载(后期可以改造为jsonp方式)

    • img标签

    相同点:直接改变地址栏地址

  3. 哪些方式不能发送跨域请求

    • 默认情况下,ajax请求方式:被同源策略阻止
  4. 什么是同源策略?

    • 浏览器的一种安全策略
    • 同源三要素:协议一致,域名一致,端口号一致
    • 只有同源才可共用同一个XMLHttpRequest
  5. 为什么不能不同源则不能共用同一个XMLHttpRequest?

    • 安全角度
  6. 解决ajax跨域请求的方案

    方案1:设置响应头

    //被访问的资源,设置允许访问自身的访问源
    response.setHeader("Access-Control-Allow-Origin", "http://localhost:8080") //允许某个访问源
    response.setHeader("Access-Control-Allow-Origin", "*") //允许所有访问源

    方案2:jsonp(压根没有用到XMLHttpRequest对象,不受同源策略的限制)

    • json with padding(带填充的json)

    • 不是一个真正的ajax请求,但是可以完成局部刷新效果,是一种类ajax请求

    • 并且可以完成ajax跨域请求

      <!--利用<script>标签,不用超链接(页面跳转,非局部刷新)-->
      <script src="http://localhost;8081/b/jsonp1"></script> <!--
      后端响应的js代码,在返回到前端后,浏览器会执行这段js代码
      --> <!--
      前端可以动态的向后端传递要调用的函数的名称
      -->

      jsonp 解决跨域问题时,只支持get请求

      jsonp底层原理实现

         自定义时机执行<script>标签
      var scriptElement = document.createElement("script") //创建script元素
      scriptElement.type = "text/javascript" //设置script元素属性
      scriptElement.src = "http://localhost:8081/b/jsonp1?fun=sayHello"
      document.getElementsByTagName("body")[0].appendChild(scriptElement) //将script对象添加到body标签中(相当于完成了script标签的加载)
      后端返回数据时参照前端函数名返回

    方案3:官方jQuery类库封装的jsonp

      本质:方案2的高度封装
    核心代码 ```javascript
    $.ajax({
    type : "GET",
    url : "http://localhost:8081/b/jsonp1",
    dataType : "jsonp" //数据类型
    jsonp : "fun" //指定参数名,不设置的时候默认为"call back" ----> 指定第一层回调函数(主要用来作为入口,接受后端传来的json数据)
    jsonCallback : "sayHello" //指定回调函数的名字,不设置的时候,随即生成一个回调函数,且会调用success的回调函数 ----> 指定第二层回调函数(主要用于按照程序员需求处理后端传来的数据)
    })
    ```

    方案4 : 代理机制

    java程序如何发送get或者post请求?

    1. jdk内置的API

      1. java.net.URL... 可以发送http请求
    2. 第三方的开源组件
      1. apache的httpclient组件(开源免费)

    方案5:nginx反向代理

    学习了nginx再继续研究

ajax03_跨域访问问题的更多相关文章

  1. 解决cookie跨域访问

    一.前言 随着项目模块越来越多,很多模块现在都是独立部署.模块之间的交流有时可能会通过cookie来完成.比如说门户和应用,分别部署在不同的机器或者web容器中,假如用户登陆之后会在浏览器客户端写入c ...

  2. Angular2中对ASP.NET MVC跨域访问

    应用场景 项目开发决定使用angular2进行前后端分离开发,由我负责后端服务的开发,起初选择的是web api进行开发.对跨域访问通过API中间件+过滤器对跨域访问进行支持.开发一段后,通知需要移植 ...

  3. cookie 跨域访问的解决方案

    Cookie 同域单点登录  最近在做一个单点登录的系统整合项目,之前我们使用控件实现单点登录(以后可以介绍一下).但现在为了满足客户需求,在不使用控件情况下实现单点登录,先来介绍一下单点登录.    ...

  4. System.Web.Http.Cors配置跨域访问的两种方式

    System.Web.Http.Cors配置跨域访问的两种方式 使用System.Web.Http.Cors配置跨域访问,众多大神已经发布了很多文章,我就不在详细描述了,作为小白我只说一下自己的使用心 ...

  5. flash跨域访问,crossdomain.xml,error #2048

    最近遇到了flash的万年老梗,跨域访问的问题.之前一直没有处理过这类问题,是因为做项目的时候别人已经处理好了.真到自己遇到的时候,还是很费脑筋的. 1遇到的问题 客户端发布到网页的时候,socket ...

  6. Ajax跨域访问wcf服务中所遇到的问题总结。

    工具说明:vs2012,sql server 2008R2 1.首先,通过vs2012建立一个wcf服务项目,建立好之后.再新开一个vs2012 建立web项目,通过jQuery的ajax方法访问服务 ...

  7. Jsonp跨域访问

    很早之前看过好几篇跨域访问的文章,然后做项目的时候基本没有遇到跨域访问的问题.不过该来的还是会来,前些天终于让我遇到了.于是重温了一下原理这些,再进行实战.于是现在也敢通过实战后的一些理解来和大家分享 ...

  8. js跨域访问,No 'Access-Control-Allow-Origin' header is present on the requested resource

    js跨域访问提示错误:XMLHttpRequest cannot load http://...... No 'Access-Control-Allow-Origin' header is prese ...

  9. ajax 跨域访问

    后台方法添加 HttpServletResponse response=ServletActionContext.getResponse(); response.addHeader("Acc ...

随机推荐

  1. Windows平台安装SQLite3数据库

    Windows平台安装SQLite3数据库 话不多说,开始! 访问SQLite官网下载资源 在搜索引擎中键入SQLite3关键字寻找官网入口或直接点击此处前往SQLite官网,官网界面如下: 点击页面 ...

  2. CentOS 并没有死,Rocky Linux 让其重生

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 近日,CentOS 官方发文称CentOS Stream ...

  3. 网页数字递增——jquery.countTo.js

    html <div class="timer" data-to="633"></div> <div class="tim ...

  4. 从防御者视角来看APT攻击

    前言 APT防御的重要性毋庸讳言,为了帮助各位师傅在防御方面建立一个总体认识,本文会将APT防御方法分为三类,分别是:监控.检测和缓解技术,并分别进行梳理,介绍分析代表性技术.这一篇分析现有的监控技术 ...

  5. OAuth2.0之OLTU实现举例

    一.场景 三个角色:用户(user),web应用(client),资源服务器和授权服务器合为服务器(server) 用户登录登录后可查看自己的信息 二.准备 2.1 数据库 schema drop t ...

  6. [持续更新] Python学习、使用过程中遇见的非代码层面知识(想不到更好的标题了 T_T)

    写在前面: 这篇博文记录的不是python代码.数据结构.算法相关的内容,而是在学习.使用过程中遇见的一些没有技术含量,但有时很令人抓耳挠腮的小东西.比如:python内置库怎么看.python搜索模 ...

  7. 技术管理进阶——空降Leader如何开展工作?

    原创不易,求分享.求一键三连 前几天有个粉丝咨询了一个的问题: 最近遇到一个空降Leader,挺苦恼的: 新Leader技术很厉害,但平时根本就不管我们,也不愿意了解业务,更像是一个技术顾问. 具体案 ...

  8. 从URL输入到页面展现到底发生什么?DNS 解析&TCP 连接

    DNS 解析:将域名解析成 IP 地址 TCP 连接:TCP 三次握手 发送 HTTP 请求 服务器处理请求并返回 HTTP 报文 浏览器解析渲染页面 断开连接:TCP 四次挥手 一.什么是URL? ...

  9. 用STM32玩SR04(测距、串口显示、OLED显示)

    目录 用STM32玩SR04(测距.串口显示.OLED显示) 超声波模块使用 SR04初始化 SR04使用串口打印数据 SR04使用OLED来传输数据,并显示在OLED上 用STM32玩SR04(测距 ...

  10. 【进阶】Spring中的注解与反射

    [进阶]Spring中的注解与反射 目录 [进阶]Spring中的注解与反射 前言 一.内置(常用)注解 1.1@Overrode 1.2@RequestMapping 1.3@RequestBody ...