0

我有一个上传器(仅供内部使用),它会将 HTML 文档上传到我面向客户的网站中表格的二进制列。面向客户端的网站有一个索引,允许用户像普通网站一样查看页面(使用send_data h_t.html_code, :type => "html", :disposition => "inline")。我还想让用户能够下载页面的 PDF。为此,我正在使用 wicked_pdf。

整个问题似乎源于数据存储在数据库中的事实。听起来很奇怪,但对业务运营来说,准确格式化是至关重要的。问题是我看不到任何图像,样式表/样式标签没有任何效果。

我试过的-

Gsub-

def show
  html = HtmlTranscript.find(params[:id])
  html_code = html.html_code.gsub('<img src="/images/bwTranscriptLogo.gif" alt="Logo">','<%= wicked_pdf_image_tag "bwTranscriptLogo.gif" %>')
  html_code = html_code.gsub('<link rel="StyleSheet" href="" type="text/css">','<%= wicked_pdf_stylesheet_link_tag "transcripts.css" %>')
  transcript = WickedPdf.new.pdf_from_string(html_code)

  respond_to do |format|
    format.html do
      send_data transcript, :type => "pdf", :disposition => "attachment"
    end
##### i never could get this part figured out, so if you have a fix for this...
#      format.pdf do
#      render :pdf => "transcript_for_#{@html.created_at}", :template => "html_transcripts/show.html.erb", :layout => false
#      end
    end
  end

使用模板-

#Controller (above, modified)
html = HtmlTranscript.find(params[:id])
@html_code = html.html_code.gsub('<img src="/images/bwTranscriptLogo.gif" alt="Logo">','<%= wicked_pdf_image_tag "bwTranscriptLogo.gif" %>')
@html_code = @html_code.gsub('<link rel="StyleSheet" href="" type="text/css">','<%= wicked_pdf_stylesheet_link_tag "transcripts.css" %>')
transcript = WickedPdf.new.pdf_from_string(render_to_string(:template => "html_transcripts/show.html.erb", :layout => false))


#view
<!-- tried with stylesheet & image link tags, with wicked_pdf stylesheet & image link tags, with html style & img tags, etc -->
<%= raw(@html_code) %>

两者都会生成一个成绩单——但都不会有样式或图像。

创建一个初始化器-

module WickedPdfHelper
  def wicked_pdf_stylesheet_link_tag(*sources)
    sources.collect { |source|
      "<style type='text/css'>#{Rails.application.assets.find_asset("#{source}.css")}</style>"
    }.join("\n").gsub(/url\(['"](.+)['"]\)(.+)/,%[url("#{wicked_pdf_image_location("\\1")}")\\2]).html_safe
  end

  def wicked_pdf_image_tag(img, options={})
    image_tag wicked_pdf_image_location(img), options
  end

  def wicked_pdf_image_location(img)
    "file://#{Rails.root.join('app', 'assets', 'images', img)}"
  end

  def wicked_pdf_javascript_src_tag(source)
    "<script type='text/javascript'>#{Rails.application.assets.find_asset("#{source}.js").body}</script>"
  end

  def wicked_pdf_javascript_include_tag(*sources)
    sources.collect{ |source| wicked_pdf_javascript_src_tag(source) }.join("\n").html_safe
  end
end

完全没有做任何事情,我不知道接下来要尝试什么。

作为旁注,查看脚本的 HTML 版本的代码如下:

def transcript_data
  h_t = HtmlTranscript.find(params[:id])
  send_data h_t.html_code, :type => "html", :disposition => "inline"
end

它不需要视图,因为 html 数据存储在数据库中,但我得到了图像、样式等。一切都适用于 HTML 版本——而不是 PDF。

我在 ruby​​ 1.8.7 和 rails 3.0.20 上。

4

1 回答 1

0

解决了-

事实证明,手头的问题不止一个。

1- 通过为 Ubuntu 安装 wkhtmltopdf$apt-get install并不能完全满足我的要求......

http://rubykitchen.in/blog/2013/03/17/pdf-generation-with-rails

(以前没有运行也可能存在问题sudo apt-get install openssl build-essential xorg libssl-dev libxrender-dev,就像我运行时一样,它安装了许多我以前没有的组件。)

2- 我上传的 HTML 文件包含破坏格式的图像和样式代码。我用这个修复了它...

def rm_by_line(which = 0, line1 = 0, line2 = 0)
  h_t = HtmlTranscript.find(which)
  line_by_line = h_t.html_code.split('
')
  for i in line1..line2
    line_by_line[i] = ''
  end
  line_by_line = line_by_line.join('
').strip

  return line_by_line
end

然后,我所要做的就是传递我想要删除的行。(我不得不用回车分割括号,因为'\n'在返回的字符串上调用'raw'时不能正常工作。)

3- wicked_pdf_stylesheet_link_tag 和 wicked_pdf_image_tag 未定义。我必须将我想要的样式格式内联到我创建的布局中(结果 wicked_pdf_stylesheet_link_tag 使用了我的 ruby​​/rails 没有实现的资产管道,这也意味着我必须摆脱 javascript 助手)并为 wicked_pdf_image_tag 创建了一个助手,在要使用的图像标签(image_tag 或 wicked_pdf_image_tag)的布局中进行切换。

4- 我的模板需要一个 .html.erb 和一个 .pdf.erb,所以我都做了。

5-摆脱支持通过使用或在标签WickedPdf.new.pdf_from_string中链接到html或pdf 。:format => 'html':format => 'pdf'link_to

于 2013-10-10T17:47:57.557 回答