首页 > 后端开发 > 正文

php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery

2023-09-14 04:23:19 | 我爱编程网

今天,我爱编程网小编为关注后端开发的同学们准备了php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery,下面一起来看一下吧。

php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery

如何使用fsockopen函数实现异步执行PHP

Web服务器执行一个PHP脚本,有时耗时很长才能返回执行结果,后面的脚本需要等待很长一段时间才能继续执行。如果想实现只简单触发耗时脚本的执行而不等待执行结果就直接执行下一步操作,可以通过fscokopen函数来实现。
PHP支持socket编程,fscokopen函数返回一个到远程主机连接的句柄,可以像使用fopen返回的句柄一样,对它进行fwrite、fgets、fread等操作。使用fsockopen连接到本地服务器,触发脚本执行,然后立即返回,不等待脚本执行完成,即可实现异步执行PHP的效果。
示例代码如下:
functiontriggerRequest($url,$post_data=array(),$cookie=array()){
$method="GET";//通过POST或者GET传递一些参数给要触发的脚本
$url_array=parse_url($url);//获取URL信息
$port=isset($url_array['port'])?$url_array['port']:80;
$fp=fsockopen($url_array['host'],$port,$errno,$errstr,30);
if(!$fp){
returnFALSE;
}
$getPath=$url_array['path']."?".$url_array['query'];
if(!empty($post_data)){
$method="POST";
}
$header=$method."".$getPath;
$header.="HTTP/1.1\r\n";
$header.="Host:".$url_array['host']."\r\n";//HTTP1.1Host域不能省略
/*以下头信息域可以省略
$header.="User-Agent:Mozilla/5.0(Windows;U;
WindowsNT5.1;en-US;rv:1.8.1.13)Gecko/20080311Firefox/2.0.0.13\r\n";
$header.="Accept:text/xml,application/xml,application/
xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,q=0.5\r\n";
$header.="Accept-Language:en-us,en;q=0.5";
$header.="Accept-Encoding:gzip,deflate\r\n";
*/
$header.="Connection:Close\r\n";
if(!empty($cookie)){
$_cookie=strval(NULL);
foreach($cookieas$k=>$v){
$_cookie.=$k."=".$v.";";
}
$cookie_str="Cookie:".base64_encode($_cookie)."\r\n";//传递Cookie
$header.=$cookie_str;
}
if(!empty($post_data)){
$_post=strval(NULL);
foreach($post_dataas$k=>$v){
$_post.=$k."=".$v."&";
}
$post_str="Content-Type:application/x-www-form-urlencoded\r\n";
$post_str.="Content-Length:".strlen($_post)."\r\n";//POST数据的长度
$post_str.=$_post."\r\n\r\n";//传递POST数据
$header.=$post_str;
}
fwrite($fp,$header);
//echofread($fp,1024);//服务器返回
fclose($fp);
returntrue;
}
这样就可以通过fsockopen()函数来触发一个PHP脚本的执行,然后函数就会返回。接着执行下一步操作了。
现在存在一个问题:当客户端断开连接后,也就是triggerRequest发送请求后,立即关闭了连接,那么可能会引起服务器端正在执行的脚本退出。
在PHP内部,系统维护着连接状态,其状态有三种可能的情况:
*0–NORMAL(正常)
*1–ABORTED(异常退出)
*2–TIMEOUT(超时)
当PHP脚本正常地运行NORMAL状态时,连接为有效。当客户端中断连接时,ABORTED状态的标记将会被打开。远程客户端连接的中断通常是由用户点击STOP按钮导致的。当连接时间超过PHP的时限(参阅set_time_limit()函数)时,TIMEOUT状态的标记将被打开。
可以决定脚本是否需要在客户端中断连接时退出。有时候让脚本完整地运行会带来很多方便,即使没有远程浏览器接受脚本的输出。默认的情况是当远程客户端连接中断时脚本将会退出。该处理过程可由php.ini的ignore_user_abort或由Apache.conf设置中对应的"php_valueignore_user_abort"以及ignore_user_abort()函数来控制。如果没有告诉PHP忽略用户的中断,脚本将会被中断,除非通过register_shutdown_function()设置了关闭触发函数。通过该关闭触发函数,当远程用户点击STOP按钮后,脚本再次尝试输出数据时,PHP将会检测到连接已被中断,并调用关闭触发函数。
脚本也有可能被内置的脚本计时器中断。默认的超时限制为30秒。这个值可以通过设置php.ini的max_execution_time或Apache.conf设置中对应的"php_valuemax_execution_time"参数或者set_time_limit()函数来更改。当计数器超时的时候,脚本将会类似于以上连接中断的情况退出,先前被注册过的关闭触发函数也将在这时被执行。在该关闭触发函数中,可以通过调用connection_status()函数来检查超时是否导致关闭触发函数被调用。如果超时导致了关闭触发函数的调用,该函数将返回2。
需要注意的一点是ABORTED和TIMEOUT状态可以同时有效。这在告诉PHP忽略用户的退出操作时是可能的。PHP将仍然注意用户已经中断了连接但脚本仍然在运行的情况。如果到了运行的时间限制,脚本将被退出,设置过的关闭触发函数也将被执行。在这时会发现函数connection_status()返回3。
所以还在要触发的脚本中指明:
ignore_user_abort(TRUE);//如果客户端断开连接,不会引起脚本abort
set_time_limit(0);//取消脚本执行延时上限
或使用:
register_shutdown_function(callbackfuction[,parameters]);//注册脚本退出时执行的函数

php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery我爱编程网

PHP如何实现异步加载


PHP实现异步加载的方法:首先获取浏览器可视区域页面的高度;然后构造一个公式,计算相对比例;接着使用jQuery的getJSON方法,向服务端result.php发送请求;最后解析JSON数据即可。
推荐:《PHP视频教程》
php异步加载数据
无刷新功能我们用到很多很多的,下面我就来给各位介绍一个实例,就是实现php+ajax实现无刷新滚屏加载数据,例子非常的简单大家只要按流程来操作就可以了哦。
方法
首先,我们要获取浏览器可视区域页面的高度
然后,当滚动页面的时候需要做的事情是:计算页面总高度(当滚动底部时,页面新加载数据,所以页面总高度是动态变化的),计算滚动条位置(滚动条位置也是随着加载页面的高度动态变化的),然后构造一个公式,计算相对比例
当滚动条接近页底时,触发ajax加载,在本例中我们使用jQuery的getJSON方法,向服务端result.php发送请求,请求的参数为page,即页数
如果请求响应成功返回JSON数据,则解析JSON数据,并将数据追加到页面DIV#container后,如果没有JSON数据返回,则说明数据全部显示完毕
完整的jQuery代码如下
result.php
当滚动到页面底部时,前端Ajax请求到result.php,该后台程序将根据请求的数据页数:page,查询数据表中对应的记录,并将记录集以json的格式输出返回给前端处理
好了,本文的介绍到此结束,快去看看效果吧。

php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery

如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery


ECharts地图主要用于地理区域数据的可视化,展示不同区域的数据分布信息。ECharts官网提供了中国地图、世界地图等地图数据下载,通过js引入或异步加载json文件的形式调用地图。



效果演示 源码下载

本文将结合实例讲解如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据,我们以中国地图为例,展示去年(2015年)我国各省份GDP数据。通过异步请求php,读取mysql中的数据,然后展示在地图上,因此本文除了你掌握前端知识外,还需要你了解PHP以及MySQL方面的相关知识。

HTML

首先在页面中需要加载地图的位置放上div#myChart。


然后是加载Echarts和中国地图js文件。由于本文实例中应用了异步ajax加载数据,所以需要加载jQuery库文件。



Javascript

接下来js部分,先设置好Echarts选项内容,请看以下代码及注释。

然后我们使用jQuery的Ajax()来异步请求数据。

很显然,我们看到通过jQuery的$.ajax()向mapdata.php发送了一个post请求,要求返回json格式的数据,当请求成功并得到回应时,重新渲染地图数据。

PHP

mapdata.php的任务是读取mysql数据表中的数据,然后返回给前端。首先是要连接数据库,这部分代码在connect.php中,请下载源码查看。然后就是sql查询,读取表echarts_map中的数据,最后以json格式返回。


输出json格式数据
MySQL

最后提供mysql数据表结构信息,数据信息可以下载源码后,将sql导入你的mysql中即可,注意演示时修改connect.php的数据库配置信息。

CREATE TABLE IF NOT EXISTS `echarts_map` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`province` varchar(30) NOT NULL,
`gdp` decimal(10,2) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

以上就是我爱编程网小编为大家带来的php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery,希望对大家有帮助,了解更多相关资讯请关注我爱编程网。
与“php异步框架编程 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jquery”相关推荐
php异步请求框架 PHP如何实现异步加载
php异步请求框架 PHP如何实现异步加载

php每秒5000个并发请求接口怎么写要实现每秒5000个并发请求接口,可以结合以下几种方案:1.多进程或多线程:使用PHP的pcntl、pthreads等扩展库,创建多个进程或线程,每个进程或线程负责处理一部分请求。2.异步IO:使用Swoole、ReactPHP等异步IO的框架,通过异步非阻塞IO的方式,能够让一个进程或线程处理多个请求,从而提高请求的处理能力。3.负载

2023-09-07 03:17:52
php框架异步调节 PHP如何实现异步加载
php框架异步调节 PHP如何实现异步加载

PHP如何实现异步加载PHP实现异步加载的方法:首先获取浏览器可视区域页面的高度;然后构造一个公式,计算相对比例;接着使用jQuery的getJSON方法,向服务端result.php发送请求;最后解析JSON数据即可。推荐:《PHP视频教程》php异步加载数据无刷新功能我们用到很多很多的,下面我就来给各位介绍一个实例,就是实现php+ajax实现无刷新滚屏加载数据,例子非常的

2023-09-19 06:26:55
php框架异步怎么设置 PHP如何实现异步加载
php框架异步怎么设置 PHP如何实现异步加载

PHP如何实现异步加载PHP实现异步加载的方法:首先获取浏览器可视区域页面的高度;然后构造一个公式,计算相对比例;接着使用jQuery的getJSON方法,向服务端result.php发送请求;最后解析JSON数据即可。推荐:《PHP视频教程》php异步加载数据无刷新功能我们用到很多很多的,下面我就来给各位介绍一个实例,就是实现php+ajax实现无刷新滚屏加载数据,例子非常的

2023-09-23 22:43:26
php框架实现的自动加载 PHP如何实现异步加载
php框架实现的自动加载 PHP如何实现异步加载

我想尝试着写个小型PHP框架,现在卡在类自动加载和路由实现上了类自动加载跟路由是框架最基础的特性给你点自动加载的思路,首先现在写框架必须用上命名空间,框架内部的类文件夹根据命名空间命名方便自动加载在入口文件引入自己写的Autoload.php通过spl_autoload_register获得要加载的类名spl_autoload_register(function ($cla

2023-09-29 22:02:31
php框架异步调用 如何使用fsockopen函数实现异步执行PHP
php框架异步调用 如何使用fsockopen函数实现异步执行PHP

如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)_jqueryECharts地图主要用于地理区域数据的可视化,展示不同区域的数据分布信息。ECharts官网提供了中国地图、世界地图等地图数据下载,通过js引入或异步加载json文件的形式调用地图。效果演示源码下载本文将结合实例讲解如何使用PHP+jQuery+MySQL实现异步加载EC

2023-09-17 21:08:05
异步服务器框架php php的CI框架如何实现异步调用?
异步服务器框架php php的CI框架如何实现异步调用?

PHP如何实现异步加载PHP实现异步加载的方法:首先获取浏览器可视区域页面的高度;然后构造一个公式,计算相对比例;接着使用jQuery的getJSON方法,向服务端result.php发送请求;最后解析JSON数据即可。推荐:《PHP视频教程》php异步加载数据无刷新功能我们用到很多很多的,下面我就来给各位介绍一个实例,就是实现php+ajax实现无刷新滚屏加载数据,例子非常的

2023-08-28 08:15:02
swoole与php异步框架 PHP如何连接swoole
swoole与php异步框架 PHP如何连接swoole

php为什么要使用swoole首先我们要知道Swoole是一个网络应用的开发工具,它支持Http、TCP、UDP、WebSocket。使用理由如下:1、常驻内存,避免重复加载带来的性能损耗,提升海量性能。2、协程异步,提高对I/O密集型场景并发处理能力(如:微信开发、支付、登录等)。3、方便地开发Http、WebSocket、TCP、UDP等应用,可以与硬件通信。4、

2023-09-16 22:31:32
PHP异步框架选择 php为什么要使用swoole
PHP异步框架选择 php为什么要使用swoole

php为什么要使用swoole首先我们要知道Swoole是一个网络应用的开发工具,它支持Http、TCP、UDP、WebSocket。使用理由如下:1、常驻内存,避免重复加载带来的性能损耗,提升海量性能。2、协程异步,提高对I/O密集型场景并发处理能力(如:微信开发、支付、登录等)。3、方便地开发Http、WebSocket、TCP、UDP等应用,可以与硬件通信。4、

2023-09-07 02:25:27