3G调制解调器中的错误检测

时间:2012-06-12 10:46:33

标签: perl at-command

我正在尝试将一些错误检测添加到用于从我们的监控系统发送SMS消息的脚本中。大部分时间它都像魅力一样,但在极少数情况下它停止发送消息,我们不知道为什么。

我们无法重现错误,所以我想知道是否有人有类似的问题。下面是发送消息的代码,下面是我可能能够捕获错误的想法。

以下是发送消息的代码:

sub sendsms {
  my ($number,$msg) = @_;
  my $store = undef;
  my $status = undef;
  $msg =~ tr/\\[\]_'^~\{\}\|/\/\(\)\-"??\(\)!/; # \ -> /, [ -> (, ] -> ), ...., strippa út [ ] _ ' ^ ~ { } | \
  $msg =~ tr/\xe1\xe9\xed\xf3\xfa\xfd\xf0\xfe\xe6\xf6\xc1\xc9\xcd\xd3\xda\xdd\xd0\xde\xc6\xd6/aeiouydtaoAEIOUYDTAO/;
  for (my $i = 0; $i < length($msg); $i++) {
    substr($msg,$i,1) = '_' if (ord(substr($msg,$i,1)) < 0x20 || ord(substr($msg,$i,1)) > 0x7f);
  }
  my $s = substr($msg,0,$maxlen);
  RETRY: for (my $t = 0; $t < 5; $t++) {
    eval {
      put('AT+CMGD='.($next_store+1), 'OK');
      put('AT+CSCA="'.$sca.'",145', 'OK');
      put('AT+CMGF=1', 'OK');
      put('AT+CMGW="'.$number.'",145', '>');
      put($s, '>');
      my $a = put("\x{1a}", undef);
      print "a = '$a'\n" if ($verbose);
      if ($a =~ /\+CMGW: ([0-9]*)/) {
        $store = $1;
        last RETRY;
      }
     };
    if ($@) {
      print "ERROR: attempt $t: $@\n";
    }
    sleep 2*($t+1);
  }
  if (defined $store) {
    print "Message store $store\n" if ($verbose);
    put('AT+CMSS='.$store.',"'.$number.'",145',undef);
    $next_store = (($store - 1) + 1) % $stores;
  }
  else {
    die "Message not stored";
  }
}

put函数:

sub put {
  my ($cmd,$expect) = @_;
  print "Sending command '$cmd' expecting '$expect'\n" if ($verbose);
  $modem->atsend($cmd."\r\n") || die "FAILED send\n";
  my $a = $modem->answer();
  die "Failed '$cmd' expected '$expect' got '$a'\n" if (defined $expect && !($a =~ /$expect/));
  return $a;
}

就像我之前说的那样,99%的时间都有效。错误似乎是消息被写入商店但从未发送过。

我的想法:

eval {'$status = AT+CPAS'};
if (defined $status and ($status == '+CPAS: 1' or $status == '+CPAS: 2')){
    print "Modem returned an error status: ".$status;
    flush_stores();
    sendsms('+xxxxxxxxxx', 'There is an error in the 3G modem');
}

冲洗功能:

sub flush_stores {
   for (my $i = 0; $i < $stores; $i++) {
      put('AT+CMGD='.($i+1), 'OK');
   }
}

这会有用吗?

如果没有,会是什么?

吉斯利

1 个答案:

答案 0 :(得分:0)

这似乎是一个硬件问题。我们已经取代了3G调制解调器和SIM卡,现在一切都很顺利。知道是否有任何方法可以检测到这类故障会很有趣。