然后直接上代码
private static void versionsone(String htmlCode, String pdfPath){
Document document = new Document()
try{
StyleSheet st = new StyleSheet()
st.loadTagStyle("body", "leading", "16,0")
PdfWriter.getInstance(document, new FileOutputStream(pdfPath))
document.open()
BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED)
Font FontChinese = new Font(bfChinese, 12, Font.NORMAL)
ArrayList<ArrayList>p = HTMLWorker.parseToList(dome_2(htmlCode), st)
for(int k=0k<p.size()k++){
for(int m=0m<p.get(k).size()m++){
Paragraph pCode = new Paragraph(p.get(k).get(m).toString(),FontChinese)
document.add(pCode)
}
}
}catch(Exception e){
e.printStackTrace()
}finally{
document.close()
}
}
private static Reader dome_2(String htmlCode){
if(htmlCode != null &&!htmlCode.trim().equals("")){
try{
InputStream tInputStringStream = new ByteArrayInputStream(htmlCode.getBytes())
InputStreamReader isr = new InputStreamReader(tInputStringStream,"utf-8")
BufferedReader reader = new BufferedReader(isr)
return reader
}catch(Exception e){
e.printStackTrace()
}
}
return null
}
其实此处和别人的最大的不一样的是,
ArrayList<ArrayList>p = HTMLWorker.parseToList(dome_2(htmlCode), st)
其实刚刚开始我在网上找来的代码中是这样写的“ArrayList p = HTMLWorker.parseToList(dome_2(htmlCode), st)”
但后来我通过debug发现,ArrayList 里面装的还是一个集合,然后集合中放得才是真正不含html标签的字符串。对于普通得文章,一般html标签一般都是<p></p>
占大多数。所以我直接用了两层for循环直接从里面取得我们想要的字符串。然后直接“Paragraph pCode = new Paragraph(p.get(k).get(m).toString(),FontChinese)”document.add(pCode)这样就能解决中文问题了
很简单的,你在servlet里自己用HTML代码
形成一个大的
字符
窜,把这个字符窜做为一个
变量
传递到前台,前台的JSP在制定的位置用<%=
添加获取字符窜变量的代码%>的形式就可以了!
记得给分哦!