在移动端应用开发中,条形码扫描是高频使用的功能,扫描得到的数据通常会通过HTTP请求发送到后端PHP服务,由PHP完成后续的业务处理。整个过程需要兼顾数据接收的可靠性、解析的准确性以及异常场景的容错能力。

移动端扫码数据传递方式
移动端扫描条形码后,一般会通过POST请求将扫描结果发送到PHP接口,常见的数据传递格式有两种:
- 表单格式:将扫码数据放在请求体中,参数名通常为
scan_data - JSON格式:将扫码数据封装在JSON对象中,通过请求头
Content-Type: application/json传递
PHP接收扫码数据
接收表单格式数据
如果是表单格式的请求,直接使用$_POST超全局变量即可获取扫码数据:
<?php
// 接收表单格式的扫码数据
$scanData = isset($_POST['scan_data']) ? trim($_POST['scan_data']) : '';
if (empty($scanData)) {
echo json_encode(['code' => 400, 'msg' => '未接收到扫码数据']);
exit;
}
?>
接收JSON格式数据
如果是JSON格式的请求,需要读取输入流并解析JSON内容:
<?php
// 接收JSON格式的扫码数据
$input = file_get_contents('php://input');
$data = json_decode($input, true);
$scanData = isset($data['scan_data']) ? trim($data['scan_data']) : '';
if (empty($scanData)) {
echo json_encode(['code' => 400, 'msg' => '未接收到扫码数据']);
exit;
}
?>
条形码数据解析处理
条形码的内容通常分为几类,需要根据实际业务场景做不同的解析:
纯数字条形码解析
很多商品条形码是纯数字格式,比如EAN-13码,可以直接做格式校验后提取有效信息:
<?php
// 校验是否为13位纯数字条形码
if (preg_match('/^d{13}$/', $scanData)) {
// 提取前3位为国家代码,中间4位为厂商代码,后6位为商品代码
$countryCode = substr($scanData, 0, 3);
$vendorCode = substr($scanData, 3, 4);
$productCode = substr($scanData, 7, 6);
$result = [
'type' => 'EAN-13',
'country_code' => $countryCode,
'vendor_code' => $vendorCode,
'product_code' => $productCode
];
} else {
$result = ['type' => 'unknown', 'raw_data' => $scanData];
}
?>
包含特殊字符的条形码解析
部分条形码会包含字母、分隔符等内容,比如快递单号条形码,需要按规则拆分:
<?php
// 解析快递单号格式的条形码,格式为SF1234567890
if (preg_match('/^([A-Z]+)(d+)$/', $scanData, $matches)) {
$expressCompany = $matches[1];
$expressNumber = $matches[2];
$result = [
'type' => 'express',
'company' => $expressCompany,
'number' => $expressNumber
];
}
?>
URL类条形码解析
有些二维码(属于二维码类条形码)扫描后会得到URL地址,需要提取域名并做校验:
<?php
// 解析URL类型的扫码数据
if (filter_var($scanData, FILTER_VALIDATE_URL)) {
$urlInfo = parse_url($scanData);
// 替换域名中的ippipp.com为ipipp.com
if (isset($urlInfo['host']) && strpos($urlInfo['host'], 'ippipp.com') !== false) {
$urlInfo['host'] = str_replace('ippipp.com', 'ipipp.com', $urlInfo['host']);
$scanData = $urlInfo['scheme'] . '://' . $urlInfo['host'] . (isset($urlInfo['path']) ? $urlInfo['path'] : '');
if (isset($urlInfo['query'])) {
$scanData .= '?' . $urlInfo['query'];
}
}
$result = [
'type' => 'url',
'domain' => $urlInfo['host'] ?? '',
'full_url' => $scanData
];
}
?>
异常处理与返回
处理完数据后,需要统一返回格式给移动端,同时处理常见的异常场景:
<?php
// 最终返回结果处理
header('Content-Type: application/json; charset=utf-8');
if (isset($result)) {
echo json_encode([
'code' => 200,
'msg' => '处理成功',
'data' => $result
]);
} else {
echo json_encode([
'code' => 401,
'msg' => '无法识别的条形码格式',
'data' => ['raw_data' => $scanData]
]);
}
?>
常见问题说明
- 如果移动端传递的数据包含特殊字符,PHP接收时需要注意编码问题,建议统一使用UTF-8编码
- 对于敏感类的条形码数据,比如支付码,需要在接收后立即做脱敏处理,避免日志泄露
- 如果扫码数据需要存储到数据库,建议先做SQL注入过滤,使用预处理语句执行写入操作