为了解决跨域问题,jsonp技术应运而生。下面我们来详细了解jsonp在前端数据获取中的应用。
一、jsonp原理
jsonp(json with padding)是一种跨域数据传输方式,它是通过动态添加script标签来进行跨域数据请求并获取json数据的。jsonp在前端使用中的原理如下:
首先,前端向服务端发起一个jsonp请求,请求地址为跨域地址。jsonp请求的url中需要包含一个callback参数,后端根据该参数生成响应的json数据,并以函数调用的形式返回给前端,前端再将响应的数据解析处理。
具体的流程如下图所示:
二、服务端响应jsonp请求
当前端发起jsonp请求,服务端需要正确的响应请求。对于jsonp请求,服务端需要返回一个指定名称的javascript函数,并在函数调用时调用服务端生成的json数据。下面是一个jsonp响应的实例:
总结一下,服务端需要实现以下几点:
接收前端请求,根据callback参数生成json数据;将json数据作为参数传递给指定名字的javascript函数;将整个响应写入http响应体。三、前端处理jsonp响应
当服务端正确响应jsonp请求后,前端需要正确处理响应数据。前端需要做的事情如下:
根据callback参数指定的函数名称,创建同名的函数;取回响应的json数据,将json数据作为参数传递给前面创建的同名函数。下面是一个jsonp处理的实例:
最后,我们需要注意的一点是,在进行jsonp请求时,由于响应的数据会以javascript的形式返回,如果返回的数据中包含了javascript语句,则需要进行转义处理,否则会影响前端代码的执行。常见的转义函数有jquery的$.parsejson()函数和javascript的json.parse()函数。
to be continued...
以上就是php jsonp 转化json数据的详细内容。
