14

我有这个功能:

/**
 * @Secure(roles="IS_AUTHENTICATED_FULLY")
 * @Route("/chequearFabricanteDistribuidor", name="chequearFabricanteDistribuidor", condition="request.headers.get('X-Requested-With') == 'XMLHttpRequest'")
 * @Method("GET")
 */

public function chequearFabricanteAction(Request $request)
{
    $em       = $this->getDoctrine()->getManager();
    $entities = $em->getRepository('AppBundle:FabricanteDistribuidor')->findOneBy(
        array( 'nombre' => $request->query->get('fabricante')['nombre'] )
    );

    $response['valid'] = true;

    if ($entities) {
        $response['valid'] = false;
    }

    return new JsonResponse($response);
}

该函数需要从两种不同的形式调用,唯一不同的是保存该值的请求变量。第一种形式是:$request->query->get('fabricante')['nombre']而第二种形式是,$request->query->get('distribuidor')['nombre']所以我问是否正确的处理方法是:

if (isset($request->query->get('fabricante'))) 
{
   $nombre = $request->query->get('fabricante')['nombre'];
}
else
{
   $nombre = $request->query->get('distribuidor')['nombre'];
}

这是正确的吗?有更好的吗?

4

1 回答 1

30

正如 Cerad 在回复中发布的那样,您可以使用:

$request->query->has('distribuidor')
于 2016-09-29T01:05:33.347 回答