91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信或手機瀏覽器在線顯示office文件的案例

發布時間:2021-02-19 14:54:09 來源:億速云 閱讀:256 作者:小新 欄目:移動開發

這篇文章主要介紹微信或手機瀏覽器在線顯示office文件的案例,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

最近開發微信企業號,發現微信andriod版內置瀏覽器在打開文件方面有問題,但是ios版沒有問題,原因是ios版使用的是safari瀏覽器 支持文檔直接打開,但是andriod版使用的是騰訊瀏覽器x5內核,不知道什么原因不支持,可能是集成出現的問題,這里提供解決方法,這種方法也同樣適用手機瀏覽器或者安卓開發。通過此方法可以在微信上開發自己的第三方應用,或者解決自己的項目問題,解決方法及核心代碼如下:
1、判斷瀏覽器類型
HttpServletRequest req = ServletActionContext.getRequest();
String userAgent=req.getHeader("User-Agent");//里面包含了設備類型
2、IOS版直接使用流輸出
Andriod版利用openoffice+jod轉換成html,然后對html內容重新編輯,文件中有圖片的將路徑改為網絡路徑或者采用流輸出(改成網絡路徑注意特殊符號,如+號會變成空格)

/**
 * 從OA上抓取文件
 * author 牟云飛
 * company 海頤軟件股份有限公司
 * tel  15562579597
 * qq  1147417467
 * team 客服產品中心/于洋
 * @return
 */
 public String getFileFromOa(){ 
  
 HttpServletRequest req = ServletActionContext.getRequest();
 String userAgent=req.getHeader("User-Agent");//里面包含了設備類型
 if(-1!=userAgent.indexOf("iPhone")){
 //-----------------//
 //此方法需要瀏覽器自己能夠打開,ios可以但是微信andriod版內置瀏覽器不支持
 //-----------------//
 //如果是蘋果手機
 //獲得文件地址
 String fileUrl = ServletActionContext.getRequest().getParameter("fileUrl");
 fileUrl.replaceAll("%20", "\\+");//轉換加號
 String strURL = MessageUtil.oaUrl+fileUrl;
 String fileType=strURL.substring(strURL.lastIndexOf(".")+1,strURL.length());
 //獲得圖片的數據流
 try {
 URL oaUrl = new URL(strURL);
 HttpURLConnection httpConn = (HttpURLConnection) oaUrl.openConnection();
 InputStream in = httpConn.getInputStream();
 //獲取輸出流
 HttpServletResponse response = ServletActionContext.getResponse();
 req.setCharacterEncoding("UTF-8");
 response.setCharacterEncoding("UTF-8");
 String name=fileUrl.substring(fileUrl.lastIndexOf("/")+1, fileUrl.length());
  
 response.setHeader("Content-Disposition", 
      "attachment;filename=" + 
       new String( (name ).getBytes(), 
          "iso-8859-1"));
 if("doc".equals(fileType)||"docx".equals(fileType)){
  response.setContentType("application/msword");
 }else if("xls".equals(fileType)||"xlsx".equals(fileType)){
  response.setContentType("application/msexcel"); 
 }else{
  response.setContentType("application/"+fileType);
 }
 OutputStream out = response.getOutputStream();
 //輸出圖片信息
 byte[] bytes = new byte[1024]; 
 int cnt=0; 
 while ((cnt=in.read(bytes,0,bytes.length)) != -1) { 
  out.write(bytes, 0, cnt); 
 } 
 out.flush();
 out.close();
 in.close();
  
 } catch (MalformedURLException e) {
 e.printStackTrace();
 } catch (IOException e) {
 e.printStackTrace();
 }
 return null;
 }else{
 //如果非蘋果手機,自己處理文檔
  
 //獲得文件地址
 String fileUrl = ServletActionContext.getRequest().getParameter("fileUrl");
   
 fileUrl.replaceAll("%2B", "\\+");//轉換加號
 String strURL = MessageUtil.oaUrl+fileUrl;
 //在本地存放OA文件,然后轉換成html,再對文檔中的圖片路徑進行修改,最后輸出到頁面
 try {
 URL oaUrl = new URL(strURL);
 HttpURLConnection httpConn = (HttpURLConnection) oaUrl.openConnection();
 InputStream in = httpConn.getInputStream();
 //獲取輸出流
 HttpServletResponse response = ServletActionContext.getResponse();
 req.setCharacterEncoding("UTF-8");
 response.setCharacterEncoding("UTF-8");
 String name=fileUrl.substring(fileUrl.lastIndexOf("/")+1, fileUrl.length());
  
 //首先判斷本地是否存在
 String path=req.getRealPath("");
 path=path.substring(0, path.lastIndexOf("\\")+1);
 File htmlFile=new File(path + "OaFileToHtml\\"+name+".html");
 if(!htmlFile.exists()){
  //判斷文件夾是否存在,創建文件夾
  String oaFilePath=path + "OaFile";//存放OA文檔的文件夾路徑;
  File oaFiles=new File(oaFilePath);
  if(!oaFiles.exists()){
  //如果文件夾不存在創建文件夾
  oaFiles.mkdirs();
  }
  //將OA消息存入本地
  File oafile=new File(oaFiles+ File.separator +name);
  OutputStream out = new FileOutputStream(oafile);
  //輸出圖片信息
  byte[] bytes = new byte[1024]; 
  int cnt=0; 
  while ((cnt=in.read(bytes,0,bytes.length)) != -1) { 
  out.write(bytes, 0, cnt); 
  } 
  out.flush();
  out.close();
  in.close();
  //轉換成html
  String htmlFilePath =path + "OaFileToHtml";//OA文件轉成html的位置
  String htmlcontext=ConvertFileToHtml.toHtmlString(oafile, htmlFilePath);
  req.setAttribute("htmlcontext", htmlcontext);
 }else{
  //已經存在轉換成功的文檔
  StringBuffer htmlSb = new StringBuffer();
  try {
  BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(htmlFile),Charset.forName("gb2312")));
  while (br.ready()) {
  htmlSb.append(br.readLine());
  }
  br.close();
  } catch (FileNotFoundException e) {
  e.printStackTrace();
  } catch (IOException e) {
  e.printStackTrace();
  }
  // HTML文件字符串
  String htmlStr = htmlSb.toString();
  //System.out.println("htmlStr=" + htmlStr);
  // 返回經過清潔的html文本
  req.setAttribute("htmlcontext", ConvertFileToHtml.clearFormat(htmlStr, ""));
 }
  
 } catch (MalformedURLException e) {
 e.printStackTrace();
 } catch (IOException e) {
 e.printStackTrace();
 }
 return "lookfile";
 }
  
 }

------------------將word轉換成html文件,并讀取內容-------------------------

package com.haiyisoft.wx.util;
 
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.ConnectException;
import java.nio.charset.Charset;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
 
import com.artofsolving.jodconverter.DocumentConverter;
import com.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;
import com.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;
import com.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;
 
/**
 * * 端口啟動命令:
 * soffice -headless -accept="socket,port=8100;urp;
 *
 * 
 * author 牟云飛
 * company 海頤軟件股份有限公司
 * tel  15562579597
 * qq  1147417467
 * team 客服產品中心/于洋
 * 
 */
public class ConvertFileToHtml {
 /**
 * 將word文檔轉換成html文檔
 * @param docFile 需要轉換的word文檔
 * @param filepath 轉換之后html的存放路徑
 * @return 轉換之后的html文件
 */
 public static File convert(File docFile, String filepath) {
 
 // 創建保存html的文件
 String fileName=docFile.getName();
 File htmlFile = new File(filepath + "/" + fileName + ".html");
 // 創建Openoffice連接
 OpenOfficeConnection con = new SocketOpenOfficeConnection(8100);
 try {
 // 連接
 con.connect();
 } catch (ConnectException e) {
 System.out.println("獲取OpenOffice連接失敗...");
 e.printStackTrace();
 }
  
 // 創建轉換器
 DocumentConverter converter = new OpenOfficeDocumentConverter(con);
 // 轉換文檔問html
 converter.convert(docFile, htmlFile);
 // 關閉openoffice連接
 con.disconnect();
 return htmlFile;
 }
 
 /**
 * 
 * 將word轉換成html文件,并且獲取html文件代碼。
 * @param docFile 需要轉換的文檔
 * @param filepath 文檔中圖片的保存位置
 * @return 轉換成功的html代碼
 */
 public static String toHtmlString(File docFile, String filepath) {
 // 轉換word文檔
 File htmlFile = convert(docFile, filepath);
 System.out.println(htmlFile.getAbsolutePath());
 // 獲取html文件流
 StringBuffer htmlSb = new StringBuffer();
 try {
 BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(htmlFile),Charset.forName("gb2312")));
 while (br.ready()) {
 htmlSb.append(br.readLine());
 }
 br.close();
 // 刪除臨時文件
 //htmlFile.delete();
 } catch (FileNotFoundException e) {
 e.printStackTrace();
 } catch (IOException e) {
 e.printStackTrace();
 }
 // HTML文件字符串
 String htmlStr = htmlSb.toString();
 //System.out.println("htmlStr=" + htmlStr);
 // 返回經過清潔的html文本
 return clearFormat(htmlStr, filepath);
 }
 
 /**
 * 
 * 清除一些不需要的html標記
 */
 
 public static String clearFormat(String htmlStr, String docImgPath) {
 
 // 獲取body內容的正則
 String bodyReg = "<BODY .*</BODY>";
 Pattern bodyPattern = Pattern.compile(bodyReg);
 Matcher bodyMatcher = bodyPattern.matcher(htmlStr);
 if (bodyMatcher.find()) {
 // 獲取BODY內容,并轉化BODY標簽為DIV
 htmlStr = bodyMatcher.group().replaceFirst("<BODY", "<DIV").replaceAll("</BODY>", "</DIV>");
 }
 
 // 調整圖片地址,這里將圖片路徑改為網絡路徑
  
 htmlStr = htmlStr.replaceAll("<IMG SRC=\"../","<IMG SRC=\"" + MessageUtil.webUrl+"/******.do?action=***);
 //特殊處理一下+號,因為網絡傳輸+會變成空格,用%2B替換+號
 String temp1=htmlStr.substring(htmlStr.indexOf("action=***"), htmlStr.length());
 String temp2=temp1.substring(0,temp1.indexOf("."));
 String temp3=temp2.replaceAll("\\+", "%2B");
 htmlStr=htmlStr.substring(0,htmlStr.indexOf("action=***"))+temp3+temp1.substring(temp1.indexOf("."), temp1.length());
  
 // 把<P></P>轉換成</div></div>保留樣式
 // content = content.replaceAll("(<P)([^>]*>.*?)(<\\/P>)",
 // "<div$2</div>");
 // 把<P></P>轉換成</div></div>并刪除樣式
 htmlStr = htmlStr.replaceAll("(<P)([^>]*)(>.*?)(<\\/P>)", "<p$3</p>");
 // 刪除不需要的標簽
 htmlStr = htmlStr.replaceAll("<[/]?(font|FONT|span|SPAN|xml|XML|del|DEL|ins|INS|meta|META|[ovwxpOVWXP]:\\w+)[^>]*?>","");
 // 刪除不需要的屬性
 htmlStr = htmlStr.replaceAll("<([^>]*)(?:lang|LANG|class|CLASS|style|STYLE|size|SIZE|face|FACE|[ovwxpOVWXP]:\\w+)=(?:'[^']*'|\"\"[^\"\"]*\"\"|[^>]+)([^>]*)>","<$1$2>");
 
 return htmlStr;
 
 }
}

以上是“微信或手機瀏覽器在線顯示office文件的案例”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥德县| 陆丰市| 兴义市| 黄冈市| 云梦县| 邓州市| 乡宁县| 琼海市| 勃利县| 博湖县| 济阳县| 民乐县| 界首市| 边坝县| 哈尔滨市| 商都县| 浦县| 墨竹工卡县| 延庆县| 黄浦区| 夏邑县| 沈丘县| 星子县| 黄冈市| 龙海市| 博爱县| 政和县| 昆山市| 汾西县| 隆尧县| 石景山区| 祥云县| 垦利县| 洪湖市| 广灵县| 巴里| 永济市| 夏河县| 登封市| 页游| 夏邑县|