首页
关于
Search
1
给你10个市场数据调研报告的免费下载网站!以后竞品数据就从这里找!
141 阅读
2
php接口优化 使用curl_multi_init批量请求
131 阅读
3
2024年备考系统架构设计师
102 阅读
4
《从菜鸟到大师之路 ElasticSearch 篇》
102 阅读
5
PHP 文件I/O
89 阅读
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
登录
Search
标签搜索
php函数
php语法
性能优化
安全
错误和异常处理
问题
vue
Composer
Session
缓存
框架
Swoole
api
并发
异步
正则表达式
php-fpm
mysql 索引
开发规范
协程
dafenqi
累计撰写
785
篇文章
累计收到
8
条评论
首页
栏目
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
副业
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
页面
关于
搜索到
785
篇与
的结果
2023-08-28
使用fscok实现异步调用PHP
使用fscok实现异步调用PHPWeb 服务器执行一个脚本,可能几毫秒就完成,也可能几分钟都完不成。如果程序执行缓慢,用户可能没有耐心等下去,就关闭浏览器了。 而有的时候,我们更本不关心这些耗时的脚本的执行结果,但却还要等他执行完返回,才能继续下一步。 那么有没有什么办法,只是简单的触发调用这些耗时的脚本然后就继续下一步,让这些耗时的脚本在服务端慢慢执行? 接下来,我将使用fscokopen来实现这一功能。 PHP是支持socket编程的,就是fsockopen, 在以前做CMS的时候,我也曾经用过它做过smtp发信。 fscokopen返回一个到远程主机连接的句柄。你可以像使用fopen返回的句柄一样,对她进行写fwrite,读取fgets, fread等操作。 我们的异步PHP,主要想要的效果就是,触发一个PHP脚本,然后立即返回,留它在服务器端慢慢执行。前面我也写过一篇文章讨论过这个问题。 那么,我们就可以使用fsockopen连接到本地服务器,触发脚本执行,然后立即返回,不等待脚本执行完成。 function triggerRequest($url, $post_data = array(), $cookie = array())...{ $method = "GET"; //可以通过POST或者GET传递一些参数给要触发的脚本 $url_array = parse_url($url); //获取URL信息,以便平凑HTTP HEADER $port = isset($url_array['port'])? $url_array['port'] : 80; $fp = fsockopen($url_array['host'], $port, $errno, $errstr, 30); if (!$fp) ...{ return FALSE; } $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 "; //HTTP 1.1 Host域不能省略 /**//*以下头信息域可以省略 $header .= "User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.13) Gecko/20080311 Firefox/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($cookie as $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_data as $k => $v)...{ $_post .= $k."=".$v."&"; } $post_str = "Content-Type: application/x-www-form-urlencoded\r\n";//POST数据 $post_str .= "Content-Length: ". strlen($_post) ." \r\n";//POST数据的长度 $post_str .= $_post."\r\n\r\n "; //传递POST数据 $header .= $post_str; } fwrite($fp, $header); //echo fread($fp, 1024); //我们不关心服务器返回 fclose($fp); return true; }现在,就可以通过这个函数来触发一个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_value ignore_user_abort”以及 ignore_user_abort() 函数来控制。如果没有告诉 PHP 忽略用户的中断,脚本将会被中断,除非通过 register_shutdown_function() 设置了关闭触发函数。通过该关闭触发函数,当远程用户点击 STOP 按钮后,脚本再次尝试输出数据时,PHP 将会检测到连接已被中断,并调用关闭触发函数。 脚本也有可能被内置的脚本计时器中断。默认的超时限制为 30 秒。这个值可以通过设置 php.ini 的 max_execution_time 或 Apache .conf 设置中对应的“php_value max_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(callback fuction[, parameters]);//注册脚本退出时执行的函数
2023年08月28日
9 阅读
0 评论
0 点赞
2023-08-28
汉字和Unicode码(utf-8)之间的转换(Pack/Unpack)
汉字和Unicode码(utf-8)之间的转换(Pack/Unpack)保证你要转换的字符串编码为UTF8,如果不是,请iconv cnStr成utf8$cnStr = "中"; //utf8的中文 //unicode $code = unpack("H6codes", $cnStr); //汉字 $cnStr = pack("H6", $code['codes']);恩, pack/unpack很强大,, 和c语言交换数据, 二进制方式的序列化,操作二进制文件.. etc...附上format参数的说明:a NUL-padded string, 即"\0"作为"空字符"的表示形式A SPACE-padded string, 空格作为"空字符"的表示形式h Hex string, low nibble first,升序位顺序H Hex string, high nibble first,降序位顺序c signed char, 有符号单字节C unsigned char, 无符号单字节s signed short (always 16 bit, machine byte order)S unsigned short (always 16 bit, machine byte order)n unsigned short (always 16 bit, big endian byte order)v unsigned short (always 16 bit, little endian byte order)i signed integer (machine dependent size and byte order)I unsigned integer (machine dependent size and byte order)l signed long (always 32 bit, machine byte order)L unsigned long (always 32 bit, machine byte order)N unsigned long (always 32 bit, big endian byte order)V unsigned long (always 32 bit, little endian byte order)f float (machine dependent size and representation)d double (machine dependent size and representation)x NUL byte, 实际使用的时候作为跳过多少字节用,很有用X Back up one byte, 后退1字节@ NUL-fill to absolute position,实际使用的时候作为从开头跳到某字节用.
2023年08月28日
5 阅读
0 评论
0 点赞
2023-08-28
PHP:Header
PHP:HeaderRFC2616有相关的所有的状态信息的说明, 就状态码,大体总结如下:1xx: Informational - Request received, continuing process2xx: Success - The action was successfully received, understood, and accepted3xx: Redirection - Further action must be taken in order to complete the request4xx: Client Error - The request contains bad syntax or cannot be fulfilled5xx: Server Error - The server failed to fulfill an apparently valid request状态码含义100Continue 继续101Switching Protocols 交换协议200OK 好的201Created 创建202Accepted 接受203Non-Authoritative Information 非授权信息204No Content 没有内容205Reset Content 重置内容206Partial Content 部分内容300Multiple Choices 多选301Moved Permanently 永久移动302Moved Temporarily 临时移动303See Other 看到其他304Not Modified 不修改305Use Proxy 使用代理400Bad Request 坏的请求401Unauthorized 未经授权的402Payment Required 付款要求403Forbidden 被禁止的404Not Found 没有找到405Method Not Allowed 不允许406Not Acceptable 不能接受的407Proxy Authentication Required 需要代理认证408Request Time-out 请求超时409Conflict 冲突410Gone 走了411Length Required 长度要求412Precondition Failed 失败的前提413Request Entity Too Large 请求实体太大414Request-URI Too Large 请求uri太大415Unsupported Media Type 不支持的媒体类型500Internal Server Error 服务器内部错误501Not Implemented 没有实现502Bad Gateway 坏的网关503Service Unavailable 服务不可用504Gateway Time-out 网关超时505HTTP Version not supported 不支持HTTP版本So, 举几个例子:header("HTTP/1.1 404 Not Found", true, 404); header("HTTP/1.0 401 Unauthorized"); header("Content-Type: text/html; charset=utf-8;"); header("Location:http://www.xxx.com");RFC2616 http://www.faqs.org/rfcs/rfc2616
2023年08月28日
11 阅读
0 评论
0 点赞
2023-08-28
深入Mysql字符集设置
深入Mysql字符集设置基本概念• 字符(Character)是指人类语言中最小的表义符号。例如'A'、'B'等;• 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encoding)。例如,我们给字符'A'赋予数值0,给字符'B'赋予数值1,则0就是字符'A'的编码;• 给定一系列字符并赋予对应的编码后,所有这些字符和编码对组成的集合就是字符集(Character Set)。例如,给定字符列表为{'A','B'}时,{'A'=>0, 'B'=>1}就是一个字符集;• 字符序(Collation)是指在同一字符集内字符之间的比较规则;• 确定字符序后,才能在一个字符集上定义什么是等价的字符,以及字符之间的大小关系;• 每个字符序唯一对应一种字符集,但一个字符集可以对应多种字符序,其中有一个是默认字符序(Default Collation);• MySQL中的字符序名称遵从命名惯例:以字符序对应的字符集名称开头;以_ci(表示大小写不敏感)、_cs(表示大小写敏感)或_bin(表示按编码值比较)结尾。例如:在字符序utf8_general_ci''下,字符a''和``A''是等价的;MySQL字符集设置• 系统变量:– character_set_server:默认的内部操作字符集– character_set_client:客户端来源数据使用的字符集– character_set_connection:连接层字符集– character_set_results:查询结果字符集– character_set_database:当前选中数据库的默认字符集– character_set_system:系统元数据(字段名等)字符集– 还有以collation_开头的同上面对应的变量,用来描述字符序。• 用introducer指定文本字符串的字符集:– 格式为:[_charset] 'string' [COLLATE collation]– 例如:• SELECT _latin1 'string';• SELECT _utf8 '你好' COLLATE utf8_general_ci;– 由introducer修饰的文本字符串在请求过程中不经过多余的转码,直接转换为内部字符集处理。MySQL中的字符集转换过程MySQL Server收到请求时将请求数据从character_set_client转换为character_set_connection;进行内部操作前将请求数据从character_set_connection转换为内部操作字符集,其确定方法如下:• 使用每个数据字段的CHARACTER SET设定值;• 若上述值不存在,则使用对应数据表的DEFAULT CHARACTER SET设定值(MySQL扩展,非SQL标准);• 若上述值不存在,则使用对应数据库的DEFAULT CHARACTER SET设定值;• 若上述值不存在,则使用character_set_server设定值。将操作结果从内部操作字符集转换为character_set_results。图片1常见问题解析• 向默认字符集为utf8的数据表插入utf8编码的数据前没有设置连接字符集,查询时设置连接字符集为utf8– 插入时根据MySQL服务器的默认设置,character_set_client、character_set_connection和character_set_results均为latin1;– 插入操作的数据将经过latin1=>latin1=>utf8的字符集转换过程,这一过程中每个插入的汉字都会从原始的3个字节变成6个字节保存;– 查询时的结果将经过utf8=>utf8的字符集转换过程,将保存的6个字节原封不动返回,产生乱码……图片2• 向默认字符集为latin1的数据表插入utf8编码的数据前设置了连接字符集为utf8– 插入时根据连接字符集设置,character_set_client、character_set_connection和character_set_results均为utf8;– 插入数据将经过utf8=>utf8=>latin1的字符集转换,若原始数据中含有\u0000~\u00ff范围以外的Unicode字 符,会因为无法在latin1字符集中表示而被转换为“?”(0x3F)符号,以后查询时不管连接字符集设置如何都无法恢复其内容了。图片3检测字符集问题的一些手段• SHOW CHARACTER SET;• SHOW COLLATION;• SHOW VARIABLES LIKE 'character%';• SHOW VARIABLES LIKE 'collation%';• SQL函数HEX、LENGTH、CHAR_LENGTH• SQL函数CHARSET、COLLATION使用MySQL字符集时的建议• 建立数据库/表和进行数据库操作时尽量显式指出使用的字符集,而不是依赖于MySQL的默认设置,否则MySQL升级时可能带来很大困扰;• 数据库和连接字符集都使用latin1时虽然大部分情况下都可以解决乱码问题,但缺点是无法以字符为单位来进行SQL操作,一般情况下将数据库和连接字符集都置为utf8是较好的选择;• 使用mysql C API时,初始化数据库句柄后马上用mysql_options设定MYSQL_SET_CHARSET_NAME属性为utf8,这样就不用显式地用 SET NAMES语句指定连接字符集,且用mysql_ping重连断开的长连接时也会把连接字符集重置为utf8;• 对于mysql PHP API,一般页面级的PHP程序总运行时间较短,在连接到数据库以后显式用SET NAMES语句设置一次连接字符集即可;但当使用长连接时,请注意保持连接通畅并在断开重连后用SET NAMES语句显式重置连接字符集。其他注意事项• my.cnf中的default_character_set设置只影响mysql命令连接服务器时的连接字符集,不会对使用libmysqlclient库的应用程序产生任何作用!• 对字段进行的SQL函数操作通常都是以内部操作字符集进行的,不受连接字符集设置的影响。• SQL语句中的裸字符串会受到连接字符集或introducer设置的影响,对于比较之类的操作可能产生完全不同的结果,需要小心!
2023年08月28日
13 阅读
0 评论
0 点赞
2023-08-28
var_export 与 var_dump的不同
var_export 与 var_dump的不同var_export 必须返回合法的php代码, 也就是说,var_export返回的代码,可以直接当作php代码赋值个一个变量。 而这个变量就会取得和被var_export一样的类型的值 但是, 当变量类型为resource的时候, 是无法简单copy复制的,所以, 当var_export的变量是resource类型时, var_export会返回NULL 实例$res = yblog_mspconfiginit("ratings"); var_dump($res); var_export($res);结果:resource(1) of type (yahoo_yblog) NULL再比如:$res = fopen('status.html', 'r'); var_dump($res); var_export($res);结果:resource(2) of type (stream) NULL
2023年08月28日
7 阅读
0 评论
0 点赞
1
...
71
72
73
...
157