JSONP-愉快解决跨域接口请求

平时我们在浏览器中请求不同域名的接口数据的时候,通常浏览器会在控制台报一个跨域异常,提示拒绝访问。这是因为受到了同源策略的影响。

同源策略是什么

同源策略是浏览器最核心也是最基本的安全功能,同源指的是两条URL在协议、域名和端口上都是相同的,一旦有其中一个条件是不同的,两者就是不同源。

同源保证了两个同源的URL之间在浏览器上是可以相互访问资源和可以操作DOM的,不同源URL在浏览器上互相访问的时候,浏览器就会判断到不同源,就会出来制裁,拒绝访问。

注意同源策源就只是浏览器行为,两个不同服务器接口互相访问,还是可以正常响应的。

同源策略作用的地方

同源策略主要作用在DOM、Web数据和网络三个层面上。

  1. DOM层面:
    同源策略限制了来自不同源的JavaScript脚本对不同源页面的DOM对象读和写操作。
  2. Web数据层面:
    同源策源限制了不同源的JavaScript脚本读取对不同源页面的Cookie、LocalStorage等数据。
  3. 网络层面:
    同源策略限制了通过XMLHttpRequest、Fetch API等方式将不同源的接口数据获取回来。

回到文章的开头内容,我们在浏览器上请求不同域名的接口数据的时候,就是主要被限制在网络层面的XMLHttpRequest(简称XHR)上,目前所有的现代浏览器都内置了一个XHR对象,这个对象可以在页面加载后从服务器上请求以及获取数据,而不会影响页面的正常行为。XHR在AJAX异步编程上是很关键的功能点。

我们该如何解决跨域问题呢?一般我们都是设置CORS跨域资源共享,来打破同源策略的限制,实现web页面成功访问不同源的接口数据。另外就是使用JSONP的方式来是实现跨域请求。

两者在对比上,CORS支持所有类型的HTTP请求,而JSONP只支持GET请求,显然CORS是更为强大的,不过JSONP的优势在于支持老式浏览器,还可以向不支持CORS的网站请求数据。下面我们将重点研究JSONP。

JSONP是什么

JSONP即JSON with Padding,看上去和JSON很像,其实他就是JSON的一种使用模式,可用于解决现代浏览器的跨域数据访问的问题。非常聪明的程序员发现HTML页面的Script标签是没有跨域限制的,可以从其他不同源的网站获取JSON数据,而这种方式就是JSONP,是一种非官方的跨域方式。

用JSONP获取的数据也并不是JSON对象,而是任意的JavaScript对象,用JavaScript直译器执行而不是用JSON解析器解析。具体理解看以下的JSONP工作原理

JSONP工作原理

通过在页面创建script标签,里面的具体内容是注册一个函数名为随机生成的callback值在客户端,然后将一个callback参数名以及随机生成的值拼接在接口的URL后面,将其最终请求的URL放进src属性,接着插入到head标签里面等待执行。

执行的时候,参数将传送给服务器的接口,接口响应会生成JSON数据,然后以JavaScript 语法的方式,生成一个 function函数,函数名就是入参callback的值。最后将JSON数据以入参的方式,放置到函数中,这样就生成了一段 JavaScript 语法的代码返回给了客户端。

浏览器上的客户端,script标签对返回的函数动态解析,将返回的函数入参数据传入到了预先注册好的callback函数里面,此时就获取到想到获取的数据了,在函数里面做具体的操作了。

JSONP具体实现

JSONP在前端目前的实现方式有两种,一种是通过纯js代码实现,另一种是JQuery实现,下面演示JQuery版本。

前端代码:

$.ajax({
    type: "get",
    async: false,
    url: "http://xxx.com/demo",
    dataType: "jsonp",
    jsonp: "callback", //默认的请求参数名
    jsonpCallback:"abc", //命令jsonp回调函数名称,也可写成问号让名称随机生成
    success: function(json){
    alert('您看到的数据为: ' + json);
    },
    error: function(){
    alert('请求出错');
    }
});

服务器Java代码:

@GetMapping("/demo")
public String getData(String callback){    
    if( callback == null ){        
        throw new RuntimeException("callback值不能为空");    
    }    
    return new StringBuilder(callback).append("(").append("关注微信公众号:红橙呀").append(")").toString();
}

通过JSONP的方式,我们下次遇到跨域问题,也可以使用它实现愉快的跨域请求,早点下班了~

更多Java后端开发干货,可以关注公众号「 红橙呀 」。
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要解决vue-pdf的跨域问题,可以采取以下几种方法: 1. 使用代理服务器:可以在vue.config.js中配置代理服务器,将跨域请求发送到代理服务器上,再由代理服务器去请求pdf文件。这样可以避免直接在前端发起跨域请求,从而解决跨域问题。 2. 设置响应头:在后端服务器中设置Access-Control-Allow-Origin头,允许前端的请求跨域访问。可以设置"*"表示允许所有域名的跨域请求,也可以指定具体的域名。 3. 使用后端接口:将pdf文件存储在后端服务器上,然后通过后端接口请求pdf文件并返回给前端。这样可以避免直接在前端发起跨域请求。 4. JSONP方式请求:如果后端支持JSONP方式,可以在前端使用JSONP方式去请求pdf文件。JSONP通过动态创建<script>标签实现跨域请求,并且服务器返回的是一段可执行的JavaScript代码。 以上是几种常用的解决vue-pdf跨域问题的方法,具体选择哪种方法取决于项目需求和后端支持情况。 ### 回答2: Vue-pdf是一个用于在Vue项目中显示PDF的插件。在某些情况下,可能会遇到跨域问题,即无法加载外部PDF文件。以下是解决跨域问题的方法: 1. 在Vue项目的配置文件vue.config.js中添加webpack配置。找到configureWebpack选项,添加以下代码: ``` module.exports = { configureWebpack: { devServer: { headers: { "Access-Control-Allow-Origin": "*" } } } } ``` 这将设置允许所有域名访问该服务。请注意,这样做可能会在生产环境中引起安全风险,仅在开发环境中使用。 2. 使用一个代理服务器来代理PDF文件的请求。在vue.config.js中添加以下代码: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://example.com', changeOrigin: true, pathRewrite: { '^/api': '' } } } } } ``` 这将把以/api开头的请求转发到http://example.com上。确保将http://example.com替换为实际的PDF文件所在的服务器地址。 3. 将PDF文件转换为base64编码格式,然后通过URL.createObjectURL方法将其作为Blob对象传递给vue-pdf。可以使用axios或其他网络请求库来获取PDF文件,并使用FileReader将其转换为base64编码。 以上方法中的任何一种都可以解决跨域问题,需要根据具体情况选择适合的方法。 ### 回答3: 要解决Vue-PDF的跨域问题,可以通过设置服务器代理、使用nginx来解决。下面将详细介绍两种方法: 1. 设置服务器代理: 如果Vue项目是使用vue-cli创建的,并且项目使用的是webpack-dev-server作为开发服务器,可以在项目的根目录下创建vue.config.js文件,并在其中添加以下内容: ```javascript module.exports = { devServer: { proxy: { '/api': { // 将/api替换为实际的API请求前缀 target: 'http://example.com', // 设置实际接口的域名 changeOrigin: true, // 允许跨域 secure: false // 关闭SSL验证 } } } } ``` 其中,`/api`是你实际的API请求前缀,`http://example.com`是实际接口的域名。这样,当你在Vue组件中发起API请求时,会自动将请求代理到指定的域名,解决跨域问题。 2. 使用nginx: 如果项目部署在nginx服务器上,可以通过配置nginx来解决跨域问题。首先,打开nginx的配置文件,在`http`块中添加以下内容: ```nginx location /api/ { rewrite ^.+api/?(.*)$ /$1 break; proxy_pass http://example.com/; // 将example.com替换为实际的接口域名 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } ``` 在上述配置中,`/api/`是你实际的API请求前缀,`http://example.com/`是实际接口的域名。这样,当你在Vue组件中发起API请求时,nginx会将请求代理到指定的域名,解决跨域问题。 无论是使用服务器代理还是nginx,都可以解决Vue-PDF的跨域问题。根据具体情况选择适合自己项目的方法即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值