Save file using blob
------------------
After [this articleAs a follow-up from the [How to upload a file using a model](http://www.yiiframework.com/wiki/2/how-to-upload-a-file-using-a-model/ "How to upload a file using a model")
wiki entry that explains how to save a file
into the filesystem,
here anthis article
forwill do the same using a blob field in
the database.
#### Edit the model
:
The first step is to change the model in order to self manage the file:[...]
class Candidate extends CActiveRecord
{
/**
* Property for receivi
ng the file from the form
* It should be different fro
nm any other field in
the database
*/
public $uploadedFile;
public function rules()
{
return array(
{
return array(
array('uploadedFile', 'file', 'types'=>'jpg, gif, png'),
);
);
}
/**
*
s Saves the name, size
,
type and data of the uploaded file
*/
public function beforeSave()
{
if($file=CUploadedFile::getInstance($this,'uploadedFile'))
{
$this->file_name=$file->name;
$this->file_type=$file->type;
$this->file_size=$file->size;
$this->file_content=file_get_contents($file->tempName);
}
return parent::beforeSave();
;
}
}
```
Do not forget to give a rule for this attribute
, because as it has to be safe. Is also a good practice to delete any rule refer
ring
to the other 4 fields (file_name, file_type, file_size, file_content),
becauseas they are not supposed to be modified by massively assigned inputs.
###
# Edit the view:
In the view we can put:
```php
<div class="row">[...]
### Displaying images:
For show theIn the view we put the code:
```php
<? echo CHtml::link(my_link_name,array('displaySavedImage','id'=>$model->primaryKey)); ?>
```
So it generates link like http://myserver/yii/myapp/index.php?r=candidate/displaySavedImage&id=1
Where Candidate is current model.
To show saved image we can write an action
:
in Controller:
```php
/**
*
Displays the preview of the photoOpens the dialog in browser to open/save the image.
*/
public function actionDisplay
SavedImage()
{
$model=$this->loadModel(
);
header('Content-Type: '.$model->file_type);
$_GET['id']);
header('Pragma: public');
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Content-Transfer-Encoding: binary');
header('Content-length: '.$model->file_size);
header('Content-Type: '.$model->file_type);
header('Content-Disposition: attachment; filename='.$model->file_name);
echo $model->file_content;
}
```
Note *$_GET\['id'\]* as passed argument of loadModel function.