1

我正在开发我的第一个 Laravel 4 项目,并使用雄辩的 ORM 使用路由从数据库中检索行。例子:

这是一条路线:

Route::get('{publisher}/{series}', function($publisher, $series)
{
$result = Comic::where('publisher', '=', $publisher)
->where('series', '=', $series)
->orderBy('issue', 'asc')
->get();

return View::make('comic')
->with('result', $result); 
});

这应该与 site.com/marvel/amazing-spider-man 之类的网址匹配

现在它只适用于 site.com/marvel/amazing spider-man 或 site.com/marvel/amazing%20spider-man

如何确保只使用“-”网址?我相信我需要做的是:

一个。编写在路由期间将“-”替换为 %20 的代码 b. 编写在 url 生成期间用“-”替换 %20 的代码

另一个考虑是我真的不希望我的内容在两个 url 上都可以访问。

4

4 回答 4

5

我认为你没有得到你期望的结果的原因是因为“系列”名称存储在数据库中的格式,记住这是在寻找一个完全匹配,所以如果你想检索结果:

http://www.site.com/marvel/amazing-spider-man

您需要将其作为“amazing-spider-man”存储在数据库中以避免删除破折号 (-) 的额外步骤,如果您不喜欢这种格式,那么您可以执行以下操作:

$series = str_replace('-', ' ', $series); 

这将删除破折号,但请注意不要在名称中使用破折号,因为它们会被删除,现在您可以将系列名称作为“神奇蜘蛛侠”存储在数据库中。

于 2013-09-29T16:53:10.633 回答
2

->with('result', Str::slug($result));

  • Str::slug(字符串 $title, 字符串 $separator = '-')

http://laravel.com/docs/4.2/helpers#strings

于 2015-03-13T10:36:19.897 回答
0

这是 Laravel 的解决方案。

use Str;
use Carbon\Carbon;

$start_at = Str::replace('-', '/', '12-28-2021');
Carbon::parse($start_at);
于 2021-12-30T04:43:41.430 回答
0

截至 2021 年,这是此类问题的第一个谷歌结果,有些人可能会欣赏我对这个案例的解决方案,因为这在今天仍然很重要。

我使用公共*.csv文件将国家和城市保存在我的数据库中。因此,有些条目带有破折号和空格,例如 OP 的问题。

此外,就像 OP 在他的评论中提到的那样,他将不得不重命名他的所有数据库条目。

因此,我对这个问题有一个很好的解决方案:

  1. 确保您的所有链接都带有下划线而不是空格,以提高可读性(也提高了 SEO),例如:

$slug = str_replace(' ', '_', $this->country); // "United%20States" will be "United_States"

  1. 打开您的 MySQL 控制台,并使用以下命令将每个空格替换为下划线:

UPDATE locations SET country = replace(country, ' ', '_');

这样,带有连字符 ( -) 的条目仍将保留在您的数据库中,并且所有其他带有空格的条目都将有一个下划线以完全匹配。您还改进了 SEO 和 URL 可读性。

于 2021-08-02T21:38:59.010 回答