首页 >后端开发 >php教程 >Laravel 5.1 表单提交数据(包含数组)插入数据库错误解决办法

Laravel 5.1 表单提交数据(包含数组)插入数据库错误解决办法

WBOY
WBOY原创
2016-07-23 08:54:431372浏览

当表单中有需要提交数组到数据库,比如要加一些客服QQ的信息,Laravel 会抛出输入的字段不能为数组的错误,解决办法也很简单。

增加多个QQ客服需要用到数组

Laravel 5.1 表单提交数据(包含数组)插入数据库错误解决办法

抛出的错误

  1. ErrorException in helpers.php line 671:preg_replace(): Parameter mismatch, pattern is a string while replacement is an array
复制代码

解决办法:

模型中把需要提交的字段“阻止”,在控制器中单独用Input接收并将其序列化,然后再进行保存就可以了。

模型示例:

  1. class Shop extends Model
  2. {
  3. public $timestamps=false;
  4. protected $guarded = ['qq','submit'];
  5. }
复制代码

控制器示例

  1. public function store(CheckNameRequest $request)
  2. {
  3. $shop = Shop::create(Input::get());
  4. $shop->qq = serialize(Input::get('qq'));
  5. $shop->save();
  6. }
复制代码

同理,在显示的时候将其反序列化即可。

原文地址:http://note.mango.im/article/24

解决办法, Laravel


声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn