首页
学习
活动
专区
圈层
工具
发布

从laravel 5表单中插入多个选定的值

可以通过以下步骤实现:

  1. 在前端页面中创建一个表单,使用HTML的<form>标签,并设置methodPOSTaction为处理表单的路由地址。
  2. 在表单中创建一个多选框,使用HTML的<select>标签,并设置multiple属性,以允许选择多个选项。
  3. 在多选框中添加选项,使用HTML的<option>标签,并设置value属性为每个选项的值,同时在标签内添加选项的显示文本。
  4. 在后端的路由文件中定义处理表单提交的路由,使用Laravel的路由定义语法。
  5. 在后端的控制器文件中编写处理表单提交的方法,可以通过请求对象$request获取表单提交的数据。
  6. 在处理方法中,使用Laravel的数据库查询构建器或ORM模型来插入多个选定的值到数据库中。

以下是一个示例的代码:

前端页面代码(例如,create.blade.php):

代码语言:html
复制
<form method="POST" action="/submit-form">
    @csrf
    <select name="selected_values[]" multiple>
        <option value="value1">Option 1</option>
        <option value="value2">Option 2</option>
        <option value="value3">Option 3</option>
    </select>
    <button type="submit">Submit</button>
</form>

后端路由定义(例如,web.php):

代码语言:php
复制
Route::post('/submit-form', 'FormController@submitForm');

后端控制器代码(例如,FormController.php):

代码语言:php
复制
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\YourModel; // 替换为你的模型类

class FormController extends Controller
{
    public function submitForm(Request $request)
    {
        $selectedValues = $request->input('selected_values');

        foreach ($selectedValues as $value) {
            YourModel::create(['column_name' => $value]);
        }

        return redirect('/success'); // 替换为你的成功页面路由
    }
}

在上述示例中,用户可以在前端页面中选择多个选项,然后提交表单。后端控制器会接收到选中的值数组,然后使用模型的create方法将每个选项的值插入到数据库中。最后,用户将被重定向到成功页面。

请注意,上述示例中的YourModelcolumn_name需要根据你的实际情况进行替换。此外,还需要根据你的项目配置和需求进行适当的调整。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Laravel5.2之Demo1——URL生成和存储

学习主题 该demo主要涉及如下几个知识点: 创建数据库并迁移数据表 创建表单,学习Laravel的blade模板引擎 创建名为Link的模型Model 保存数据进入数据库 从数据库中获得...在这里使用laravelcollective/html这个组件,顺便了解下怎么在laravel中安装组件。 这里书中使用了laravel4.*自带的Form类,但laravel5....;//根据输入的link做hash哈希就行或者别的更简短的输入值 } (4).向link数据表里插入一个新的记录record: else{ $newHash = Hash::make(Input...); 这里带上$newHash变量是为了后面捕获这个变量后,根据这个变量从数据表里查找对应的url值。...6、从数据库中取出URL并且重定向 最后根据生成的URL获取其hash部分,根据hash值从links数据表取出对应的URL为了重定向,这里英文原文也是在路由中写逻辑,这里也在路由里写逻辑: Route

25.9K31
  • laravel初次学习总结及一些细节

    最近学习了laravel,先简单谈谈学习的感受吧 刚开始一周多一点的时间先把laravel的开发文档看了一遍,,感觉刚开始接触时的感觉laravel的目录与thinkphp又不一样,它们的渲染模板的方式也不一样...在laravel的文档中,学到了门面(接口)和契约(接口),还知道了中间件,csrf保护和blade视图模板及laravel验证(过滤进入应用的 HTTP 请求提供了一套便利的机制) 在学习完laravel5.3...如果使用laravel5.3的模型的自动维护时间,,数据库的时间存储为时间戳timestamp或datetime类型,,如果存成int类型,则会出错 4.在blade模板中如果遇到解析不正确的话可以使用...5. 在laravel中如果出现了向后台提交数据不对的情况,一定要先检查是否向后台提交了 _token':'{{csrf_token() 6....在form表单提交checkbox时,,要将其name上加上 [],要不如果提交多个的话,,只能收到最后一个

    5.1K20

    30分钟用Laravel实现一个博客

    ---- 使用 Seeder 一次性完成多个数据库的批量虚拟数据插入 创建 Seeder (如果你处于 tinker, 【ctrl】+【c】 先退出) php artisan make:seeder UserTableSeeder...') }} => 我的博客 //注意这里有一个 config('app.name') 该函数其实是读取的 /.env 里的 APP_NAME 值,且默认值为 'Laravel' ,也就是说,你改 APP_NAME...Laravel提供了一种防范这种攻击的手段,即将自己的路由隐藏起来,只有带有 @csrf 声明的表单可以找得到接收表单信息的路由 编辑 BlogController@store public function...模型 的静态方法 create() 插入 $request->post() 数据即可 $blog = Blog::create($request->post()); //改方法的返回值是新插入的数据生成的对象...现在请告诉我,它是否配得上 “优雅” 的两字?:) 希望大家可以喜欢、学习和推广Laravel。如果您愿意付出比学习thinkphp5多0.01分的努力,我想这个框架是非常简单的。

    8.5K00

    Laravel5.2之Validator

    引言: Laravel提供了Validator模块,可解决表单提交验证等一些需求,并且可以在视图View中显示错误验证信息,交互还是很友好的。注明:作者水平有限,有错误或建议请指正,轻拍。...http://XXX/laravel/test/validator这个路由,其中XXX为你的host,可以是虚拟的host也可以是你的共有域名,则表单提交页面为: 3、写表单提交控制器 然后写上表单提交方法...4、写显示验证错误信息视图 在laravel中,laravel会在每次请求把errors变量刷到session中,和视图模板绑定,所以errors变量在视图模板中可用,官方文档原话:"So, it is...5、定制显示错误信息 错误信息是由laravel默认的,如果自定义显示错误信息,如: public function postValidator(Request $request){ /...如果针对对于多个页面的person.*.name都写同样的错误显示信息,可以在resources/lang/en/validation.php文件中做定制: 'custom' => [

    14.2K31

    The Clean Architecture in PHP 读书笔记(十)

    我们啊来建立我们的数据库sqlite3 database/database.sqlite,建表,插入数据。...此处我们需要几个功能 form filter,我们需要对post的表单进行验证 Hydrator,我们需要将输入的表单方便的赋值到我们的Entity的属性上 此处表单验证上,我们使用laravel的表单验证...总结 The Clean Architecture in PHP读书笔记写到这全部结束了,在这最后一篇中,我们以laravel为框架给出了示例,最核心的领域逻辑是纯的php class,不依赖于任何的框架...但是在使用laravel过程中,特别是repository这块,由于没有直接使用laravel的Eloquent模块,实现上确实比较麻烦,在实现CleanPhp\Invoicer\Persistence...\Eloquent\Repository下的类的时候,很多方法都比较tricky,而且可以想象的是,随着项目负责度的提升,这一块会成为程序员的梦靥,所以下一个系列我会去带领大家看看php中几大主流orm

    1.2K30

    laravel与thinkphp之间的区别与优缺点

    4、post传值中注意点不同 在Laravel框架里,由于其考虑到了跨站攻击,所以如果使用form表单以post方式进行传值时,如果不再form表单中加入{{csrf_field()}}则会报出TokenMethodnotfound...6、Laravel里内置了大量的方法供开发者使用 在实际应用中更接近于”让对象完成一切”的开发思想,比如在后台表单验证的时候,Laravel内置了大量的验证方法。...7、加密方式 在TP框架中,我们对用户名密码进行加密时使用md5();的方式进行加密。...但md5的缺点在于其可以逆向破解,而且在同等规则下同样的密码md5加密出的字符串是有可能出现相同的,这就降低其安全性。...无须担心,从github中pull下项目后在数据表里直接修改,只需要用: php artisan migrate:refresh 9、ORM 在介绍建表时已经使用了创建模型的命令: php artisan

    6.7K20

    Laravel和Thinkphp有什么区别,哪个框架好用

    4、post传值中注意点不同 在Laravel框架里,由于其考虑到了跨站攻击,所以如果使用form表单以post方式进行传值时,如果不再form表单中加入{{csrf_field()}}则会报出TokenMethodnotfound...6、Laravel里内置了大量的方法供开发者使用 在实际应用中更接近于”让对象完成一切”的开发思想,比如在后台表单验证的时候,Laravel内置了大量的验证方法。...7、加密方式 在TP框架中,我们对用户名密码进行加密时使用md5();的方式进行加密。...但md5的缺点在于其可以逆向破解,而且在同等规则下同样的密码md5加密出的字符串是有可能出现相同的,这就降低其安全性。...无须担心,从github中pull下项目后在数据表里直接修改,只需要用: php artisan migrate:refresh 9、ORM 在介绍建表时已经使用了创建模型的命令: php artisan

    7.2K20

    laravel ajax 解决报错419 csrf 问题

    Laravel(5以后)有个默认的CSRF middleWare,所有POST,PUT请求都会经过这个middleWare,看有没有csrf的token存在并且匹配,不存在的话就会抛出错误页面。...在Laravel的表单中,埋入一个就可以在表单请求的时候发出正确的token,这样就不会有问题了,而在ajax请求的时候呢,方法多多~ 1....如果你不是提交表单,那么就要考虑将token值放在一个什么地方,比如还是一个input中,然后ajax提交的时候去读取这个input,附在提交值中。 3....因为你总是要在页面的什么地方调用csrf_token()输出这个值,然后用js脚本获得这个值~ 我看Laravel源码的时候发现,Laravel默认会把CSRF_TOKEN的值写在一个叫XCRF-TOKEN...的cookie中,其实每次访问这个值都会发生变化,那我们只要用这个值就好了嘛,下面就是见证奇迹的时刻(好古老的梗): $.ajaxSetup({ headers: { '

    1.5K10

    程序猿必读-防范CSRF跨站请求伪造

    这就要求我们在请求中嵌入一些额外的授权数据,让网站服务器能够区分出这些未授权的请求,比如说在请求参数中添加一个字段,这个字段的值从登录用户的Cookie或者页面中获取的(这个字段的值必须对每个用户来说是随机的...在页面的表单中使用{{ csrf_field() }}来生成token,该函数会在表单中添加一个名为_token的隐藏域,该隐藏域的值为Laravel生成的token,Laravel使用随机生成的40个字符作为防范...参数的的值,这个值就是在前面表单中添加的csrf_field()函数生成的。...如果请求是异步的,那么会读取X-CSRF-TOKEN请求头,从请求头中读取token的值。...你可能注意到,这个检查过程中也会读取一个名为X-XSRF-TOKEN的请求头,这个值是为了提供对一些javascript框架的支持(比如Angular),它们会自动的对异步请求中添加该请求头,而该值是从

    3K20

    Laravel 5.5 的自定义验证对象类

    Laravel 中的表单验证是比较方便的,而且内置了大量的可用验证规则,但不管官方提供了多少,总还是会有满足不了需求的时候。...但在 Laravel 5.5 版本中,我们有了新的手段,只要定义一个实现 Illuminate\Contracts\Validation\Rule 接口的类即可实现自定义的验证规则,并可以直接使用。...; } }] ]); } 在验证的表单项为空值或者不存在的时候,对应的自定义验证规则不会执行。这个与系统自带的验证规则的逻辑是一致的。...如果你希望你的自定义验证规则,即使是在对应的表单项为空值时也被执行的话,那么只要把继承的接口从 rule 改成 ImplicitRule 即可: class IsOddValidationRule implements...ImplicitRule { ... } 采用 Laravel 5.5 新增的自定义验证类,可以更好地管理大量的自定义验证规则,而且在 PHPStorm 之类的 IDE 中,从验证代码里快速跳转到对应的验证类的代码也会更方便

    3.4K90

    跟我一起学Laravel-数据库操作和查询构造器

     查询操作 基本查询操作 使用sql语句执行select查询操作 从数据表中取得所有的数据列 从表中查询单行/列 从数据表中分块查找数据列 从数据表中查询某一列的列表 聚集函数 指定select查询条件...使用sql执行删除 基本删除操作 悲观锁 事务处理 查看日志记录 其它操作 在Laravel中执行数据库操作有两种方式,一种是使用\DB外观对象的静态方法直接执行sql查询,另外一种是使用Model类的静态方法...('email'); 从数据表中分块查找数据列 该方法用于数据表中有大量的数据的操作,每次从结果集中取出一部分,使用闭包函数进行处理,然后再处理下一部分,该命令一般用于Artisan命令行程序中处理大量数据...从数据表中查询某一列的列表 比如我们希望查询出角色表中所有的title字段值 $titles = DB::table('roles')->pluck('title'); foreach ($titles...,或者是跳过指定行数的结果(OFFSET),可以使用skip和take方法 $users = DB::table('users')->skip(10)->take(5)->get(); 插入操作 使用sql

    6.7K30

    通过 Laravel 创建一个 Vue 单页面应用(六)

    如果您需要跟上,我们在 第5部分  中停止了删除用户的功能,以及在成功删除后如何重定向用户。我们还研究了如何将 HTTP 客户机提取到一个专用模块中,以便在整个应用程序中重用。...以下是迄今为止的系列概要: 第1部分 – 设置项目和 Vue 路由器 第2部分 – 在 Vue 路由器中加载异步数据 第3部分 – 在 Laravel 中创建真实的用户端 第4部分 – 编辑用户 第5部分...我们尝试从返回值中拿到 message 属性或给予一个默认的错误信息。...这时你提交表单的话会在控制台看到带有 405 错误状态的错误信息。 添加 API 接口 我们准备在 Laravel 中添加 API 接口以创建新用户。这将类似于编辑现有用户。...这个教程带你了解了 Vue 中基础的 CRUD。 作为作业,你可以定义一个单独的用户表单组件来处理用户的新建和编辑(如果你认为它值得复用)。

    4.6K20

    Laravel Eloquent 模型关联关系(下)

    从性能上来说,渴求式加载更优,因为它会提前从数据库一次性查询所有关联数据,而懒惰式加载在每次查询动态属性的时候才会去执行查询,会多次连接数据库,性能上差一些(数据库操作主要开销在数据库连接上,所以在开发过程中如果想优化性能...注:实际开发中为了提高查询性能,我们往往是在 posts 表中冗余提供一个 comments_count 字段,每新增一条评论,该字段值加 1,查询的时候直接取该字段即可,从而提高查询的性能。...; }])->where('id', '5)->get(); 底层执行的 SQL 语句如下: select * from `posts` where `id` 5 and...>orderBy('created_at', 'desc'); }]); 关联插入与更新 一对多关联记录插入 新增关联模型的时候,可以在父模型上调用相应方法直接插入记录到数据库,这样做的好处是不需要指定关联模型与父模型的外键关联字段值...protected $touches = [ 'commentable' ]; 属性值是对应关联方法的名称,支持配置多个关联关系。

    21.8K30

    通过 Request 对象实例获取用户请求数据

    而作为最流行的 PHP 框架,Laravel 自然也是为处理用户请求提供了丰富的工具集,从收集、验证、到过滤、编排,可谓是一应俱全,接下来,我们将通过三四篇教程的篇幅来为你详细介绍如何在 Laravel.../form 路由的请求,同时在 URL 和请求表单中传入请求数据: ?...,我们还可以通过 input 方法值,该方法可以从所有请求方式中获取给定字段的值,所以更加通用: $id = $request->input('id'); $name = $request->input...'); 获取数组输入字段值 有的时候,我们在表单中传递给后端的可能是一个数组,比如一些复选框选中项,这些表单输入框的 name 值通常是 name[],如 books[],这个时候传递到后端的 books...获取 JSON 输入字段值 随着基于 JavaScript 的单页面应用(SPA)应用的流行,除了传统表单请求提交的 POST/GET 数据之外,JSON 格式的请求数据也越来越常见,Laravel 支持对

    20.9K30

    Laravel 表单方法伪造与 CSRF 攻击防护

    表单请求方法伪造 要告知 Laravel 当前提交的表单使用的是 GET/POST 之外的其他请求方式,需要在表单中添加一个名为 _method 的隐藏字段,字段值是「PUT」、「DELETE」或 「PATCH...Laravel 在处理提交表单请求时,会将字段值作为请求方式匹配对应的路由。...避免跨站请求伪造攻击的措施就是对写入操作采用非 GET 方式请求,同时在请求数据中添加校验 Token 字段,Laravel 也是这么做的,这个 Token 值会在渲染表单页面时通过 Session 生成...在 Laravel 中,和表单方法伪造一样,支持通过 HTML 表单隐藏字段传递这个值: Route::get('task/{id}/delete', function ($id) { return...会在每次请求都检查请求头中是否包含 X-CSRF-TOKEN,并检查其值是否和 Session 中的 Token 值是否一致。

    10.1K40

    通过 Laravel 表单请求类实现字段验证和错误提示

    在上一篇教程中,我们已经演示了如何在控制器方法中对表单请求字段进行验证,并且提到如果请求字段很多很复杂,都写到控制器方法里面会导致控制器臃肿,从单一职责原则来说需要将表单请求验证拆分出去,然后通过类型提示的方式注入到控制器方法...今天,我们就来实现这个拆分,Laravel 提供了表单请求类的功能帮助我们快速完成这一架构调整。...$request) { return response('表单验证通过'); } Laravel 底层在解析这个控制器方法的参数时,如果发现这个请求是一个表单请求类,则会自动执行其中定义的字段验证规则对请求字段进行验证...由于该表单请求类也是 Illuminate\Http\Request 的子类,所以后续获取请求字段值也可以通过 $request 来获取,将表单请求验证和请求实例参数合二为一,非常方便。...我们测试下表单请求,会发现和在控制器方法中通过 $this->validate() 验证字段的结果一样: ? 这样一来,以后我们就可以在表单请求类中维护字段验证逻辑了,完成了请求验证和控制器的解耦。

    4.7K30

    Laravel学习记录--request做文件上传

    Request 对象简单使用 在创建控制器时,lavarel会自动创建request对象 使用不需要实例化 在方法中的使用 function show(Request $rep){ } //...将Request 对象的返回值,覆给rep,如方法需要传参,直接在其后添加即可 什么时候使用?...Request的input()方法:字段自动注入,其值不是从form表单提交 如 $model->stu = $rep->input('0');//表单提交自动给stu赋予0 2.文件上传 $rep-...>file(‘input name名称’)->move(‘路径’,[可选指定图片名,不指定以原图片名存储]) 缺点:虽能上传,但访问较复杂 解决办法:使用laravel的文件存储系统 使用laravel...Request对象 use Storage; $path = Storage::putFile('磁盘名',$reg->file('文件名')) helper辅助函数 array_collapse();将多个数组折合成一个数组

    1.5K20

    PHP面试题集锦

    List(array)是用来快速把数组中的元素赋给一些变量。使用时要注意,array必须为一个索引数组,并且索引值从0开始。 get和post的区别?...1. get是从服务器上获取数据,post是向服务器传送数据。 2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。...5、负载均衡: Apache的最大并发连接为1500,只能增加服务器,可以从硬件上着手,如F5服务器。当然硬件的成本比较高,我们往往从软件方面着手。 php单例模式代码实现?...(重点看函数的‘参数’和‘返回值’) ①array()创建数组; ②count()返回数组中元素的数目; ③array_push()将一个或多个元素插入数组的末尾(入栈); ④array_column(...; ⑧in_array()检查数组中是否存在指定的值; PHP7 和 PHP5 的区别,具体多了哪些新特性?

    7.5K20
    领券