MySQL と Ruby を使用して簡単な電子商取引 Web サイトを開発する方法
電子商取引 Web サイトの開発は、最新のインターネット アプリケーションの重要な部分です。この記事では、MySQLとRubyを使って簡単なECサイトを開発する方法を紹介します。データベース設計、バックエンド ロジック、フロントエンド インタラクションについて説明し、具体的なコード例を示します。
まず、電子商取引 Web サイトに適したデータベースを設計する必要があります。データベース管理システムとして MySQL を使用し、次のテーブルを定義します:
MySQL でこれらのテーブルを作成するコードは次のとおりです:
CREATE TABLE User ( id INT AUTO_INCREMENT PRIMARY KEY, username VARCHAR(50) NOT NULL, password VARCHAR(50) NOT NULL, email VARCHAR(50) NOT NULL ); CREATE TABLE Product ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50) NOT NULL, price DECIMAL(10, 2) NOT NULL, stock INT NOT NULL ); CREATE TABLE Order ( id INT AUTO_INCREMENT PRIMARY KEY, user_id INT NOT NULL, product_id INT NOT NULL, quantity INT NOT NULL, FOREIGN KEY (user_id) REFERENCES User(id), FOREIGN KEY (product_id) REFERENCES Product(id) );
次に、Ruby を使用して実装します。バックエンドロジック。 Web フレームワークとして Sinatra を使用し、MySQL データベースと対話するために ActiveRecord を使用します。以下は、簡単なバックエンド コードの例です。
require 'sinatra' require 'sinatra/activerecord' # 配置数据库连接 set :database, {adapter: 'mysql2', host: 'localhost', database: 'ecommerce', username: 'root', password: 'password'} # 定义User模型 class User < ActiveRecord::Base has_many :orders end # 定义Product模型 class Product < ActiveRecord::Base has_many :orders end # 定义Order模型 class Order < ActiveRecord::Base belongs_to :user belongs_to :product end # 创建用户 post '/users' do user = User.create(params[:user]) if user.valid? {status: 'success', message: 'User created successfully'}.to_json else {status: 'error', message: user.errors.full_messages.join(', ')}.to_json end end # 创建商品 post '/products' do product = Product.create(params[:product]) if product.valid? {status: 'success', message: 'Product created successfully'}.to_json else {status: 'error', message: product.errors.full_messages.join(', ')}.to_json end end # 创建订单 post '/orders' do order = Order.create(params[:order]) if order.valid? {status: 'success', message: 'Order created successfully'}.to_json else {status: 'error', message: order.errors.full_messages.join(', ')}.to_json end end
上の例では、データベースと対話するための 3 つのモデル (ユーザー、製品、注文) を定義しました。ユーザー、製品、注文の作成リクエストを処理するために 3 つのルートを作成しました。
最後に、HTML、CSS、JavaScript を使用してフロントエンド インタラクションを実装します。簡単なフロントエンド コードの例を次に示します。
<!DOCTYPE html> <html> <head> <title>E-commerce Website</title> <link rel="stylesheet" type="text/css" href="style.css"> <script src="script.js"></script> </head> <body> <h1>Welcome to our E-commerce Website</h1> <form id="user-form" onsubmit="createUser(event)"> <input type="text" name="username" placeholder="Username" required> <input type="password" name="password" placeholder="Password" required> <input type="email" name="email" placeholder="Email" required> <button type="submit">Create User</button> </form> <form id="product-form" onsubmit="createProduct(event)"> <input type="text" name="name" placeholder="Product Name" required> <input type="number" name="price" step="0.01" placeholder="Price" required> <input type="number" name="stock" placeholder="Stock" required> <button type="submit">Create Product</button> </form> <form id="order-form" onsubmit="createOrder(event)"> <input type="number" name="user_id" placeholder="User ID" required> <input type="number" name="product_id" placeholder="Product ID" required> <input type="number" name="quantity" placeholder="Quantity" required> <button type="submit">Create Order</button> </form> <script src="http://code.jquery.com/jquery-3.5.1.min.js"></script> <script src="script.js"></script> </body> </html>
/* style.css */ input { margin-bottom: 10px; } button { margin-top: 10px; }
// script.js function createUser(event) { event.preventDefault(); $.ajax({ url: '/users', method: 'POST', data: $('#user-form').serialize(), success: function(response) { console.log(response); } }); } function createProduct(event) { event.preventDefault(); $.ajax({ url: '/products', method: 'POST', data: $('#product-form').serialize(), success: function(response) { console.log(response); } }); } function createOrder(event) { event.preventDefault(); $.ajax({ url: '/orders', method: 'POST', data: $('#order-form').serialize(), success: function(response) { console.log(response); } }); }
上の例では、ユーザー、アイテム、注文を作成するための簡単なフォームを作成しました。フォームが送信されると、データは Ajax リクエストを介してバックエンドに送信され、レスポンスがコンソールに表示されます。
概要:
この記事では、MySQL と Ruby を使用して簡単な電子商取引 Web サイトを開発する方法を紹介します。データベース設計、バックエンド ロジック、フロントエンド インタラクションについて説明し、具体的なコード例を示します。これらの例を学習することで、独自の電子商取引 Web サイトの開発を開始し、必要に応じて拡張およびカスタマイズできます。この記事があなたのお役に立てば幸いです!
以上がMySQL と Ruby を使用して簡単な電子商取引 Web サイトを開発する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。