php中怎么实现后台执行?先返回用户请求,然后在后台运行。

个人博客地址:http://www.lampnick.com/php/364
<?php
ignore_user_abort(true); // 后台运行,不受前端断开连接影响
set_time_limit(3600); // 脚本最多运行1个小时
//后台运行的后面还要,set_time_limit(0); 除非在服务器上关闭这个程序,否则下面的代码将永远执行下去止到完成为止。
//如果程序运行不超时,在没有执行结束前,程序不会自动结束的.
//=========================================
//PHP中,在客户端发出请求触发脚本执行,然后在服务器端执行一段代码,页面关闭了也要继续执行,并且要先返回一些状态给客户端,避免前端等待超时。

ob_end_clean();//清除之前的缓冲内容,这是必需的,如果之前的缓存不为空的话,里面可能有http头或者其它内容,导致后面的内容不能及时的输出
header("Connection: close");//告诉浏览器,连接关闭了,这样浏览器就不用等待服务器的响应
header("HTTP/1.1 200 OK"); //可以发送200状态码,以这些请求是成功的,要不然可能浏览器会重试,特别是有代理的情况下

//return false;//加了这个下面的就不执行了,不加这个无法返回页面状态,浏览器一直在等待状态,可以关闭,但不是要的效果。
//die(); 或 return ;也一样不执行下面的
//runRack();自定义函数
//register_shutdown_function("runRack");
//return  ;

ob_start();//开始当前代码缓冲
$arr = ["文件生成中"];
echo json_encode($arr);
//下面输出http的一些头信息
$size = ob_get_length();
header("Content-Length: $size");
ob_end_flush();//输出当前缓冲
flush();//输出PHP缓冲
//在Yii2框架下,上面代码可能不会立即返回给客户端,所以需要加如下的代码,即可实现立即返回给客户端
//具体可查看此文章:http://www.lampnick.com/php/375
if (function_exists("fastcgi_finish_request")) {
     fastcgi_finish_request(); /* 响应完成, 关闭连接 */
} 
/*
  休眠PHP,也就是当前PHP代码的执行停止,20秒钟后PHP被唤醒,
  PHP唤醒后,继续执行下面的代码,但这个时候上面代码的结果已经输出浏览器了,
  也就是浏览器从HTTP头中知道了服务端关闭了连接,浏览器将不在等待服务器的响应,
  反应给客户的就是页面不会显示处于加载状态,换句话说用户可以关掉当前页面,或者关掉浏览器,
  PHP唤醒后继续执行下面的代码,这也就实现了PHP后台执行的效果,
  休眠的作用只是让php先把前面的输出作完,不要急于马上执行下面的代码,休息一下而已,也就是说下面的代码
  执行的时候前面的输出应该到达浏览器了
*/
sleep(20);
echo '这里的输出用户看不到,后台运行的';

//下面代码的任何输出都不会输出给浏览器,因为http连接已经关了,
//所以下面的代码的执行属于后台运行的

ignore_user_abort(true); // 后台运行,这个只是运行浏览器关闭,并不是直接就中止返回200状态。
set_time_limit(3600); // 脚本最多运行1个小时

runRack();

function runRack()
{
    file_put_contents("c:/runBack.txt", "后台运行输出结果");
}
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现后台登陆,一般需要以下几个步骤: 1. 创建一个登陆页面,其包括用户名和密码的输入框以及提交按钮。 2. 在后台编写一个处理登陆请求的程序。这个程序需要接收前台提交的用户名和密码,然后与数据库保存的用户信息进行比对,如果匹配成功则将用户信息保存到 session ,并跳转到后台首页;否则提示用户登陆失败。 3. 在后台的每一个需要权限控制的页面,都需要检查用户是否已经登陆。如果没有登陆则跳转到登陆页面,如果已经登陆则可以正常访问。 4. 当用户点击退出登陆按钮时,需要清除 session 保存的用户信息,并跳转到登陆页面。 具体实现步骤可以参考以下代码: 1. 登陆页面 ```html <form method="post" action="login.php"> <label>用户名:</label><input type="text" name="username"><br> <label>密码:</label><input type="password" name="password"><br> <input type="submit" value="登陆"> </form> ``` 2. 登陆处理程序 ```php <?php session_start(); // 连接数据库 $conn = mysqli_connect('localhost', 'root', 'password', 'dbname'); if (mysqli_connect_errno()) { die('数据库连接失败:' . mysqli_connect_error()); } // 接收登陆请求 $username = $_POST['username']; $password = $_POST['password']; // 查询用户信息 $sql = "SELECT * FROM users WHERE username='$username' AND password='$password'"; $result = mysqli_query($conn, $sql); // 判断用户是否存在 if (mysqli_num_rows($result) > 0) { // 保存用户信息到 session $_SESSION['username'] = $username; // 跳转到后台首页 header('Location: index.php'); } else { // 登陆失败 echo '登陆失败,请检查用户名和密码!'; } ?> ``` 3. 后台页面权限控制代码 ```php <?php session_start(); // 判断用户是否已经登陆 if (!isset($_SESSION['username'])) { // 跳转到登陆页面 header('Location: login.php'); exit; } ?> ``` 4. 退出登陆代码 ```php <?php session_start(); // 清除 session 保存的用户信息 unset($_SESSION['username']); // 跳转到登陆页面 header('Location: login.php'); ?> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值