3v4l.org

run code in 300+ PHP versions simultaneously
<?php /** * @file requestUserInfo.php * @TIME * @brief Brief * @Author Author * @Website www.lotto-pass.cn * */ define('IN_ECS', true); //echo "<p>in request:"; //print_r($_POST); $current_path = dirname(__FILE__); $base_path = substr($current_path, 0, strlen($current_path) - strlen("/webservice")); require_once($base_path . '/includes/init.php'); require_once(ROOT_PATH . 'includes/cls_json.php'); require_once(ROOT_PATH . 'includes/lib_common.php'); // echo "<p>After include:"; require_once (ROOT_PATH . 'includes/utilities/dbutilities.php'); require_once (ROOT_PATH . 'includes/webservice/webserviceutilities.php'); require_once (ROOT_PATH . 'includes/utilities/userUtilities.php'); $device_id = getHttpRequest("device_id"); $trans_time = getHttpRequest("trans_time"); $card_number = getHttpRequest("card_number"); $sessionId = getHttpRequest("sessionId"); $pSessionId = getHttpRequest("pSessionId"); $sessionTime = $trans_time; //getHttpRequest("sessionTime"); $min_required_points = getHttpRequest("mpb"); $check_sum = getHttpRequest("checksum"); $check_sum_array = array( "device_id" => $device_id, "card_number" => $card_number, "mpb" => $min_required_points, "trans_time" => $trans_time, "sessionId" => $sessionId, "checksum" => $check_sum ); $check_sum_str = constructHttpParameters($check_sum_array); // echo "<p>card_number:".$card_number; // echo "<p>check_sum_str:".$check_sum_str; $resultcode = 0; $xml_string = ""; $update_data = array(); $log_date = array(); $post_data = array(); // In case previousSessionId is found if (strlen($pSessionId) > 0) { include_once("closeUserTransaction.php"); $closedPreviousTransaction = array(); $consumed_points = getHttpRequest("consumed_points"); $received_award_points = getHttpRequest("award_points"); $transfer_points = getHttpRequest("transfer_points"); $user_points = 0; $received_cash_points = getHttpRequest("cash_points"); $closingRecordsReceived['card_number'] = $card_number; $closingRecordsReceived['sessionId'] = $pSessionId; $closingRecordsReceived['consumed_points'] = $consumed_points; $closingRecordsReceived['award_points'] = $received_award_points; $closingRecordsReceived['transfer_points'] = $transfer_points; $closingRecordsReceived['user_points'] = $user_points; $closingRecordsReceived['cash_points'] = $received_cash_points; $closingRecordsReceived['device_id'] = $device_id; $closingRecordsReceived['TransTime'] = $trans_time; $closedPreviousTransaction = closeUserTransaction($closingRecordsReceived); $post_data = array_merge($post_data, $closedPreviousTransaction); $post_data['pSessionId'] = $pSessionId; $resultcode_closing = 3; $post_data['status_closing'] = $resultcode_closing; } $min_factor1=5; //最低积分的倍数; $min_factor2=10; $transfer_factor1 = 0; // Not enough, no transfer $transfer_factor2 = 1; // Very low, send everything that enough for purchase $transfer_factor3 = 2; // Not enough for 10 purchases, send half of the points $transfer_factor4 = 10; // Sufficient, send points for 10 purchases. $exist_card_number = 0; $post_data['sessionId'] = $sessionId; $post_data['device_id'] = $device_id; $post_data['sessionTime'] = $sessionTime; $post_data['trans_time'] = $trans_time; $post_data['mpb'] = $min_required_points; $post_data['user_id'] = ""; $post_data['user_name'] = ""; $post_data['alias'] = "";//urlencode($alias); $post_data['display_user_points'] = 0; $post_data['message'] = ""; $post_data['transfer_points'] = 0; $post_data['user_points'] = 0; $post_data['fund_status'] = 100; //100 means not enough fund // Retrieve the jackpot related information and messages $jackpot_table_name = "jackpot_award"; $jackpot_key = "add_time"; $jackpot_sql_result = selectLastRecord($jackpot_key, $jackpot_table_name); while($sql_data = mysql_fetch_array($jackpot_sql_result, MYSQL_ASSOC)){ // echo "<p>The sql_result:"; // print_r($sql_data); $jackpot_amount = $sql_data['jackpot_amount']; $jackpot_ceiling = $sql_data['jackpot_ceiling']; $jackpot_preserved = $sql_data['jackpot_preserved']; $message_front = $sql_data['message_front']; $message_mid = $sql_data['message_mid']; $message_end = $sql_data['message_end']; $message_top = $sql_data['message_top']; //echo "The messages:".$message_front."-".$message_mid."-".$message_end."-".$message_top; $jackpot_data['jackpot_amount'] = $jackpot_amount; $jackpot_data['jackpot_ceiling'] = $jackpot_ceiling; $jackpot_data['jackpot_preserved'] = $jackpot_preserved; $jackpot_data['message_front'] = $message_front; $jackpot_data['message_mid'] = $message_mid; $jackpot_data['message_end'] = $message_end; $jackpot_data['message_top'] = $message_top; $post_data['Jackpot'] = $jackpot_data; } mysql_free_result($sql_result); // echo "<p>The post data:"; // print_r($post_data); // echo "<p>card_number length:".strlen($card_number); if (!existSessionId($sessionId, $sessionTime)) { // Retrieve the user information and the points from database $table_name = "users"; // echo "before check sum"; if (strlen($card_number) > 0) { $conditions = "card_number = ".$card_number; if (true) {// if (checkBcc($check_sum_str, $check_sum)) { // echo "after check sum"; $sql_result = selectConditionalRecords($conditions, $table_name); while($sql_data = mysql_fetch_array($sql_result, MYSQL_ASSOC)){ // echo "<p>The sql_result:"; // print_r($sql_data); $exist_card_number++; $user_id = $sql_data['user_id']; $user_name = $sql_data['user_name']; $alias = $sql_data['alias']; $current_user_points = abs($sql_data['user_points']); $current_frozen_points = abs($sql_data['frozen_points']); $post_data['user_id'] = $user_id; $post_data['user_name'] = $user_name; $post_data['alias'] = $alias; $post_data['display_user_points'] = abs(intval($current_user_points)); $usable_points = $current_user_points - $current_frozen_points; // echo "<p>usable_points:".$usable_points; switch ($usable_points) { case ($usable_points < $min_required_points) : // echo "<p>case: 100"; $post_data['message'] = "剩余积分不足, 请充值后再继续。"; //$usable_points = 0; $transfer_points = $usable_points * $transfer_factor1; $user_points = $current_user_points; $frozen_points = $current_frozen_points + $transfer_points; $post_data['transfer_points'] = abs(intval($transfer_points)); $post_data['user_points'] = abs(intval($user_points)); $post_data['fund_status'] = 100; //100 means not enough fund break; case ($usable_points >= $min_required_points and $usable_points <= $min_required_points*$min_factor1) : // echo "<p>case: 200"; $post_data['message'] = "剩余积分很低,请速充值。"; $transfer_points = round($usable_points/($min_required_points * $transfer_factor2),0)*$min_required_points; while ($transfer_points > $usable_points) { $transfer_points = $transfer_points - $min_required_points; } $frozen_points = $current_frozen_points + $transfer_points; $user_points = $current_user_points - $transfer_points; // echo "<p> transfer_points:".$transfer_points; $post_data['frozen_points'] = abs(intval($frozen_points)); $post_data['transfer_points'] = abs(intval($transfer_points)); $post_data['user_points'] = abs(intval($user_points)); $post_data['fund_status'] = 200; //200 means very low fund break; case ($usable_points > $min_required_points*$min_factor1 and $usable_points <= $min_required_points*$min_factor2) : // echo "<p>case: 300"; $post_data['message'] = "剩余积分低,请速充值。"; $transfer_points = round($usable_points /($min_required_points * $transfer_factor3),0)*$min_required_points; while ($transfer_points > $usable_points) { $transfer_points = $transfer_points - $min_required_points; } $frozen_points = $current_frozen_points + $transfer_points; $user_points = $current_user_points - $transfer_points; // echo "<p> transfer_points:".$transfer_points; $post_data['frozen_points'] = abs(intval($frozen_points)); $post_data['transfer_points'] = abs(intval($transfer_points)); $post_data['user_points'] = abs(intval($user_points)); $post_data['fund_status'] = 300; //300 means low fund break; case ($usable_points >= $min_required_points*$min_factor4) : // echo "<p>case: default"; $post_data['message'] = "感谢参与公益购彩。"; $transfer_points = $min_required_points*$transfer_factor4; $frozen_points = $current_frozen_points + $transfer_points; $user_points = $current_user_points - $transfer_points; // echo "<p> transfer_points:".$transfer_points; $post_data['frozen_points'] = abs(intval($frozen_points)); $post_data['transfer_points'] = abs(intval($transfer_points)); $post_data['user_points'] = abs(intval($user_points)); $post_data['fund_status'] = 1000; //1000 means sufficient fund break; default : // echo "<p>case: 0"; $post_data['message'] = "无法获取有效积分,请重试。"; $usable_points = 0; $transfer_points = 0; $user_points = 0; $post_data['transfer_points'] = 0; $post_data['user_points'] = 0; $post_data['fund_status'] = 0; //0 means not processed } } mysql_free_result($sql_result); } else { $resultcode = -5; } } else { $resultcode = 0; } // print_r($post_data); // Update if ($exist_card_number > 0) { $post_data['card_number'] = $card_number; $user_point_change = - $transfer_points; $frozen_points_change = $transfer_points; $change_desc = "可用积分".$usable_points.",向".$device_id."上划拨".$frozen_points."积分,资金状态".$post_data['fund_status']; log_account_change($user_id, 0, 0, 0, $user_point_change, $frozen_points_change, 0, 0, $change_desc); $resultcode = 1; $post_data['status'] = $resultcode; // Check if there is any voucher need to be printed for this user. $voucher_table_name = "active_vouchers"; $conditions = "user_id = ".$user_id." AND status = 0"; $voucher_sql_result = selectConditionalRecords($conditions, $voucher_table_name);; while($sql_data = mysql_fetch_array($voucher_sql_result, MYSQL_ASSOC)){ // echo "<p>The sql_result:"; // print_r($sql_data); $voucher_id = $sql_data['id']; $voucher_template_id = $sql_data['voucher_id']; $qr_message = $sql_data['qr_message']; $voucher_message = $sql_data['message']; $voucher_data['voucher_id'] = $voucher_id; $voucher_data['voucher_template_id'] = $voucher_template_id; $voucher_data['qr_message'] = $qr_message; $voucher_data['voucher_message'] = $voucher_message; $post_data['Coupon'] = $voucher_data; } mysql_free_result($sql_result); } else { $post_data['card_number'] = -1; } $xml_string = getArrayToXML($post_data); //echo $xml_string; $dbStatus = setSessionId($sessionId, $sessionTime, $frozen_points, $xml_string); // echo "<p> The XML_data:".$xml_string; } else { if (strlen($card_number) > 0) { $resultcode = 2;//重发 // $post_data['status'] = $resultcode; echo "resultcode:".$resultcode; $xml_string = getTransferred($sessionId, $sessionTime); } else { $resultcode = -1; $post_data['status'] = $resultcode; $post_data['card_number'] = -1; $xml_string = getArrayToXML($post_data); } } header("Expires: date('Y-m-d H:i:s')"); echo $xml_string; function setAcceptableArgs() { //echo "<p>In setAcceptableArgs: "; $acceptable_args = array( "card_number", "sessionId", "trans_time", "award_points", "min_required_points", "device_id", "checksum" ); return $acceptable_args; } ?>

Here you find the average performance (time & memory) of each version. A grayed out version indicates it didn't complete successfully (based on exit-code).

VersionSystem time (s)User time (s)Memory (MiB)
8.3.70.0180.00416.73
8.3.60.0120.00316.88
8.3.50.0100.00922.04
8.3.40.0130.00318.98
8.3.30.0080.00819.09
8.3.20.0050.00320.41
8.3.10.0080.00021.99
8.3.00.0060.00319.51
8.2.190.0140.00716.88
8.2.180.0170.00316.88
8.2.170.0090.00622.96
8.2.160.0070.01122.06
8.2.150.0050.00324.18
8.2.140.0030.00624.66
8.2.130.0080.00026.16
8.2.120.0040.00419.64
8.2.110.0090.00019.35
8.2.100.0110.00417.88
8.2.90.0030.00519.34
8.2.80.0000.00817.97
8.2.70.0050.00317.75
8.2.60.0050.00517.80
8.2.50.0040.00418.07
8.2.40.0110.00018.19
8.2.30.0060.00318.13
8.2.20.0000.00817.93
8.2.10.0040.00418.16
8.2.00.0060.00317.84
8.1.280.0040.01825.92
8.1.270.0160.00319.25
8.1.260.0030.00626.35
8.1.250.0050.00328.09
8.1.240.0060.00324.02
8.1.230.0090.00317.61
8.1.220.0030.00517.91
8.1.210.0060.00318.77
8.1.200.0070.00317.50
8.1.190.0030.00517.60
8.1.180.0030.00618.10
8.1.170.0090.00020.44
8.1.160.0000.00722.20
8.1.150.0000.00819.07
8.1.140.0000.00817.70
8.1.130.0040.00418.01
8.1.120.0000.00717.57
8.1.110.0030.00617.61
8.1.100.0040.00417.52
8.1.90.0070.00017.68
8.1.80.0080.00017.55
8.1.70.0040.00417.62
8.1.60.0030.00617.72
8.1.50.0030.00617.69
8.1.40.0040.00417.70
8.1.30.0000.00817.93
8.1.20.0000.00817.92
8.1.10.0040.00417.80
8.1.00.0080.00317.78
8.0.300.0000.00918.77
8.0.290.0050.00317.13
8.0.280.0050.00318.67
8.0.270.0040.00417.51
8.0.260.0000.00717.43
8.0.250.0040.00417.11
8.0.240.0030.00317.33
8.0.230.0070.00017.29
8.0.220.0050.00217.27
8.0.210.0060.00317.11
8.0.200.0040.00417.26
8.0.190.0000.00817.23
8.0.180.0030.00517.27
8.0.170.0000.00917.21
8.0.160.0060.00317.26
8.0.150.0070.00017.21
8.0.140.0030.00517.23
8.0.130.0060.00213.63
8.0.120.0000.00715.39
8.0.110.0030.00515.34
8.0.100.0030.00415.32
8.0.90.0050.00215.33
8.0.80.0050.00715.46
8.0.70.0020.00615.37
8.0.60.0050.00215.45
8.0.50.0020.00515.38
8.0.30.0140.00916.15
8.0.20.0080.01116.21
8.0.10.0020.00515.48
8.0.00.0020.01215.99
7.4.330.0030.00315.21
7.4.320.0030.00316.60
7.4.300.0040.00716.75
7.4.290.0030.00516.77
7.4.280.0040.00416.77
7.4.270.0040.00416.68
7.4.260.0000.00716.77
7.4.250.0020.00515.13
7.4.240.0030.00415.66
7.4.230.0020.00515.14
7.4.220.0070.01015.03
7.4.210.0050.00715.71
7.4.200.0050.00115.07
7.4.190.0030.00313.47
7.4.180.0030.00313.52
7.4.160.0060.00815.23
7.4.150.0070.00615.44
7.4.140.0040.01116.38
7.4.130.0130.00115.66
7.4.120.0050.00815.53
7.4.110.0020.01015.00
7.4.100.0060.00615.22
7.4.90.0080.00415.01
7.4.80.0070.00416.39
7.4.70.0080.00415.15
7.4.60.0070.00515.09
7.4.50.0000.00614.90
7.4.40.0060.00614.92
7.4.30.0080.00415.05
7.4.20.0000.00613.33
7.4.10.0000.00513.36
7.4.00.0080.00314.24
7.3.330.0030.00313.66
7.3.320.0160.00013.53
7.3.310.0020.00414.99
7.3.300.0000.00615.06
7.3.290.0000.00615.02
7.3.280.0060.00815.88
7.3.270.0090.00315.52
7.3.260.0090.00315.00
7.3.250.0070.00815.60
7.3.240.0060.00515.07
7.3.230.0060.00615.21
7.3.220.0080.00013.41
7.3.210.0020.00915.01
7.3.200.0050.00716.40
7.3.190.0030.01115.04
7.3.180.0050.00615.14
7.3.170.0080.00615.05
7.3.160.0060.00615.06
7.3.150.0000.00513.38
7.3.140.0030.00313.61
7.3.130.0000.00613.44
7.3.120.0030.00313.36
7.3.110.0050.00013.38
7.3.100.0060.00013.36
7.3.90.0000.00613.69
7.3.80.0020.00513.40
7.3.70.0060.00013.11
7.3.60.0050.00013.46
7.3.50.0030.00313.46
7.3.40.0060.00013.59
7.3.30.0030.00313.43
7.3.20.0000.00615.30
7.3.10.0030.00315.12
7.3.00.0050.00015.31
7.2.340.0100.00213.50
7.2.330.0100.00515.12
7.2.320.0080.00815.09
7.2.310.0100.00915.11
7.2.300.0070.00815.24
7.2.290.0050.01115.19
7.2.280.0090.00413.64
7.2.270.0040.00813.49
7.2.260.0070.00513.49
7.2.250.0120.00013.49
7.2.240.0130.00013.60
7.2.230.0090.00413.62
7.2.220.0130.00013.60
7.2.210.0100.00213.63
7.2.200.0120.00213.57
7.2.190.0130.00013.70
7.2.180.0130.00013.70
7.2.170.0140.00013.75
7.2.160.0120.00013.70
7.2.150.0140.00015.32
7.2.140.0130.00015.26
7.2.130.0130.00015.50
7.2.120.0080.00415.39
7.2.110.0090.00315.46
7.2.100.0100.00315.48
7.2.90.0090.00515.41
7.2.80.0080.00415.50
7.2.70.0060.00615.25
7.2.60.0100.00616.21
7.2.50.0080.00616.22
7.2.40.0060.00615.51
7.2.30.0100.00315.40
7.2.20.0090.00415.34
7.2.10.0000.01215.41
7.2.00.0140.00015.35
7.1.330.0120.00014.18
7.1.320.0040.00914.21
7.1.310.0120.00014.16
7.1.300.0000.01214.12
7.1.290.0100.00214.38
7.1.280.0120.00014.36
7.1.270.0060.00614.36
7.1.260.0110.00014.17
7.1.250.0120.00014.28
7.1.240.0110.00014.29
7.1.230.0000.01214.14
7.1.220.0060.00614.31
7.1.210.0060.00614.21
7.1.200.0110.00415.11
7.1.190.0060.00614.42
7.1.180.0000.01214.25
7.1.170.0060.00614.27
7.1.160.0090.00314.29
7.1.150.0120.00014.29
7.1.140.0000.01214.30
7.1.130.0100.00214.33
7.1.120.0060.00614.11
7.1.110.0120.00014.12
7.1.100.0090.00416.20
7.1.90.0070.00514.18
7.1.80.0090.00314.32
7.1.70.0060.00415.66
7.1.60.0090.00716.91
7.1.50.0120.00515.70
7.1.40.0120.00014.22
7.1.30.0070.00514.34
7.1.20.0060.00614.26
7.1.10.0100.00214.26
7.1.00.0070.03918.36
7.0.330.0100.00214.27
7.0.320.0110.00014.38
7.0.310.0040.00814.31
7.0.300.0000.01214.26
7.0.290.0130.00014.18
7.0.280.0100.00314.32
7.0.270.0060.00614.32
7.0.260.0040.00814.09
7.0.250.0060.00614.35
7.0.240.0080.00414.44
7.0.230.0060.00614.42
7.0.220.0070.00514.16
7.0.210.0090.00314.19
7.0.200.0080.00215.57
7.0.190.0060.00614.30
7.0.180.0060.00614.30
7.0.170.0100.00214.35
7.0.160.0090.00314.20
7.0.150.0100.00214.15
7.0.140.0070.02218.15
7.0.130.0090.00314.22
7.0.120.0060.00614.34
7.0.110.0110.00014.16
7.0.100.0190.01817.24
7.0.90.0100.02117.09
7.0.80.0200.03517.05
7.0.70.0140.02117.07
7.0.60.0060.02717.18
7.0.50.0130.03617.35
7.0.40.0050.02217.18
7.0.30.0100.02517.18
7.0.20.0030.04717.18
7.0.10.0090.03217.20
7.0.00.0050.04417.07
5.6.400.0090.00312.85
5.6.390.0120.00012.70
5.6.380.0060.00612.75
5.6.370.0060.00612.70
5.6.360.0090.00212.73
5.6.350.0130.00012.78
5.6.340.0090.00212.69
5.6.330.0040.00712.52
5.6.320.0080.00312.74
5.6.310.0080.00312.77
5.6.300.0090.00312.76
5.6.290.0100.00312.73
5.6.280.0060.03816.95
5.6.270.0080.00312.74
5.6.260.0060.00612.54
5.6.250.0090.03716.72
5.6.240.0100.04016.78
5.6.230.0090.04016.77
5.6.220.0060.02416.72
5.6.210.0110.04116.67
5.6.200.0070.02517.07
5.6.190.0050.04117.10
5.6.180.0080.04516.90
5.6.170.0110.03217.03
5.6.160.0090.04016.99
5.6.150.0070.02616.96
5.6.140.0060.04016.89
5.6.130.0080.03916.82
5.6.120.0070.02016.99
5.6.110.0050.03916.90
5.6.100.0110.02316.89
5.6.90.0070.02516.84
5.6.80.0040.04016.57
5.6.70.0070.02416.50
5.6.60.0100.03916.68
5.6.50.0090.03216.59
5.6.40.0060.04016.63
5.6.30.0020.04716.59
5.6.20.0040.03316.66
5.6.10.0070.02816.46
5.6.00.0080.02116.47
5.5.380.0060.02216.71
5.5.370.0080.04616.65
5.5.360.0080.04616.64
5.5.350.0040.02216.47
5.5.340.0090.03516.82
5.5.330.0110.04016.71
5.5.320.0120.03216.74
5.5.310.0090.04216.77
5.5.300.0060.02016.72
5.5.290.0100.02016.68
5.5.280.0090.03716.86
5.5.270.0060.02316.89
5.5.260.0100.02316.79
5.5.250.0050.02316.56
5.5.240.0070.03516.43
5.5.230.0030.02416.53
5.5.220.0090.03416.49
5.5.210.0040.04516.57
5.5.200.0120.03416.43
5.5.190.0080.02316.25
5.5.180.0130.03516.43
5.5.170.0110.00012.59
5.5.160.0080.03916.35
5.5.150.0060.02316.43
5.5.140.0050.01916.38
5.5.130.0130.02816.42
5.5.120.0030.04416.41
5.5.110.0080.02916.33
5.5.100.0090.04016.44
5.5.90.0090.03716.39
5.5.80.0040.02216.35
5.5.70.0070.02216.35
5.5.60.0090.03916.46
5.5.50.0080.04216.48
5.5.40.0040.04016.41
5.5.30.0070.04216.33
5.5.20.0070.02316.36
5.5.10.0050.02016.44
5.5.00.0090.03816.42
5.4.450.0060.03115.96
5.4.440.0090.04316.10
5.4.430.0080.03616.05
5.4.420.0040.02916.08
5.4.410.0080.02016.01
5.4.400.0060.03215.93
5.4.390.0110.03715.98
5.4.380.0040.02515.78
5.4.370.0070.04215.84
5.4.360.0080.03815.92
5.4.350.0040.02015.90
5.4.340.0060.02015.95
5.4.330.0060.00612.83
5.4.320.0030.02315.89
5.4.310.0140.03315.92
5.4.300.0130.03515.94
5.4.290.0060.01915.87
5.4.280.0050.04315.82
5.4.270.0060.01815.85
5.4.260.0070.03415.90
5.4.250.0060.02415.79
5.4.240.0050.02115.67
5.4.230.0110.01715.81
5.4.220.0170.03215.71
5.4.210.0090.03315.90
5.4.200.0040.02415.93
5.4.190.0080.02215.86
5.4.180.0020.02715.76
5.4.170.0050.02515.67
5.4.160.0040.02115.89
5.4.150.0090.04216.00
5.4.140.0090.01514.49
5.4.130.0050.02714.72
5.4.120.0150.02714.55
5.4.110.0030.03114.52
5.4.100.0050.03614.64
5.4.90.0110.03614.50
5.4.80.0080.02014.66
5.4.70.0070.02614.55
5.4.60.0040.02714.53
5.4.50.0040.02214.50
5.4.40.0070.02014.49
5.4.30.0090.02814.60
5.4.20.0100.03514.51
5.4.10.0040.02314.60
5.4.00.0030.04414.10

preferences:
42.44 ms | 401 KiB | 5 Q