dongqing5925 2014-07-22 20:53
浏览 1003
已采纳

在Laravel中转义whereRaw查询

I'm trying to do a fulltext search on one of my MySQL database tables in Laravel. I have my search controller looking like this: class SearchController extends \BaseController {

public function postSearch()
{
        if (Input::has('search')) {
            $q = Input::get('search');
            $q = urlencode($q);
            return Redirect::to('/search/'.$q);
        }
        else
            //TODO: Handle this error
}

public function getSearch($query)
{
    $query = urldecode($query);
    $products =  Product::whereRaw(
            'MATCH(product_name,product_desc,product_category) AGAINST(? IN BOOLEAN MODE)',
            array($query)
        )->paginate(5);
        return View::make('searchResults', array('products' => $products, 'query' => $query));
}

I have the separate get/post functions as I was told that pagination is much easier to deal with when the search is done using a GET request; as a result I use the route Route::get('/search/{query}', 'SearchController@getSearch'); to display the search results.

However, it doesn't seem like the search query is being escaped correctly. I used urlencode to prevent the URL from having special characters in it, but when the query is performed, I can still cause errors by searching for ); or other strings with parentheses or semicolons. (I get SQLSTATE[42000]: Syntax error or access violation: errors).

Am I performing my fulltext query incorrectly, or is there some function I can call to 'prepare' my query string?

  • 写回答

1条回答 默认 最新

  • duanfuxing2212 2014-07-22 21:56
    关注

    Using the e() function on the input query seemed to do the trick. I guess this is the same as htmlentities()

    I'm not sure if my urlencode is still necessary, but it seems to work fine leaving it in.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站