更新:它已在 Restler 2.1.5 中修复
这是一个存在于 Restler 2.1.4 中的错误,由 DocParser 引起,因为它需要@class
特定格式的注释,如下所示
/**
* @class ClassName(property=value&property2=value2)
*/
它用于在初始化后设置另一个类的属性。例如,我们可以使用它来告诉 XmlFormat 设置根名称,定义应该转换为属性的内容等,让我们以已知的 BMI 示例,添加 PHPDoc 注释,如下所示,
<?php
class BMI {
/**
* @class XmlFormat(root_name=self&attribute_names=height,weight)
*/
function index($height=162.6, $weight=84) {
$result = new stdClass();
$cm = $height;
$kg = $weight;
$meter = $cm / 100;
$inches = $meter * 39.3700787;
$feet = round($inches/12);
$inches = $inches % 12;
$result->bmi = round($kg/($meter*$meter),2);
$lb = round($kg/0.45359237,2);
if($result->bmi<18.5){
$result->message = 'Underweight';
}elseif ($result->bmi<=24.9){
$result->message = 'Normal weight';
}elseif ($result->bmi<=29.9){
$result->message = 'Overweight';
}else{
$result->message = 'Obesity';
}
$result->metric = array('height'=>"$cm centimeter", 'weight'=>"$weight kilograms");
$result->imperial = array('height'=>"$feet feet $inches inches", 'weight'=>"$lb pounds");
return $result;
}
}
返回以下 XML
<?xml version="1.0"?>
<self>
<bmi>31.77</bmi>
<message>Obesity</message>
<metric height="162.6 centimeter" weight="84 kilograms"/>
<imperial height="5 feet 4 inches" weight="185.19 pounds"/>
</self>
否则将是
<?xml version="1.0"?>
<response>
<bmi>31.77</bmi>
<message>Obesity</message>
<metric>
<height>162.6 centimeter</height>
<weight>84 kilograms</weight>
</metric>
<imperial>
<height>5 feet 4 inches</height>
<weight>185.19 pounds</weight>
</imperial>
</response>
更多用例和解释可以在这里找到
@class
当以意外格式定义时,它不应该抛出错误。我们将在下一个版本中修复它。