서비스 작업자 레일 젬을 테스트하고 VAPID 개인 키와 공개 키를 사용하여 푸시 알림을 보내고 있습니다. 로컬 푸시 알림을 만들 수 있지만 내가 Heroku가에 배포 할 때, 앱이 푸시 알림 페이지로 이동하려고 할 때 위에서 언급 한 오류가 발생 여기에 오류이다. 여기ActionView :: Template :: Error (정의되지 않은 메소드`tr 'for nil : NilClass
75] Started GET "/push-simple/" for 69.253.120.203 at 2017-02-12 06:37:35 +0000
2017-02-12T06:37:35.339318+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] ActionView::Template::Error (undefined method `tr' for nil:NilClass
2017-02-12T06:37:35.333379+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] Rendering pages/push-simple.html.erb within layouts/application
2017-02-12T06:37:35.332337+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] Processing by PagesController#show as HTML
2017-02-12T06:37:35.336377+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] Rendered pages/push-simple.html.erb within layouts/application (2.8ms)
2017-02-12T06:37:35.336998+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] Completed 500 Internal Server Error in 4ms
2017-02-12T06:37:35.339281+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75]
2017-02-12T06:37:35.339490+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 13: <script type="text/javascript">
2017-02-12T06:37:35.339320+00:00 app[web.1]: Did you mean? try):
2017-02-12T06:37:35.339489+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 11: </div>
2017-02-12T06:37:35.339489+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 12:
2017-02-12T06:37:35.339561+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] app/views/pages/push-simple.html.erb:14:in `_app_views_pages_push_simple_html_erb__2838769268823495646_39526220'
2017-02-12T06:37:35.339491+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 15: </script>
2017-02-12T06:37:35.339491+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 14: var publicKey = new Uint8Array(<%= WebpushClient.public_key_bytes %>);
2017-02-12T06:37:35.339492+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] 16: <%= javascript_include_tag 'push-simple' %>
2017-02-12T06:37:35.339520+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75]
2017-02-12T06:37:35.339560+00:00 app[web.1]: [3d626b62-4c1b-41ca-aad3-fc653dc96b75] app/clients/webpush_client.rb:7:in `public_key_bytes'
는 그리고 나의 webpushclient입니다 어디 맛없는 키 다음과 같이 정의됩니다.
class WebpushClient
def self.public_key
ENV['VAPID_PUBLIC_KEY']
end
def self.public_key_bytes
Base64.urlsafe_decode64(public_key).bytes
end
def self.private_key
ENV['VAPID_PRIVATE_KEY']
end
# Send webpush message using subscription parameters
#
# @param message [String] text to encrypt
# @param subscription_params [Hash<Symbol, String>]
# @option subscription_params [String] :endpoint url to send encrypted message
# @option subscription_params [Hash<Symbol, String>] :keys auth keys to send with message for decryption
# @return true/false
def send_notification(message, endpoint: "", p256dh: "", auth: "")
raise ArgumentError, ":endpoint param is required" if endpoint.blank?
raise ArgumentError, "subscription :keys are missing" if p256dh.blank? || auth.blank?
Rails.logger.info("Sending WebPush notification...............")
Rails.logger.info("message: #{message}")
Rails.logger.info("endpoint: #{endpoint}")
Rails.logger.info("p256dh: #{p256dh}")
Rails.logger.info("auth: #{auth}")
Webpush.payload_send \
message: message,
endpoint: endpoint,
p256dh: p256dh,
auth: auth,
vapid: {
subject: "[email protected]",
public_key: public_key,
private_key: private_key
}
end
def public_key
self.class.public_key
end
def private_key
self.class.private_key
end
end
여기에 cal을 사용하는 스크립트가 있습니다. l 공개 키 :
<script type="text/javascript">
var publicKey = new Uint8Array(<%= WebpushClient.public_key_bytes %>);
</script>
<%= javascript_include_tag 'push-react' %>
앞에서 말한 것처럼 로컬로 작동합니다. 나는 변수를 정의하는 것을 잊어 버린 것 같고 비슷한 게시물을보고 꽤 오랫동안 디버깅을 해왔지만 운이 없었습니다. 어떤 제안? 나는 또한 추가하고 싶다, 나는 아주 새롭다, 그래서 명백한 과실 인 경우에, 나는 완전하게 이해할 것이다.
당신은 손톱에 닿았습니다. 고마워요 톤 톰! –
그런데,이 오류 메시지를 더 명확하게함으로써 코드를 개선 할 수있는 한 가지 방법은 (예를 들어, 실수를 다시 반복한다면,보다 유용한 오류 메시지를 줄 수 있습니다!) public_key' 메서드를 정의하는 것입니다 다음과 같이 : ENV [ 'VAPID_PUBLIC_KEY'] || raise "Vapid API 키가 설정되지 않았습니다." –