0

我有一个脚本,允许用户提交搜索查询,通常以站点名称的形式或使用设备的 MAC 地址。我想让搜索尽可能简单,所以只需要一个搜索字段,并且不想用选择字段或单选按钮将其弄乱,以便用户指定他们正在搜索的内容。我想在后端自动处理这个问题。

以下是我希望以下列格式之一搜索站点名称的方式:

字母和数字只是例子,可以是任何东西,只是这种格式。

TX-DAL0099A1
TX-DAL0099A
TX-DAL0099
DAL0099A1
DAL0099A
DAL0099

或按 MAC 地址

00 11 22 33 44 55
00:11:22:33:44:55
00.11.22.33.44.55
00-11-22-33-44-55
001122334455

我正在寻找最好的方法来首先检查它是否是站点名称(第一个示例),然后如果不是,请确保它是 MAC 地址。我不想在搜索查询上运行 preg_replace 函数来去除任何杂项字符,如连字符、句点、冒号等,因为拥有站点名称的前缀 TX- 部分很重要——如果它实际上是正在搜索的站点名称。

注意:我需要知道站点名称是否有前缀,以及示例中的结尾 A/A1。这些很重要。

我希望这是有道理的。=/

哦,我正在用 PHP 做这个 - 忘了提。

更新:这个代码片段会起作用吗?

if(preg_match("/^([0-9A-F]{2}[:-\s]?){5}([0-9A-F]{2})$/", $input)) {
    // SEARCH IS A MAC ADDRESS
}
else if((($query = $mysqli->query("SELECT * FROM `table` WHERE `site` LIKE '%$input%'")) !== false) && $query->num_rows() > 0) {
    // SEARCH IS A SITE AND FOUND ROW IN DATABASE
}
else {
    // NEITHER SITE NOR MAC, OR COULDN'T BE FOUND
}
4

3 回答 3

4

以下是一些应该有所帮助的片段。

看看我们是否有 MAC 地址(从什么是 MAC 地址的正则表达式中获取(和调整)正则表达式模式?):

if(preg_match("/^([0-9A-F]{2}[:-\s]?){5}([0-9A-F]{2})$/", $input)) {
   // We have a MAC address
}

看看我们在输入中是否有破折号(表示前缀)以及它是什么:

$siteNamePieces = explode("-",$input);
if(count($siteNamePieces) >= 2) {
   // Site name has a prefix, and it is $siteNamePieces[0]
}

看看我们是以 A 还是 A1 结尾:

if(substr($input, -1) == "A") {
   // Ends in A
} else if(substr($input, -2) == "A1") {
   // Ends in A1
}

我希望这些将需要根据您正在寻找的不同类型的结尾进行调整,是否可以出现破折号而不一定意味着它是一个前缀等。我猜你需要去掉前缀和结尾并得到用于查询目的的核心站点名称值。

一旦您知道您正在处理什么样的数据(mac 地址、站点名称),您就可以适当地查询您的数据库。

希望这些能让你朝着正确的方向前进!

于 2013-03-29T04:43:27.103 回答
2

下面的 SQL 查询将查找 site 与输入相似的行,或者 mac 正是输入。

SELECT * FROM `table` WHERE `site` LIKE '%$input%' OR `mac` = '$input';
于 2013-03-29T04:45:45.483 回答
0

您可以尝试使用 variable1 ==== variable2

它将字符串与数据类型进行比较,因为它具有三个等号字符,否则它只会比较值

于 2013-03-29T06:49:02.170 回答