我正在尝试在CakePHP(1.3)应用中使用FileUpload
插件(https://github.com/webtechnick/CakePHP-FileUpload-Plugin)。
我有两个模型:PendingContract
和PendingContractFile
。 PendingContract
可以包含许多PendingContractFile
条记录。保存新PendingContract
时,我还要保存上传的PendingContractFile
;但是,我的保存方法失败,因为PendingContract
还没有ID,并且在我的PendingContractFile
中用作外键。
为清楚起见,这是我的模型:
<?php
class PendingContract extends AppModel {
var $name = 'PendingContract';
var $belongsTo = array(
'Supplier'
);
var $hasMany = array(
'PendingContractFile'
);
}
class PendingContractFile extends AppModel {
var $name = 'PendingContractFile';
var $belongsTo = array(
'PendingContract' => array(
'className' => 'PendingContract',
'foreignKey' => 'pending_contract_id'
),
'Author' => array(
'className' => 'User',
'foreignKey' => 'author_id'
)
);
}
这是我的控制器方法,我将保存PendingContract
:
<?php
class PendingContractsController extends AppController {
function add() {
if (!empty($this->data)) {
if ($this->FileUpload->success) {
$this->Session->setFlash('Pending contract successfully created.');
$this->redirect(array('action' => 'index'));
}
else {
$this->Session->setFlash($this->FileUpload->showErrors());
}
}
}
}
目前我得到的错误是:
1452:无法添加或更新子行:外键约束失败(pending_contract_files,CONSTRAINT pending_contract_files_ibfk_1 FOREIGN KEY(pending_contract_id)REFERENCES pending_contracts(id)ON DELETE CASCADE ON UPDATE CASCADE)
如何使用FileUpload
插件,以便使用我的新PendingContract
记录附加上传的文件?
答案 0 :(得分:0)
public function beforeSave($options = array()) {
if (!isset($this->data[$this->alias][$this->primaryKey])) {
$this->data[$this->alias][$this->primaryKey] = String::uuid();
}
return parent::beforeSave($options);
}
这将在保存之前为记录生成新的UUID。如果尚未设置密钥,则应该只执行此操作。
答案 1 :(得分:0)
我看了一下插件,看来它不会保存发布的数据和上传的文件。它有目的地将上传文件数据与表单中的任何其他输入分开,并为每个文件执行保存。
我个人会尝试其他插件,例如https://github.com/josegonzalez/upload,它们不依赖于任何控制器级代码。
答案 2 :(得分:0)
我有类似的问题,我所做的是在您的情况下添加新的PendingContractFile时取消设置验证。所以在saveAll方法之前尝试添加:
unset($this->PendingContract->PendingContractFile->validate['pending_contract_id']);
所以它不会检查foreign_key。 希望它有所帮助。