基本上是在尝试创建一个收件箱消息,其中"读取详细信息"应将用户重定向到自定义控制器,但是我可以在浏览器中看到所需的 url 一秒钟,然后它重定向到仪表板; 这就是目前我试图实现这一目标的方式:
$myId = $myJson['id'];
$title = "Title of my notice";
$description = $myJson['text'];
$url= Mage::helper("adminhtml")->getUrl('My_Module/Controller/index', array('id' => $myId));
$sendingMessage = Mage::getModel('adminnotification/inbox')->addNotice($title,$description,$url);
上面的代码成功地将消息添加到收件箱,但是正如我之前所说,我可以在浏览器中看到所需的 URL,然后再将其重定向到仪表板。
我正在从另一个控制器访问同一个控制器,它按预期执行,实际工作的控制器是一个网格,它看起来像这样:
$this->addColumn('action',
array(
'header' => __('Answer'),
'width' => '100',
'type' => 'action',
'getter' => 'getId',
'actions' => array(
array(
'caption' => __('Answer'),
'url' => array('base'=> '*/Controller'),
'field' => 'id'
)),
'filter' => false,
'sortable' => false,
'index' => 'stores',
'is_system' => true,
));
那么,我在这里错过了什么吗?
顺便说一句,有没有办法使"阅读详细信息"链接在同一页面而不是新选项卡中打开?
====
======================================================================更新
禁用安全选项中的"将密钥添加到 URL"允许我让它工作,但是我想使用密钥。
我在第一个代码块中生成的 URL 实际上在 URL 中有一个键/值,它们看起来像这样:
https://example.com/index.php/mymodule/Controller/index/id/3963566814/key/f84701848a22d2ef36022accdb2a6a69/
您似乎正在尝试生成管理员 URL。 在Magento的现代版本中,管理员URL必须使用Magento前端名称共享技术(本文中所述)使用adminhtml
前端名称。 这是必须的,因为如果您不这样做,URL 将不起作用。 Magento删除了在后端创建非adminhtml URL的功能。
其次,这是Magento生成密钥的地方。
#File: app/code/core/Mage/Adminhtml/Model/Url.php
public function getSecretKey($controller = null, $action = null)
{
$salt = Mage::getSingleton('core/session')->getFormKey();
$p = explode('/', trim($this->getRequest()->getOriginalPathInfo(), '/'));
if (!$controller) {
$controller = !empty($p[1]) ? $p[1] : $this->getRequest()->getControllerName();
}
if (!$action) {
$action = !empty($p[2]) ? $p[2] : $this->getRequest()->getActionName();
}
$secret = $controller . $action . $salt;
return Mage::helper('core')->getHash($secret);
}
这是它验证密钥的地方
#File: app/code/core/Mage/Adminhtml/Controller/Action.php
protected function _validateSecretKey()
{
if (is_array($this->_publicActions) && in_array($this->getRequest()->getActionName(), $this->_publicActions)) {
return true;
}
if (!($secretKey = $this->getRequest()->getParam(Mage_Adminhtml_Model_Url::SECRET_KEY_PARAM_NAME, null))
|| $secretKey != Mage::getSingleton('adminhtml/url')->getSecretKey()) {
return false;
}
return true;
}
比较$secret
的前/后哈希值,看看为什么Magento在您的页面上生成了不正确的密钥。