Rails 3: мобильный MIME-тип выдает ошибку 406 после попытки загрузки контента с помощью JavaScript - PullRequest
5 голосов
/ 08 декабря 2011

Я подписан на Railscast # 199 , чтобы разрешить просмотр моего веб-приложения в мобильном браузере. Это прекрасно работает, за исключением случаев, когда я пытаюсь получить доступ к информации в интерфейсе с вкладками, используя UJS в мобильной версии. Нажатие на вкладки работает в веб-приложении, но на мобильной стороне я получаю ошибку 406. (Я попытался сделать это после установки User Agent как iPhone в Safari. Я также тестировал на iOS Simulator и на моем iPhone. Ни разу ничего не загружал.)

Ниже приведен код для одной из вкладок. Может кто-нибудь может помочь мне нацелиться на то, что происходит? Вот мой код.

Вот действие profile_about в profiles_controller.rb:

def profile_about
  @profile = Profile.find(params[:id])
  respond_to do |format|
    format.js { render :layout => nil }
  end
end

В моем profiles/show.mobile.erb (это точно такой же код, как в profiles/show.html.erb):

<div id="tabs">
  <ul id="infoContainer">
    <li><%= link_to "Cred", profile_cred_profile_path, :class=> 'active', :remote => true %></li>
    <li><%= link_to "About", profile_about_profile_path, :class=> 'inactive', :remote => true %></li>
  </ul>
  <div id="tabs-1">
  <%= render :partial => 'profile_cred' %>
  </div>
</div><!-- end tabs -->

(ПРИМЕЧАНИЕ: у меня есть файл для profiles/_profile_about.html.erb и profiles/_profile_about.mobile.erb.)

Вот мой profiles/profile_about.js.erb:

$("#tabs-1").html("<%= escape_javascript(render(:partial => 'profile_about'))%>");

Мои журналы Heroku, показывающие 406:

2012-03-08T03:02:55+00:00 app[web.1]: Started GET "/profiles/1/profile_about" for 98.218.231.113 at 2012-03-08 03:02:55 +0000
2012-03-08T03:02:55+00:00 heroku[router]: GET myapp.com/profiles/1/profile_about dyno=web.1 queue=0 wait=0ms service=14ms status=406 bytes=1
2012-03-08T03:02:55+00:00 app[web.1]:   Processing by ProfilesController#profile_about as JS
2012-03-08T03:02:55+00:00 app[web.1]:   Parameters: {"id"=>"1"}
2012-03-08T03:02:55+00:00 app[web.1]: Completed 406 Not Acceptable in 3ms
2012-03-08T03:02:55+00:00 heroku[nginx]: 98.218.231.113 - - [08/Mar/2012:03:02:55 +0000] "GET /profiles/1/profile_about HTTP/1.1" 406 1 "http://myapp.com/profiles/1" "Mozilla/5.0 (iPhone; CPU iPhone OS 5_0_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/5.1 Mobile/9A405 Safari/7534.48.3" myapp.com

с работы tail -f logs/development.log:

Started GET "/profiles/1/profile_about" for 127.0.0.1 at Wed Mar 07 22:35:36 -0500 2012
  Processing by ProfilesController#profile_about as JS
  Parameters: {"id"=>"1"}
  PK and serial sequence (5.4ms)   SELECT attr.attname, seq.relname
 FROM pg_class seq,
 pg_attribute attr,
 pg_depend dep,
 pg_namespace name,
 pg_constraint cons
 WHERE seq.oid = dep.objid
 AND seq.relkind = 'S'
 AND attr.attrelid = dep.refobjid
 AND attr.attnum = dep.refobjsubid
 AND attr.attrelid = cons.conrelid
 AND attr.attnum = cons.conkey[1]
 AND cons.contype = 'p'
 AND dep.refobjid = '"goals_profiles"'::regclass
  PK and custom sequence (2.5ms)   SELECT attr.attname,
 CASE
 WHEN split_part(def.adsrc, '''', 2) ~ '.' THEN
 substr(split_part(def.adsrc, '''', 2),
 strpos(split_part(def.adsrc, '''', 2), '.')+1)
 ELSE split_part(def.adsrc, '''', 2)
 END
 FROM pg_class t
 JOIN pg_attribute attr ON (t.oid = attrelid)
 JOIN pg_attrdef def ON (adrelid = attrelid AND adnum = attnum)
 JOIN pg_constraint cons ON (conrelid = adrelid AND adnum = conkey[1])
 WHERE t.oid = '"goals_profiles"'::regclass
 AND cons.contype = 'p'
 AND def.adsrc ~* 'nextval'

  Profile Load (1.3ms)  SELECT "profiles".* FROM "profiles" WHERE "profiles"."id" = '1' LIMIT 1
Completed 406 Not Acceptable in 30ms

Ответы [ 3 ]

0 голосов
/ 18 августа 2012

Возможно, не полностью ответил на ваш вопрос, но у меня была проблема со статусом 406, потому что я развертывал свое приложение в Phonegap!В основном это произошло потому, что тип запроса не соответствовал ни одному из ответчиков Rails в действии.

это было похоже на:

respond_to do |format|
  format.json {
    render( json: (@parishes) )
  }
end

Поскольку я использовал его только для ответа на JSON, я изменили теперь это работает:

    render( json:(@parishes) )

Более полный способ справиться с этим - точно определить, какого респондента запрашивают по этому запросу, или использовать по умолчанию что-то, что, как вы знаете, работает

0 голосов
/ 19 января 2013

Оказывается, это связано с отсутствием проверки для запроса xhr в методе prepare_for_mobile.Я нашел ответ в другой вопрос .Таким образом, приведенный ниже метод prepare_for_mobile позволяет JS работать:

def prepare_for_mobile
  session[:mobile_param] = params[:mobile] if params[:mobile]
  request.format = :mobile if mobile_device? && !request.xhr?
end
0 голосов
/ 08 февраля 2012

В вашем коде есть несколько ошибок, может быть, это просто форматирование стекового потока, но внутренние кавычки должны быть «вместо», например:

$("#tabs-1").html("<%= escape_javascript(render(:partial => 'profile_about'))%>");

И эта строка вызывает вашу ошибку:

format.mobile.js {render :layout => nil}

Это невозможно, поскольку запрос может иметь только один тип mime: «mobile» или «js», но не оба. Если вы запрашиваете действие «profile_about» из javascript, то вы должны ответить наего с js. "format.mobile" следует использовать только для рендеринга шаблона "profile_about.mobile".

Надеюсь, это хотя бы шаг в правильном направлении для вас.

...