Php Yii:禁用对控制器/操作的直接访问,仅在路由到时有效

Php Yii:禁用对控制器/操作的直接访问,仅在路由到时有效,php,yii,url-routing,Php,Yii,Url Routing,我想在中禁用对控制器/操作的直接访问,例如登录/get,并且仅当路由到时才可访问 在我的配置中,根据HTTP方法,我将登录请求路由到登录/获取和登录/发布: 'urlManager' => array( 'urlFormat' => 'path', 'showScriptName' => false, 'caseSensitive' => false, 'rules' => array( // Rewrite GET

我想在中禁用对控制器/操作的直接访问,例如登录/get,并且仅当路由到时才可访问

在我的配置中,根据HTTP方法,我将登录请求路由到登录/获取登录/发布

'urlManager' => array(
    'urlFormat' => 'path',
    'showScriptName' => false,
    'caseSensitive' => false,
    'rules' => array(
        // Rewrite GET requests of "login" to "login/get", and POST requests to "login/post".
        array('login/post', 'pattern' => 'login', 'caseSensitive' => false, 'verb' => 'POST'),
        array('login/get',  'pattern' => 'login', 'caseSensitive' => false, 'verb' => 'GET'),
    ),
),
是否有任何配置设置来禁止请求登录/get登录/post,或者最好的方法是将这些请求路由到错误/404之类的地方?例如:

array('error/404',  'pattern' => 'login/(get|post)(/.*)?')

你自己的解决方案很好用, UrlManager从上到下请求规则,因此它将首先尝试GET/POST

因此,完整的答案是

'rules' => array(
    // Rewrite GET requests of "login" to "login/get", and POST requests to "login/post".
    array('login/post', 'pattern' => 'login', 'caseSensitive' => false, 'verb' => 'POST'),
    array('login/get',  'pattern' => 'login', 'caseSensitive' => false, 'verb' => 'GET'),
    'login/post'=>'error/404',
    'login/get'=>'error/404',
),
你可以使用你给正则表达式的规则

array('error/404',  'pattern' => 'login/(get|post)(/.*)?'

您的404重定向解决方案对我来说似乎是个好主意,您不喜欢这个解决方案中的什么?似乎应该是错误400而不是404如果这是最好的方法,那么这就是我将使用的方法。我只是想知道是否已经有这样做的功能,我没有不必要地在客户控制器中重复错误。谢谢你为我澄清:)