前言:
之所以将网址改成秘密的乱码序号,是因为在实际生活中我们不希望别人别人看到一些关键信息。
典型的比如,购物平台的订单流水号,商家是不希望自己的成交量被对手猜到,因此需要把订单的id改成乱码序号。
实作步骤:
- 在订单order model中添加新的栏位token,用来存放订单乱码序号
终端执行:
rails g migration add_token_to_order
在新生成的migration文件中,加入下列代码:
class AddTokenToOrder < ActiveRecord::Migration[5.0]
def change
+ add_column :orders, :token, :string
end
end
然后执行rails g migrate
- 在order model中建立生成乱码序号的方法generate_token,
class Order < ApplicationRecord
+ def generate_token
+ self.token = SecureRandom.uuid
+ end
- 修改order model,添加before_create,设定乱码序号是在订单order生成前产生
+ before_create :generate_token
...略
- 重导网址
class OrdersController < ApplicationController
before_action :authenticate_user!,only: [:create] #用户必须登录才能结账生成订单
def create
@order = Order.new(order_params) #新建order对象
@order.user = current_user #order的所有者为当前登录用户
if @order.save
- redirect_to order_path(@order)
+ redirect_to order_path(@order.token) #重导至带有乱码序号的订单order路径
else
render 'carts/checkout'
end
end
def show
- @order = Order.find(params[:id])
+ @order = Order.find_by_token(params[:id]) #通过乱码id找到相应的订单order
end
private
def order_params
params.require(:order).permit(:billing_name,:billing_address,:shipping_name,:shipping_address)
end
end
总结:
(1)before_create是Rails model内建的回呼方法,目的是让资料在生成前先执行某个动作。
本例中我们让订单order生成前,先生成乱码序号
(2)SecureRandom.uuid 是 Ruby 内建的随机生成器,它是本例中为订单order生成乱码序号的方法
(3)通过这两点,同样可以为其他的资料产生乱码序号,来对网址进行加密