以前写的计划任务程序,发现有时和预期结果不同
URL Path 函数 Windows 服务器
<?phperror_reporting(E_ALL);ini_set('display_errors', '1');ignore_user_abort(true);header("Content-Type: text/html;charset=utf-8");date_default_timezone_set("PRC");class runjob{ static $myselftime = 50; static $url = "http://127.0.0.1/to.php?pwd=123456789"; static $myself = "http://127.0.0.1/autorun.php"; static $urltime_H = 18; static $urltime_i = 00; function __construct() { if (!file_exists("runtime.txt")) { $fp = fopen("runtime.txt","w"); fwrite($fp,""); fclose($fp); } if (!file_exists("time.txt")) { $fp = fopen("time.txt","w"); fwrite($fp,""); fclose($fp); } if (file_exists("autorun.stop")) exit(); } function get_content($url) { $buf = parse_url($url); $host=$buf['host']; $path=$buf['path']; if (isset($buf['query'])) $path .= "?" . $buf['query']; $header = "GET " . $path . " HTTP/1.1\r\n"; $header .= "Host: " . $host . "\r\n"; $header .= "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n"; $header .= "Cache-Control: max-age=0\r\n"; $header .= "Accept-Encoding: gzip,deflate,sdch\r\n"; $header .= "Accept-Language: zh-CN,zh;q=0.8\r\n"; $header .= "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1500.72 Safari/537.36\r\n"; $header .= "Connection: close\r\n\r\n"; $fp = fsockopen($host, 80, $errno, $errstr, 5); if ($fp) { fputs($fp,$header); fclose($fp); return true; } else { return false; } } function main() { $nowtime = $_SERVER["REQUEST_TIME"]; $time = file_get_contents("runtime.txt"); if ((self::$urltime_H == date("H")) && (self::$urltime_i == date("i")) && ($time != date("d"))) { $this -> get_content(self::$url); echo '运行成功'; $fp = fopen("runtime.txt","w"); fwrite($fp,date("d")); fclose($fp); } $time = file_get_contents("time.txt"); if (($nowtime - $time) >= self::$myselftime) { sleep(self::$myselftime); $this -> get_content(self::$myself); $fp = fopen("time.txt","w"); fwrite($fp,$nowtime); fclose($fp); } }}$job = new runjob();$job -> main();
程序会自动访问自身,并在18:00的时候访问目标网址http://127.0.0.1/to.php?pwd=123456789,访问一次,但有时发现会访问多次,次数是随机的,出现这种情况的时间也是随机的
回复讨论(解决方案)
PHP没有定时的功能吧。
最保险的方法就是有人访问,然后触发这个“定时”。
可以装个win32的扩展库
由于$this->get_content()请求发出时,web服务器会开出新的线程去接收你的请求(访问自身或者访问你的目标url),这实际上就相当于多个并发的访问。很可能你的文件内容还没写入,新的请求就过来了,因此,if ((self::$urltime_H == date("H")) && (self::$urltime_i == date("i")) && ($time != date("d")))这个判断可能会有效多次。自然会有多次的访问。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.
