0

我不能使用任何宝石在 Rails 中创建干净的 Url。相反,我正在推出自己的实现。我在 routes.rb 中创建了以下条目

match "/:slug" => "cleanurls#index"

其中 cleanurl 是处理所有此类请求的控制器。在 cleanurl 控制器中:

class CleanurlsController < ApplicationController


 def index

  slug  = params['slug']

  url = Url.where(:slug => slug).first

  case(url.url_type) 

       when 'profile'

                 user_id = url.id.to_i
                 @profile = Profile_info.getProfileDetails(user_id)
                 render '/profiles/index'
       end

 end

end

我创建了urls存储slug, id(相关)和type of page. 现在我只有个人资料页面要处理,但将来我将拥有不同类型的页面,这些页面具有干净的 url。

我的第一个问题:

1)这个实现是正确的方法吗?鉴于表具有所有正确的索引,从性能角度来看这是否可行。

我正在制作这样的个人资料网址:

    def self.makeProfileUrl(id,name)

     name = name.strip.titleize

     extension = User.where(:name => name).count - 1

     slug = name.split(" ").join("-")

     if extension != 0
        slug += "-#{extension}"
     end

        Url.create(:slug => slug, :id => id.to_i, :url_type => 'profile')

   end

我正在使用扩展名来追加计数,以防他们是共享相同名称的用户。

问题:

这是创建蛞蝓并确保其独一无二的正确方法吗?从另一个表中获取名称的计数似乎不正确。

4

1 回答 1

1

回答问题#1:

我不知道您的总体目标的详细信息,但如果您希望拥有基于数据库记录的此类 URL - 那么是的:这是一个好方法。

回答问题 #2(关于蛞蝓):

我宁愿使用更精细且经过良好测试的东西,例如: https ://github.com/norman/friendly_id

我对其他一些事情的 50 美分:

这是您在 Ruby/Rails 中的第一个项目吗?如果是这样 - 恭喜!:) 我问是因为我注意到你在这里和那里使用骆驼案......

还:

user_id = url.id.to_i

为什么在这里调用这个#to_i 方法?您是否将此 id 设置为字符串或其他内容?

希望这可以帮助

于 2013-10-22T07:30:52.053 回答