Нежелательные параметры формы добавляются в ссылки на страницы

У меня есть страница, которая используется для поиска в списках путем отправки данных с помощью предоставленных форм. Параметры формы отправляются с помощью ajax (пост-запроса), в таблице поиска создается новая запись, а затем списки отображаются (динамически, на той же странице, с которой отправляется форма) через show действие для этой записи.

Результаты имеют ссылки на страницы, предоставляемые Kaminari, например:

<%= paginate matches, 
  :params => {:controller => 'searches',
  # I have to specify the id because my searches are stored in the database
  :action => 'show', :id => search.id},
  :remote => true %>

Обратите внимание, что ссылки на страницы динамически включены на страницу. Поэтому, когда я выполняю новый поиск и получаю новые списки, сервер повторно отображает ссылки на страницы.

Вот мое шоу-действие в контроллере поиска

def show
  @search = Search.includes(:rate).find(params[:id])
  @matches = @search.matches.order(sort_column + " " + sort_direction).page(params[:page])

  respond_to do |format|
    format.html
    format.xml { render :xml => @matches }
    format.js
  end
end

По какой-то причине я не могу понять, все параметры, которые я использую в формах поиска (и их много), прикрепляются к URL-адресам пагинации kaminari, давая мне hrefs вот так:

<a href="/searches/145?massive parameter list omitted" data-remote="true" rel="next">2</a>

Список пропущенных параметров настолько длинный, что слишком велик, чтобы быть действительным GET-запросом, и я получаю 414 код ошибки.

Как вы можете видеть из поисков -> показать действие, которое я описал выше, для ссылок на нумерацию страниц не нужно добавлять всю эту информацию. Все, что им нужно, это маршрут, идентификатор и номер страницы.

Как я могу предотвратить это?

Кстати, я пытался установить :method => :post в вариантах каминари. Кажется, не помогает. Я использую Kaminari v 0.12.4 (последний) и Rails 3.1.rc4.

4 ответа

Решение

Главная идея

Вы можете исправить это, отредактировав части разбиения на страницы, чтобы вручную удалить параметры из URL, а затем добавить параметры страницы обратно. Я знаю, что это взлом, но кажется, что это самый быстрый способ исправить эту проблему, если разбита нумерация страниц (как это было для меня).

Я расширяю это решение, опубликованное в отчете об ошибке GitHub для этой проблемы.

Вы должны отредактировать каждую из 5 частей ссылок на страницы: _page.html.erb (по номеру), _first_page.html.erb а также _last_page.html.erb, _prev_page.html.erb а также _next_page.html.erb,

Вы можете найти нужный номер страницы из локальных переменных, доступных в партиалах: current_page, page, num_pages,

Особые инструкции

Если вы этого еще не сделали, сгенерируйте частичные нумерации страниц в своем приложении, запустив rails g kaminari:views default

Затем отредактируйте части следующим образом:

#_page.html.erb
<%
 unless page.current?
   url = url.split('?')[0] + '?page=' + page.to_s
 end
%>

<span class="page<%= ' current' if page.current? %>">
  <%= link_to_unless page.current?, page, url, opts = {:remote => remote, :rel => page.next? ? 'next' : page.prev? ? 'prev' : nil} %>
</span>

# _first_page.html.erb
<span class="first">
  <% url = url.split('?')[0] + '?page=1' %>
  <%= link_to_unless current_page.first?, raw(t 'views.pagination.first'), url, :remote => remote %>
</span>

# _prev_page.html.erb
<span class="prev">
  <% url = url.split('?')[0] + '?page=' + (current_page.to_i - 1).to_s %>
  <%= link_to_unless current_page.first?, raw(t 'views.pagination.previous'), url, :rel => 'prev', :remote => remote %>
</span>

# _next_page.html.erb
<span class="next">
  <% url = url.split('?')[0] + '?page=' + (current_page.to_i + 1).to_s %>
  <%= link_to_unless current_page.last?, raw(t 'views.pagination.next'), url, :rel => 'next', :remote => remote %>
</span>

# _last_page.html.erb
<span class="last">
  <% url = url.split('?')[0] + '?page=' + num_pages.to_s %>
  <%= link_to_unless current_page.last?, raw(t 'views.pagination.last'), url, {:remote => remote} %>
</span>

Если у кого-то все еще есть проблемы с ссылками на нумерацию страниц, здесь есть исправление: Kaminari: исключить основные параметры формы из ссылок на нумерацию страниц

Хотя это не работает для меня, как это было описано в описании коммита, в ссылке все еще присутствуют нежелательные параметры (:authenticity_token,:commit,:utf8,:_method), но вы можете исключить их, установив для них значение nil

Например:

paginate @books, params: {authenticity_token: nil, commit: nil, utf8: nil, action: nil}

Результат:

<a href="/books?page=2">2</a>

ИЛИ ЖЕ

контроллер:

def index
  # here search staff, messing our params hash
  @books = Books.all
  @pagination_params = normalize_pagination_params
end

private
def normalize_pagination_params
 params.inject({}) do |params_hash, p|
  unless p[0]=="controller"
    params_hash[p[0]] = nil
  end
  params_hash
 end
end

Посмотреть:

paginate @books, params: @pagination_params

Вы можете попробовать очистить параметры, сохранив только то, что вам нужно, и удалив все остальное перед отображением результатов поиска.

Чтобы использовать пост, я думаю, что вы пропустили второй шаг, где вы должны переопределить пароли ссылок kaminari: https://github.com/amatsuda/kaminari/wiki/Kaminari-recipes

Старый пост. Лучшее решение.

Если вы используете kaminari для разбивки на страницы для вложенных ресурсов с обновлениями ajax, вы обнаружите, что Kaminari попытается построить URL на основе текущего пути, независимо от указанных вами параметров, что приведет к ошибке маршрутизации.

Самое чистое решение - использовать маршрутный символ.

Если ваши постраничные комментарии для поста имеют контроллер комментариев с действием create и show, то:

В ваших маршрутах:

match '*path/comments(/:page)' => 'comments#show'

И виджет нумерации страниц:

<%= paginate @comments, params: { controller: :comments }, remote: true %>
Другие вопросы по тегам