>  기사  >  PHP 프레임워크  >  Laravel을 사용하여 온라인 경매 시스템을 개발하는 방법

Laravel을 사용하여 온라인 경매 시스템을 개발하는 방법

WBOY
WBOY원래의
2023-11-02 13:51:311176검색

Laravel을 사용하여 온라인 경매 시스템을 개발하는 방법

오늘날의 디지털 시대에 경매 산업은 점차 온라인으로 옮겨가고 있습니다. 이러한 추세는 새로운 왕관 전염병으로 인해 더 높은 수준으로 추진되었으며 많은 전통적인 경매 회사가 온라인 경매를 시도하기 시작했습니다. 이를 달성하려면 강력하고 사용하기 쉬운 경매 시스템이 필요했습니다. 이 글에서는 Laravel 프레임워크를 사용하여 온라인 경매 시스템을 구축하는 방법을 소개합니다.

Laravel은 라우팅, 데이터베이스 마이그레이션, 대기열 등과 같은 많은 실용적인 기능을 제공하는 인기 있는 PHP 프레임워크입니다.

1. 준비

코드를 작성하기 전에 Laravel의 개발 환경과 필요한 몇 가지 종속 항목을 설치해야 합니다. 공식 Laravel 웹사이트에서 이 프로세스에 대한 자세한 지침을 찾을 수 있습니다. 다음은 몇 가지 간단한 단계입니다:

  • Laravel 설치

Composer를 사용하여 Laravel 프로젝트를 만들 수 있습니다. 콘솔에 다음 명령을 입력하세요:

composer create-project --prefer-dist laravel/laravel auction-system
  • Install dependency

프로젝트 디렉터리로 이동하여 다음 명령을 입력하여 모든 종속성을 설치하세요.

composer install
  • Configuration Database

.env 파일에서 수정 데이터베이스 연결 정보를 확인하려면 APP_KEY 필드를 애플리케이션 키로 설정하세요. 그런 다음 다음 명령을 실행하여 데이터베이스를 마이그레이션합니다.

php artisan migrate

2. 경매 항목 모델 구축 및 마이그레이션

모델은 Laravel의 핵심 개념으로 애플리케이션과 상호 작용하는 데이터베이스 테이블을 나타냅니다. 모든 온라인 경매 항목을 나타내는 경매 항목 모델을 만들어야 합니다. Laravel에서 모델은 데이터베이스 테이블을 생성하는 데 사용되는 마이그레이션과 일대일입니다.

경매 항목 모델 및 마이그레이션을 생성하려면 다음 명령을 사용하십시오.

php artisan make:model AuctionItem -m

이 명령은 AuctionItem.php 파일과 데이터베이스 마이그레이션 파일을 생성합니다. 마이그레이션 파일은 Database/migrations 디렉터리에 있고 모델 파일은 app/Models 디렉터리에 있습니다.

이전 파일에서 경매 품목의 데이터베이스 테이블을 정의해야 합니다. 생성된 마이그레이션 파일을 열고 up 메소드를 다음과 같이 수정합니다.

public function up()
{
    Schema::create('auction_items', function (Blueprint $table) {
        $table->id();
        $table->string('name');
        $table->text('description');
        $table->integer('starting_price');
        $table->integer('current_price');
        $table->dateTime('start_time');
        $table->dateTime('end_time');
        $table->timestamps();
    });
}

여기서 경매 항목의 모델을 정의하고 다음 필드를 추가합니다.

  • name: 경매 항목의 이름
  • description: 경매 항목에 대한 설명 경매 항목
  • starting_price: 경매 항목의 시작 가격
  • current_price: 경매 항목의 현재 가격
  • start_time: 경매 시작 시간
  • end_time: 경매 종료 시간

3. 경매 항목 인터페이스 및 컨트롤러 추가

이제 필요합니다. 이 애플리케이션은 새로운 경매 항목을 생성할 수 있는 인터페이스를 추가합니다. 이를 달성하기 위해 Laravel의 뷰와 블레이드 템플릿 엔진을 사용할 것입니다.

먼저 모든 경매 품목 관련 로직을 처리하는 컨트롤러를 만들어야 합니다. 다음 명령을 사용하여 컨트롤러를 생성합니다:

php artisan make:controller AuctionItemController --resource

이 명령은 AuctionItemController.php라는 컨트롤러 파일을 생성하고 기본 index(), create(), store(), show(), edit( ), update( ), destroy() 및 기타 메소드. 여기서는 create() 메소드를 사용하여 새 경매 항목 페이지를 처리해야 합니다.

AuctionItemController.php 파일을 열고 create() 메소드에 다음 코드를 추가하세요.

public function create()
{
    return view('auction_item.create');
}

이 메소드는 Auction_item/create.blade.php라는 뷰 템플릿을 렌더링하고 브라우저에 반환합니다.

이제 resources/views 디렉토리에 Auction_item이라는 폴더를 생성하고 그 안에 create.blade.php라는 파일을 생성해야 합니다. 다음 코드를 추가하세요.

@extends('layouts.app')

@section('content')
    <div class="container">
        <h1>Create New Auction Item</h1>

        <form action="{{ route('auction-item.store') }}" method="post">
            @csrf

            <div class="form-group">
                <label for="name">Name</label>
                <input type="text" class="form-control" name="name" id="name" required>
            </div>

            <div class="form-group">
                <label for="description">Description</label>
                <textarea name="description" id="description" class="form-control" rows="5" required></textarea>
            </div>

            <div class="form-group">
                <label for="starting_price">Starting Price</label>
                <input type="number" class="form-control" name="starting_price" id="starting_price" min="0" required>
            </div>

            <div class="form-group">
                <label for="start_time">Start Time</label>
                <input type="datetime-local" class="form-control" name="start_time" id="start_time" required>
            </div>

            <div class="form-group">
                <label for="end_time">End Time</label>
                <input type="datetime-local" class="form-control" name="end_time" id="end_time" required>
            </div>

            <button type="submit" class="btn btn-primary">Create</button>
        </form>
    </div>
@endsection

이 보기 파일은 새 경매 항목을 만드는 데 필요한 양식이 포함된 사용자 인터페이스를 렌더링합니다. 우리는 Laravel의 블레이드 템플릿 엔진을 사용하여 양식을 렌더링하고 Laravel의 경로와 컨트롤러를 사용하여 제출된 데이터를 처리했습니다.

4. 경매 항목 생성 라우팅 및 처리 로직 추가

이제 사용자가 제출한 양식 데이터를 처리하기 위한 경로를 추가해야 합니다. 경로/web.php 파일에 다음 라우팅 코드를 추가합니다:

Route::get('/auction-items/create', [AuctionItemController::class, 'create'])->name('auction-item.create');
Route::post('/auction-items', [AuctionItemController::class, 'store'])->name('auction-item.store');

이 경로는 POST 요청을 처리하기 위해 AuctionItemController 컨트롤러의 store() 메서드를 사용합니다.

AuctionItemController.php 파일을 열고 다음 코드를 추가하세요:

public function store(Request $request)
{
    $data = $request->validate([
        'name' => 'required',
        'description' => 'required',
        'starting_price' => 'required|numeric|min:0',
        'start_time' => 'required|date',
        'end_time' => 'required|date|after:start_time',
    ]);

    $auctionItem = new AuctionItem();
    $auctionItem->name = $data['name'];
    $auctionItem->description = $data['description'];
    $auctionItem->starting_price = $data['starting_price'];
    $auctionItem->current_price = $data['starting_price'];
    $auctionItem->start_time = $data['start_time'];
    $auctionItem->end_time = $data['end_time'];
    $auctionItem->save();

    return redirect()->route('auction-item.index');
}

이 메소드는 사용자가 제출한 양식 데이터의 유효성을 검사하고 데이터베이스에 저장하며 사용자를 경매 항목 목록 페이지로 리디렉션합니다.

5. 목록 페이지 및 경매 기능

이제 경매 항목 목록 페이지를 추가하고 여기에 몇 가지 기본 경매 기능을 구현해야 합니다. 우리는 Laravel의 블레이드 템플릿 엔진을 사용하여 HTML 페이지를 생성하고 Laravel의 컨트롤러를 사용하여 경매 관련 로직을 처리할 것입니다.

AuctionItemController.php에 다음 코드를 추가하세요:

public function index()
{
    $auctionItems = AuctionItem::all();

    return view('auction_item.index', compact('auctionItems'));
}

public function bid(Request $request, AuctionItem $auctionItem)
{
    $bidAmount = $request->input('bid_amount');

    if ($bidAmount <= $auctionItem->current_price) {
        return redirect()->back()->withErrors(['Bid amount should be greater than current price']);
    }

    $auctionItem->current_price = $bidAmount;
    $auctionItem->save();

    return redirect()->back()->with('success', 'Bid successful');
}

이 메소드는 경매 항목 목록을 렌더링하고 사용자의 입찰 요청을 처리하며 입찰을 데이터베이스에 저장합니다.

resources/views/auction_item 폴더에 index.blade.php라는 파일을 생성하고 다음 코드를 추가하세요.

@extends('layouts.app')

@section('content')
    <div class="container">
        <h1>Auction Items</h1>

        @foreach($auctionItems as $auctionItem)
            <div class="card mb-3">
                <div class="card-body">
                    <h5 class="card-title">{{ $auctionItem->name }}</h5>
                    <p class="card-text">{{ $auctionItem->description }}</p>
                    <p class="card-text">Starting Price: ${{ $auctionItem->starting_price }}</p>
                    <p class="card-text">Current Price: ${{ $auctionItem->current_price }}</p>
                    <form action="{{ route('auction-item.bid', $auctionItem) }}" method="post">
                        @csrf

                        <div class="form-group">
                            <label for="bid_amount">Your Bid</label>
                            <input type="number" class="form-control" name="bid_amount" id="bid_amount" min="{{ $auctionItem->current_price }}" required>
                        </div>

                        <button type="submit" class="btn btn-primary">Bid</button>
                    </form>
                </div>
            </div>
        @endforeach
    </div>
@endsection

이 보기 파일은 모든 경매 항목을 표시하고 입찰 요청을 처리하기 위한 양식을 제공합니다.

6. 완료

이제 기본적인 기능을 갖춘 온라인 경매 시스템을 구축했습니다. 사용자가 앱 홈페이지를 방문하면 모든 경매 품목 목록이 표시됩니다. 사용자는 경매 항목을 클릭하면 입찰 요청을 제출할 수 있는 경매 세부정보 페이지로 이동됩니다. 경매의 현재 가치는 각 입찰 후에 자동으로 업데이트되며, 경매가 종료되면 시스템은 자동으로 최고 입찰자에게 품목을 판매합니다.

이 과정에서 모델, 마이그레이션 파일, 경로, 컨트롤러, 뷰, 블레이드 템플릿 엔진 등 Laravel 프레임워크에서 제공하는 다양한 기능을 사용했습니다. 이러한 강력한 도구를 사용하면 완전한 기능을 갖춘 온라인 경매 시스템을 쉽게 만들 수 있습니다.

위 내용은 Laravel을 사용하여 온라인 경매 시스템을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.