Поведение системы светофора - вызов кода хакера
Скрипт CLI для имитации системы светофора
Поведение:
1) В период с 06:00 до 23:00
зеленый свет на 30 секунд
зеленый и желтый свет в течение 5 секунд
красный на 40 секунд
назад к зеленому
2) В течение 23:00-06:00
- мигает желтый свет (2 сек. выключен /1 сек. включен)
Ожидаемый результат:
- текстовое представление текущего света в секунду
3 ответа
<?php
if (PHP_SAPI !== 'cli') exit("Not allowed here..");
$hour = date("H");
while (true) {
// 6am to 11pm
if($hour >= 6 && $hour < 23){
$j = 30;
for ($i=0; $i < $j; $i++) {
echo "green light [".($i+1)."]\n";
sleep(1);
}
$j = 5;
for ($i=0; $i < $j; $i++) {
echo $i%2 ? "green" : "yellow";
echo " light [".($i+1)."]\n";
sleep(1);
}
$j = 40;
for ($i=0; $i < $j; $i++) {
echo "red light [".($i+1)."]\n";
sleep(1);
}
}
if($hour < 6 || $hour >= 23){
$j = 2;
for ($i=0; $i < $j; $i++) {
echo "yellow light off [".($i+1)."]\n";
sleep(1);
}
$j = 1;
for ($i=0; $i < $j; $i++) {
echo "yellow light on [".($i+1)."]\n";
sleep(1);
}
}
}
Как в комментарии вы согласились достичь этого с помощью Javascript Вот ваш интересный вывод.
var increment = 0;
setInterval(function(){
var time = new Date();
var hours = time.getHours();
var seconds = time.getSeconds();
var count = 75;//green+red
if(increment >= count){
increment =0;
}
if(hours >= 6 && hours<23 ){
//daySignal
document.querySelector('#shift').innerHTML = 'Day Signal';
if( increment >= 0 && increment < 35){
displayGreen(35-increment);
}
if( increment >= 30 && increment < 35){
displayYellow(35-increment);
}
if( increment >= 35){
displayRed(count-increment);
}
}else{
// knightSignal
document.querySelector('#shift').innerHTML = 'Knight Signal';
reset();
if( increment %3 != 0){
displayYellow(0);
}
}
increment +=1;
},1000);
function displayRed(timer='') {
reset();
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#red_light').style.backgroundColor = "red";
}
function displayYellow(timer='') {
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#yellow_light').style.backgroundColor = "yellow";
}
function displayGreen(timer='') {
reset();
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#green_light').style.backgroundColor = "green";
}
function reset() {
document.querySelector('#red_light').style.backgroundColor = "black";
document.querySelector('#yellow_light').style.backgroundColor = "black";
document.querySelector('#green_light').style.backgroundColor = "black";
}
.signal {
height: 30px;
width: 30px;
background-color: #000;
border-radius: 50%;
margin: 15px auto;
}
.timer{
color: #000;
font-size:20px;
text-align: center;
}
<div id="shift"></div>
<div class="">
<div id="timer" class="timer"></div>
<div id="red_light" class="signal"></div>
<div id="yellow_light" class="signal"></div>
<div id="green_light" class="signal"></div>
</div>
var increment = 0;
setInterval(function(){
var time = new Date();
var hours = time.getHours();
var seconds = time.getSeconds();
var count = 75;//green+red
if(increment >= count){
increment =0;
}
if(false && hours >= 6 && hours<23 ){// false to get night signal
//daySignal
document.querySelector('#shift').innerHTML = 'Day Signal';
if( increment >= 0 && increment < 35){
displayGreen(35-increment);
}
if( increment >= 30 && increment < 35){
displayYellow(35-increment);
}
if( increment >= 35){
displayRed(count-increment);
}
}else{
// knightSignal
document.querySelector('#shift').innerHTML = 'Knight Signal';
reset();
if( increment %3 != 0){
displayYellow(increment%3);
}
}
increment +=1;
},1000);
function displayRed(timer='') {
reset();
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#red_light').style.backgroundColor = "red";
}
function displayYellow(timer='') {
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#yellow_light').style.backgroundColor = "yellow";
}
function displayGreen(timer='') {
reset();
document.querySelector('#timer').innerHTML = timer;
document.querySelector('#green_light').style.backgroundColor = "green";
}
function reset() {
document.querySelector('#red_light').style.backgroundColor = "black";
document.querySelector('#yellow_light').style.backgroundColor = "black";
document.querySelector('#green_light').style.backgroundColor = "black";
}
.signal {
height: 30px;
width: 30px;
background-color: #000;
border-radius: 50%;
margin: 25px auto;
}
.timer{
color: #000;
font-size:20px;
text-align: center;
}
<div id="shift"></div>
<div class="">
<div id="timer" class="timer"></div>
<div id="red_light" class="signal"></div>
<div id="yellow_light" class="signal"></div>
<div id="green_light" class="signal"></div>
</div>
Примечание: пожалуйста, никогда не переходите дорогу, пока есть красный сигнал.
<?php
if (PHP_SAPI !== 'cli') exit("Not allowed here..");
$hour = date("H");
while (true) {
// 6am to 11pm
if($hour >= 6 && $hour < 23){
$j = 30;
for ($i=0; $i < $j; $i++) {
echo "green light [".($i+1)."]\n";
sleep(1);
}
$j = 5;
for ($i=0; $i < $j; $i++) {
echo $i%2 ? "green" : "yellow";
echo " light [".($i+1)."]\n";
sleep(1);
}
$j = 40;
for ($i=0; $i < $j; $i++) {
echo "red light [".($i+1)."]\n";
sleep(1);
}
}
if($hour < 6 || $hour >= 23){
$j = 2;
for ($i=0; $i < $j; $i++) {
echo "yellow light off [".($i+1)."]\n";
sleep(1);
}
$j = 1;
for ($i=0; $i < $j; $i++) {
echo "yellow light on [".($i+1)."]\n";
sleep(1);
}
}
}
:-D
Добавлена другая версия, которая обновляет вывод cli вместо печати новых строк.
<?php
if (PHP_SAPI !== 'cli') exit("Not allowed here..");
$hour = date("H");
echo "Light |State|Sec\n";
while(true){
// 6am to 11pm
if($hour >= 6 && $hour < 23){
$j = 30;
for ($i=0; $i < $j; $i++) {
output("green","on",$i+1);
}
$j = 5;
for ($i=0; $i < $j; $i++) {
$ltcol = $i%2 ? "green" : "yellow";
output($ltcol,"on",$i+1);
}
$j = 40;
for ($i=0; $i < $j; $i++) {
output("red","on",$i+1);
}
}
// 11pm to 6am
if($hour < 6 || $hour >= 23){
$j = 2;
for ($i=0; $i < $j; $i++) {
output("yellow","off",$i+1);
}
$j = 1;
for ($i=0; $i < $j; $i++) {
output("yellow","on",$i+1);
}
}
}
function output($light,$state,$sec){
$str = str_pad($light, 6, ' ', STR_PAD_RIGHT).' '.str_pad($state, 5, ' ', STR_PAD_RIGHT).' '.str_pad($sec, 2, ' ', STR_PAD_RIGHT);
echo "\033[16D";
echo $str;
sleep(1);
}