【问题标题】:save info of contact form in database in laravel在 laravel 的数据库中保存联系表格的信息
【发布时间】:2017-12-28 07:28:19
【问题描述】:

我正在使用 laravel 5.4。

我尝试在我的网站上进行销售部分(商店),对于我需要销售的物品我不想使用常规方式!

这是什么意思?通常在商业网站上,当您开始订购产品时,您会去某个名为购物车的地方,那里有所有的计算,您付款就完成了。

对我来说,我尝试通过联系表格获取信息,每个项目里面都有一个表格,用户填写表格,然后用户和产品的数据将通过电子邮件发送给管理员到目前为止一切正常,但我也想保存这些数据通过电子邮件在其他表格中以Order_table 发送,并在他们的面板中向用户显示他们已被要求购买这些物品以及这些物品是否已付款。

问题: 如何将这些数据保存在表格中,包括用户选择数量的价格总和?

这是我的商品页面中的表单:

<form class="form-horizontal" action="{{route('ask_product')}}" method="POST"  id="contact_form">
            {{ csrf_field() }}

            <div class="form-group">
              <label class="col-md-3 control-label">UserName</label>
              <div class="col-md-9 inputGroupContainer">
                <div class="input-group">
                  <span class="input-group-addon"><i class="fa fa-user"></i></span>
                  <input  name="username" value="{{ Auth::user()->username }}" class="form-control"  type="text" readonly>
                </div>
              </div>
            </div>

            <!-- Text input-->
            <div class="form-group">
              <label class="col-md-3 control-label">E-Mail</label>
                <div class="col-md-9 inputGroupContainer">
                <div class="input-group">
                    <span class="input-group-addon"><i class="fa fa-envelope"></i></span>
                    <input name="email" value="{{ Auth::user()->email }}" class="form-control"  type="text" readonly>
                </div>
              </div>
            </div>

            <div class="form-group">
              <label class="col-md-3 control-label">Product</label>
              <div class="col-md-9 inputGroupContainer">
                <div class="input-group">
                  <span class="input-group-addon"><i class="fa fa-product-hunt"></i></span>
                  <input  name="product" value="{{ $product->title }}" class="form-control"  type="text" readonly>
                </div>
              </div>
            </div>

            <div class="form-group">
              <label class="col-md-3 control-label" for="type">Quantity</label>
              <div class="col-md-9 inputGroupContainer">
                <div class="input-group">
                  <span class="input-group-addon"><i class="fa fa-file-code-o"></i></span>
                  <select class="form-control" id="type" name="quantity">
                    <option value="">Select Quantity</option>
                    <option value="1">1</option>
                    <option value="2">2</option>
                    <option value="3">3</option>
                    <option value="4">4</option>
                    <option value="More than 5">More than 5</option>
                  </select>
                </div>
              </div>
            </div>

            <div class="form-group">
              <label class="col-md-3 control-label">Note to seller</label>
              <div class="col-md-9 inputGroupContainer">
                <div class="input-group">
                  <span class="input-group-addon"><i class="fa fa-commenting-o"></i></span>
                  <textarea name="note" id="text" placeholder="Your note to seller here..." class="form-control" rows="8" ></textarea>
                </div>
                <h6 class="pull-right" id="count_message"></h6>
              </div>
            </div>

            <div class="text-center">
              <input type="submit" class="btn btn-block btn-success" value="Send">
            </div>
        </form>

这是表单验证器和电子邮件发件人:

public function ask() {
      return view('frontend.shopsingle');
    }

    public function postask(Request $request) {
      $this->validate($request, array(
        'username' => 'required',
        'email' => 'required|email',
        'product' => 'required',
        'note' => 'required|min:10|max:500',
        'quantity' => 'required',
      ));

      $data = array(
        'username' => $request->username,
        'email' => $request->email,
        'product' => $request->product,
        'note' => $request->note,
        'quantity' => $request->quantity,
      );

      Mail::send('emails.ask', $data, function($message) use ($data) {
        $message->from($data['email']);
        $message->to('robertnicjoo@outlook.com');
        $message->subject($data['product']);
      });

      Session::flash('flash_message', 'Your Order was sent. Our sell team will contact you shortly.');
      return redirect()->back();

    }

这是我的表格路线:

    Route::get('/ask', 'ContactController@ask')->name('ask_product');  

Route::post('/ask', 'ContactController@postask');

【问题讨论】:

  • 为什么你使用get的路由,而你的表单方法是POST
  • 在表单和路由文件中检查您的路由操作。

标签: php mysql forms laravel


【解决方案1】:

验证后,您可以编写代码将数据存储到表中

DB::table('Order_table')->insert(
    ['username' => $request->username,
    'email' => $request->email,
    'product' => $request->product,
    'note' => $request->note,
    'quantity' => $request->quantity]
);

【讨论】:

    【解决方案2】:

    如果您使用 ORM,它会/可能看起来很简单:(取决于您的 laravel 设置)

    $order = Orders::create($request->all());
    

    【讨论】:

    • 那么对价格求和呢?以及我将如何告诉将其保存在哪个表中?
    • 订单链接到表“订单​​”。这就是 ORM 的工作原理。您可以即时汇总总价格。所以,当查看给用户。比如:echo $order->quantity * $product->price; (例如)
    • @RobertNicjoo 您可以在此处阅读 ORM 的工作原理。 Laravel 的 Eloquent 模型 laravel.com/docs/5.4/eloquent.
    【解决方案3】:

    使用:

    $order = Orders::create($request->all());
    

    您可以在不单独传递的情况下接收所有输入表单并将其保存到订单表中。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-03-18
      • 1970-01-01
      • 2017-09-16
      • 2021-04-01
      • 2020-08-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多