ZF2形式验证(zfcAdmin和BjyAuthorize相关)(zf2 form validati

2019-10-17 22:37发布

我现在面临整合在zfcAdmin和BjyAuthorize我的自定义模块验证问题。

我的窗体类:

...    
$formOptions = $this->settings->getFormSettings();
foreach ($formOptions as $field){
if (isset($field['field']))
    $this->add($field['field']);        
}
...

我的过滤器类:

$formOptions = $this->settings->getFormSettings();
foreach ($formOptions as $filter){
if (isset($filter['filter']))
    $this->add($filter['filter']);   
}
...

字段,过滤器和其他选项从配置文件检索。

基本上一切正常:表格数据可以添加,编辑或从数据库中删除。 另外,zfcAdmin模块安装后没有问题的上涨。 一切都同时使用“网站/ MyModule的”路线和“网站/管理/ MyModule的”路线工作正常:我仍然可以添加,编辑和删除数据库项目。

这里的问题:我需要一些表单元素(在这个特定的情况下选择)编辑/查看只能由管理员。 (我可以写管理一个新的控制器/实体类“特设”,但我想使用相同的代码对整个网站。)

我安装和配置bjyoungblood / BjyAuthorize模块:它让我展示一些表单元素/但是当我在编辑模式下是显示的字段只管理一个表单验证错误:“值是必需的,不能为空”

这里的代码:

//view/mymodule/mymodule/update.phtml
<div id="page" style="margin-top: 50px;">

<?php if (isset($this->messages) && count($this->messages) > 0 ): ?>
<?php foreach ($this->messages as $msg): ?>
<div class="alert alert-<?php echo $this->escapeHtmlAttr($msg['type']); ?>">
    <?php if (isset($msg['icon'])) echo '<i class="'.$this->escapeHtmlAttr($msg['icon']).'"></i>&nbsp;'; ?><?php echo $this->escapeHtml($msg['message']); ?>
</div>
<?php endforeach; ?>
<?php endif; ?>

<?php
$title = 'Edit Item';
$this->headTitle($title);
?>
<h1><?php echo $this->escapeHtml($title); ?></h1>

<?php
$form = $this->form;
$form->setAttribute('action', $this->url($this->route . 'mymodule/update', array('action' => 'update', 'id' => $this->id )));
$form->prepare();
$form->setAttribute('method', 'post');
$input = $form->getInputFilter();

?>

<?php echo $this->form()->openTag($form) ?>
<dl class="zend_form">
    <?php foreach ($form as $element): ?>

        <?php
            //CHECK USER PRIVILEDGES
            $elName = $element->getName();
            $elResource = isset($this->form_options[$elName]['auth']) ? $this->form_options[$elName]['auth']['resource'] : "userresource"; 
            $elPrivilege = isset($this->form_options[$elName]['auth']) ? $this->form_options[$elName]['auth']['privilege'] : "view";

            //SHOW THE ELEMENT IF ALLOWED
            if($this->isAllowed($elResource, $elPrivilege)): 
        ?>
            <?php if ($element->getLabel() != null): ?>
                <dt><?php echo $this->formLabel($element) ?></dt>
                <?php endif ?>
            <?php if ($element instanceof Zend\Form\Element\Button): ?>
                <dd><?php echo $this->formButton($element) ?></dd>
                <?php elseif ($element instanceof Zend\Form\Element\Select): ?>
                <dd><?php echo $this->formSelect($element) . $this->formElementErrors($element) ?></dd>
                <?php else: ?>
                <dd><?php echo $this->formInput($element) . $this->formElementErrors($element) ?></dd>
                <?php endif ?>
           <?php else: ?>
           <?php        

           ?>          
        <?php endif ?> 

    <?php endforeach ?>
</dl>
<?php echo $this->form()->closeTag() ?>


</div>
<div class="clear-both"></div>

我的控制器动作

//controller
        public function updateAction(){
            $messages = array();
            $id = (int)$this->getEvent()->getRouteMatch()->getParam('id');
            $form = $this->getServiceLocator()->get('FormItemService');

            $itemMapper = $this->getItemMapper();
            $item = $itemMapper->findById($id);
            $form->bind($item);

            $request = $this->getRequest();

            if($request->isPost()){
                $form->setData($request->getPost());
                if ($form->isValid()) {             
                    die('c');//never here
                    $service = $this->getServiceLocator()->get('mymodule\Service\Item');
                    if ( $service->save($form->getData()) )
                    {
                        $messages[] = array(
                                'type'    => 'success',
                                'icon'    => 'icon-ok-sign',
                                'message' => 'Your profile has been updated successfully!',
                        );
                    }
                    else
                    {
                        $messages[] = array(
                                'type'    => 'error',
                                'icon'    => 'icon-remove-sign',
                                'message' => 'Profile update failed!  See error messages below for more details.',
                        );
                    }
                }else{
                    var_dump($form->getMessages());//Value is required and can't be empty
                }
            }

            return array(
                'messages' => $messages,    
                'form' => $form,
                'id' => $id,    
                'form_options' => $this->getServiceLocator()->get('mymodule_module_options')->getFormSettings(),
                'route' => $this->checkRoute($this->getEvent()->getRouteMatch()->getmatchedRouteName())
            );
        }

如果不允许用户查看的资源,该元素是不回应。 所以$请求 - >的getPost()拥有该表单元素没有价值,并通过isValid方法返回一个错误()。

有没有人解决了类似的问题,或者任何人都可以点我朝着正确的方向? 谢谢

Answer 1:

问题是,你在哪里,你定义所需的字段不做你FormFilter类,任何安全检查。

的形式 - $> isValid()的函数检查对那些过滤元件的发布数据。 因此,这不足以防止视图中的“回声场”,你仍然需要安全检查适用于滤芯。



Answer 2:

另一种方法是使两种形式之一的前端和一个用于管理。 由于一个管理员将具有相同的字段加一个额外的选择字段可以使管理员状延伸的前端之一。 例如

class myForm 
{
    public function __construct(...) 
    {
         // add fields and set validators
    }
}

和管理形式可以是:

class MyAdminForm extends myForm
{
    public function __construct(...)
    {
        parent::__construct(...);
        // add the extra field and extra validator
    }
}

在即使编辑前端的形式(或验证)这样的后端将永远是最新的。

希望这可以帮助 :),

斯托扬



文章来源: zf2 form validation (zfcAdmin and BjyAuthorize related)