- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试异步运行脚本。在 Stackoverflow 上找到如何做到这一点没有问题。问题是我正在尝试我发现的示例之一,但它不起作用。尽管脚本运行时不会在 error_log 中输出错误。
我的 main-php 脚本:
function backgroundPost($url){
$parts=parse_url($url);
$fp = fsockopen($parts['host'],
isset($parts['port'])?$parts['port']:80,
$errno, $errstr, 30);
if (!$fp) {
return false;
} else {
$out = "POST ".$parts['path']." HTTP/1.1\r\n";
$out.= "Host: ".$parts['host']."\r\n";
$out.= "Content-Type: text/plain\r\n";
$out.= "Content-Length: ".strlen($parts['query'])."\r\n";
$out.= "Content-Length: ".strlen($parts['query'])."\r\n";
$out.= "Connection: Close\r\n\r\n";
if (isset($parts['query'])) $out.= $parts['query'];
fwrite($fp, $out);
fclose($fp);
return true;
}
}
//Example of use
backgroundPost('http://192.168.1.107/smic/testarea/runner.php?id=1');
fwrite() 的响应是“155”。
backgroundPost 返回“真”。
runner.php:
ignore_user_abort(true);
set_time_limit(50);
error_log("RUNNING!");
怎么会出现“RUNNING!注释写入错误日志?就像 scipt 没有实际执行一样。
当直接访问 runner.php(使用在 backgroundPost 中发布的 URL)时,脚本按预期工作。
这两个脚本都具有 apache:apache 的权限 777。
正在运行
这是否与我使用的是经过身份验证的 session 有关,而经过身份验证的用户当然不是运行脚本的 apache?
使用 CURL 进行测试
@jprofitt 建议我也尝试了 curl:
async_curl.php:
$ch = curl_init("http://192.168.1.107/");
$fp = fopen("http://192.168.1.107/smic/testarea/runner.php", "r");
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC ) ;
curl_setopt($ch, CURLOPT_USERPWD, "kaand:xIWGWt0DNVriw");
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_exec($ch);
$info = curl_getinfo($ch);
echo print_r($info);
curl_close($ch);
fclose($fp);
这是从 curl_getinfo($ch) 打印出来的:
Array
(
[url] => http://192.168.1.107/
[content_type] => text/html; charset=UTF-8
[http_code] => 302
[header_size] => 411
[request_size] => 103
[filetime] => -1
[ssl_verify_result] => 0
[redirect_count] => 0
[total_time] => 0.002165
[namelookup_time] => 0.000106
[connect_time] => 0.000192
[pretransfer_time] => 0.000211
[size_upload] => 0
[size_download] => 0
[speed_download] => 0
[speed_upload] => 0
[download_content_length] => 0
[upload_content_length] => 0
[starttransfer_time] => 0.002109
[redirect_time] => 0
[certinfo] => Array
(
)
[redirect_url] => http://192.168.1.107/login.php
)
1
我确实尝试过 $ch = curl_init("http://192.168.1.107/");同样,然后我在我的网站上收到消息“需要授权”。在 error_log 中,我得到 HTTP/1.1 401 Authorization required for running.php。
在执行“curl_setopt($ch, CURLOPT_FILE, $fp);”时,我也确实在 error_log 中收到有关 $fp“不是有效的文件句柄资源”的投诉。
在数组的末尾有一个重新定向到登录页面,这可能与那个问题有关吗?
最佳答案
因此,我遇到的问题与 runner.php 的限制区域有关。无论我使用 curl 还是 fsockopen,我都需要对请求进行身份验证。这里我包含fsockopen和curl对限制区域做异步请求的解决方案。
fsockopen:
function backgroundPost($url){
$parts=parse_url($url);
echo $parts['path']."<br/>";
echo $parts['host']."<br/>";
echo $url;
$fp = fsockopen($parts['host'],
isset($parts['port'])?$parts['port']:80,
$errno, $errstr, 10);
$auth = base64_encode("kaand:kaand123");
if (!$fp) {
return false;
} else {
$out = "POST ".$parts['path']." HTTP/1.1\r\n";
$out.= "Host: ".$parts['host']."\r\n";
$out.= "User-Agent: Anonymous\r\n";
$out.= "Content-Type: text/plain\r\n";
$out.= "Authorization: Basic ".$auth;
$out.= "Content-Length: ".strlen($parts['query'])."\r\n";
$out.= "Connection: Close\r\n\r\n";
if (isset($parts['query'])) $out.= $parts['query'];
fwrite($fp, $out);
fclose($fp);
return true;
}
}
使用示例:
backgroundPost('http://192.168.1.107/smic/testarea/runner.php?id=1');
curl :
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "http://192.168.1.107/smic/testarea/runner.php");
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC ) ;
curl_setopt($ch, CURLOPT_USERPWD, "kaand:kaand123"); //Don't use the sha1-value
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_exec($ch);
curl_close($ch);
runner.php
do whatever...
我想我会选择 fsockopen,认为这是一个比强制您至少有一些等待时间的超时更好的解决方案。如果有很多流量甚至 1 秒就可以建立...
关于php - 异步执行 php-script 正在使用经过身份验证的 session ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9735874/
我正在使用SQL Server 2008 R2,并且想创建一个触发器。 对于每个添加(仅添加),将像这样更新一列: ABC-CurrentYear-AutoIncrementCode 例子: ABC-
是否可以在显示最终一致性的数据存储中创建/存储用户帐户? 似乎不可能在没有一堆架构复杂性的情况下管理帐户创建,以避免可能发生具有相同 UID(例如电子邮件地址)的两个帐户的情况? 最终一致性存储的用户
您好, 我有一个带有 Identity 的 .NetCore MVC APP并使用 this指导我能够创建自定义用户验证器。 public class UserDomainValidator : IU
这与以下问题相同:HiLo or identity? 我们以本站的数据库为例。 假设该站点具有以下表格: 帖子。 投票。 注释。 使用它的最佳策略是什么: 身份 - 这是更常见的。 或者 HiLo -
我想将 Blazor Server 与 ASP.NET Identity 一起使用。但我需要使用 PostgreSQL 作为用户/角色存储,因为它在 AWS 中。 它不使用 EF,这是我需要的。 我创
我正在开发一个 .NET 应用程序,它可以使用 Graph API 代表用户发送电子邮件。 提示用户对应用程序进行授权;然后使用获取的访问 token 来调用 Graph API。刷新 token 用
我使用 ASP.NET 身份和 ClaimsIdentity 来验证我的用户。当用户通过身份验证时,属性 User.Identity 包含一个 ClaimsIdentity 实例。 但是,在登录请求期
所以我在两台机器上都安装了 CYGWIN。 如果我这样做,它会起作用: ssh -i desktop_rsa root@remoteserver 这需要我输入密码 ssh root@remoteser
我尝试在 mac osx 上的终端中通过 telnet 连接到 TOR 并请求新身份,但它不起作用,我总是收到此错误消息: Trying 127.0.0.1... telnet: connect to
我正在开发一个 .NET 应用程序,它可以使用 Graph API 代表用户发送电子邮件。 提示用户对应用程序进行授权;然后使用获取的访问 token 来调用 Graph API。刷新 token 用
我正在开发一项服务,客户可以在其中注册他们的 webhook URL,我将发送有关已注册 URL 的更新。为了安全起见,我想让客户端(接收方)识别是我(服务器)向他们发送请求。 Facebook和 G
在 Haskell 中,有没有办法测试两个 IORef 是否相同?我正在寻找这样的东西: IORef a -> IORef a -> IO Bool 例如,如果您想可视化由 IORef 组成的图形,这
我是 .NET、MVC 和身份框架的新手。我注意到身份框架允许通过注释保护单个 Controller 操作。 [Authorize] public ActionResult Edit(int? Id)
我有一列具有身份的列,其计数为19546542,我想在删除所有数据后将其重置。我需要类似ms sql中的'dbcc checkident'这样的内容,但在Oracle中 最佳答案 在Oracle 12
这是我用来创建 session 以发送电子邮件的代码: props.put("mail.smtp.auth", "true"); props.put("mail.smtp.starttls.enabl
我想了解 [AllowAnonymous] 标签的工作原理。 我有以下方法 [HttpGet] public ActionResult Add() { return View(); } 当我没
在使用沙盒测试环境时,PayPal 身份 token 对某些人显示而不对其他人显示的原因是否有任何原因。 我在英国使用 API,终生无法生成或找到 token 。 我已经遵循协议(protocol)并
我对非常简单的事情有一些疑问:IDENTITY。我尝试在 phpMyAdmin 中创建表: CREATE TABLE IF NOT EXISTS typEventu ( typEventu
习语 #1 和 #5 是 FinnAPL Idiom Library两者具有相同的名称:“Progressive index of (without replacement)”: ((⍴X)⍴⍋⍋X⍳
当我第一次在 TFS 中设置时,我的公司拼错了我的用户名。此后他们将其更改为正确的拼写,但该更改显然未反射(reflect)在 TFS 中。当我尝试 checkin 更改时,出现此错误: 有没有一种方
我是一名优秀的程序员,十分优秀!