laravel上传的图片没有添加到数据库中

时间:2015-01-15 01:42:11

标签: php mysql image file-upload laravel-4

我正在尝试在laravel上上传图片,但在某些时候它无法在数据库中设置图像目的地。

当我尝试测试并回显最终图像和链接目标时,一切正常,当我检查图像目的地时,我的目标文件夹图像就在那里,但只有图像不会在数据库中设置。

我在数据库中设置了这个字段

Name          Type           Collation         Attributes   Null    Default
avatarfull    varchar(500)   utf8_unicode_ci                 No       None

我将varchar增加到500以防万一。

并且在我的usercontroller上我有这个用于存储新用户

    public function store() {
    $validator = Validator::make(Input::all(), [
        'photo'             => 'mimes:jpeg,bmp,png|max:1000'
    ]);

    if($validator->fails()) {
        return Redirect::route('admin.users.create')->withErrors($validator)->withInput();
    } else {
        if(Input::hasFile('photo')) {
            if(Input::file('photo')->isValid()) {
                $imagename = str_random(20) . '.' . Input::file('photo')->getClientOriginalExtension();
                $imagelocation = Input::file('photo')->move(base_path() . '/img', $imagename );
                $avatarfull = 'img/' . $imagename;
            } else {
                $avatarfull     = 'img/profile_default.png';
            }
        } else {
            $avatarfull     = 'img/profile_default.png';
        }

        $create = User::create([
            'avatarfull'    => $avatarfull,
        ]);

        if($create) {
            return Redirect::route('admin.users.index')
                ->with('success_message', 'New user is successfully created!');
        }
    }

}

因此验证器会检查它需要检查的内容,如果图像是mime类型,并检查图像大小是否超过1mb,这是有效的。

进一步关于输入检查是否为上传设置了文件,如果文件设置为上传,它会检查文件是否有效,而不是获取图像,将其重命名为随机字符串,复制到正确位置并将$ avatarfull变量设置为正确在数据库中设置它的路径。

如果我

echo $avatarfull
or
print_r($avatarfull)
or
var_dump(Input::all())

我得到的所有数据都应该是正确的

var_dump显示输入字段的所有数据,并且有laravel通常的后端内容,例如检查文件类型,文件大小,将其存储在临时路径中,移动到新位置的路径。一切正常。

如果我检查结束$ avatarfull变量,就在我存储新用户$ avatarfull变量之前,如果图像上传而不是回声

img/random10characterstring.jpg

正确存储检查基本路径图像并将其移动到我电脑上的所需位置

/opt/lampp/htdocs/laravel/img/random10characterstring.jpg

结合使用link_to,它显示了url链接图像的最终结果

localhost/laravel/img/random10characterstring.jpg

当然,在我的文件浏览器中检查图像确实存在于该路径中。所以laravel完成了它的工作上传图像,重命名并移动到所需的位置。

只有它不会在数据库中设置字段。当我添加新用户(这是用户头像的图像字段)时,它在数据库中添加了新用户,并且我设置了数据库中的所有字段,除了我没有在数据库中设置图像的路径。出于某种原因,这个领域空白。

1 个答案:

答案 0 :(得分:1)

请检查您的用户模型中avatarfull是否为$ fillable数组。如果不是用户模型质量分配保护将不允许按Users::create(...)存储数据。 如果您不想将avatarfull放在可填充数组中,您可以随时使用:

$user = new User;
$user->avatarfull = $avatarfull;
$user->save();

有关质量分配的详细信息,请参阅:http://laravel.com/docs/4.2/eloquent#mass-assignment