请上传宽度大于 1200px,高度大于 164px 的封面图片
    调整图片尺寸与位置
    滚轮可以放大缩小图片尺寸,按住图片拖动可调整位置,多余的会自动被裁剪掉
取消
996433090(uid:79919)
职业资格认证:尚未取得认证
SQL分页模板,解决百万行数据展示卡顿问题
分页前模板 数据来源于 FRDemo的S人员花名册表,数据量为23199,如果简单显示几个字段的情况,不会触发内存报警,但是全部显示,打开很慢,触发数据报警,关闭内存预警后,页面数据加载数调整到300000条,系统加载该页面在十几秒钟。 主要问题: 1、数据加载触发最大行数报警 2、解除报警后数据加载慢 3、涉及到数据更新后重新加载不能默认为当前页面,除非写js,将页面参数传过去,如果有查询参数,又有页码参数的情况下,js代码复杂度增加很多倍。 为了解决以上问题,对页面进行分页改造。 具体步骤和js代码如下: 1.数据集改造 1.1数据类容集改造: 将原来的数据集ds1 SELECT * FROM S人员花名册 WHERE id is not null ${if(LEN(name)=0,""," AND 人员姓名 LIKE '%"+name+"%'")} 调整为新的数据集ds1 SELECT * FROM ( ----------原SQL开始------ SELECT *, ROW_NUMBER() OVER(ORDER BY id DESC) AS 行号 FROM S人员花名册 WHERE id is not null ${if(LEN(name)=0,""," AND 人员姓名 LIKE '%"+name+"%'")} ----------原SQL结束------ )A WHERE 行号 between ${pageSize}*(${pageIndex}-1)+1 and ${pageSize}*${pageIndex} 1.2新增总行数的数据集count: SELECT count(id) counts FROM ( ----------原SQL开始------ SELECT id FROM S人员花名册 WHERE id is not null ${if(LEN(name)=0,""," AND 人员姓名 LIKE '%"+name+"%'")} ----------原SQL结束------ )A 1.3新增每页显示行数数据集page: select 1 xh,10 page union select 2 xh,20 page union select 3 xh,50 page union select 4 xh,100 page order by xh asc 2.初始化参数控件 pageIndex:为当前页,默认值为1 pageSize:  为每页行数,默认值为10,使用page数据集,可以选择10、20、50、100等选项 由于数据行数比较多,此处需要对页面大小进行设置,建议高度为1000毫米,具体高度可根据最大数据行数进行设置,本人一般给的是1000。 3.修改预览页面 首页、上一页、当前页、下一页、尾页、导出、刷新等按钮 其中:当前页选择邮件,去掉所有✓选内容 3.1页面自动加载总页数 js代码: var pageSize = FR.remoteEvaluate('=$pagesize'); var pageIndex = FR.remoteEvaluate('=$pageIndex'); var qty = FR.remoteEvaluate('=value("count",1,1)'); var total = Math.ceil(qty / pageSize); //contentPane.toolbar.options.items.setValue("第 " + pageIndex + " / " + total + " 页"); // 当前页 var currentpageStr = ""; // 数据总量 var totalcntStr = " 数据总量:" + qty + ""; // 总页 var pagesizeStr = "每页显示条数:" + pageSize + ""; // 工具栏内容设置 $("#fr-btn-Email").replaceWith(currentpageStr); // 邮件 $("#fr-btn-Word").replaceWith(totalcntStr); // Word格式 $("#fr-btn-PDF").replaceWith(pagesizeStr); // PDF $("m").replaceWith(currentpageStr); // 邮件 $("#currentpage").val(pageIndex); $("#currentpage").attr("max", total); $("#currentpage").attr("val", pageIndex); $("#totalpage").text(" / " + total); //$("#pagesize").val(pagesize); // 切换页码 $("#currentpage").change(function() { var val = $(this).val(); // alert(val); if (val < 1 || val > total) { $(this).val(pageIndex); } else { // 查询 //_g().getParameterContainer().getWidgetByName("pageIndex").setValue(val); //_g().parameterCommit(); contentPane.parameterEl.getWidgetByName("pageIndex").setValue(val); _g().parameterCommit(); } }); 3.2、首页js: contentPane.parameterEl.getWidgetByName("pageIndex").setValue(1); _g().parameterCommit(); 3.3、上一页js: var pageSize = FR.remoteEvaluate('=$pagesize'); var pageIndex = FR.remoteEvaluate('=$pageIndex-1'); var qty = FR.remoteEvaluate('=value("count",1,1)'); if(pageIndex==0){ this.setEnable(false);} else{ contentPane.parameterEl.getWidgetByName("pageIndex").setValue(pageIndex); _g().parameterCommit(); } 3.4、下一页js: var pageSize = FR.remoteEvaluate('=$pagesize'); var pageIndex = FR.remoteEvaluate('=$pageIndex+1'); var qty = FR.remoteEvaluate('=value("count",1,1)'); var total=Math.ceil(qty/pageSize); if(parseInt(pageIndex) > parseInt(total)){ this.setEnable(false);} else{ contentPane.parameterEl.getWidgetByName("pageIndex").setValue(pageIndex); _g().parameterCommit(); } 3.5、尾页js: var pageSize = FR.remoteEvaluate('=$pagesize'); var pageIndex = FR.remoteEvaluate('=$pageIndex'); var qty = FR.remoteEvaluate('=value("count",1,1)'); var total=Math.ceil(qty/pageSize); contentPane.parameterEl.getWidgetByName("pageIndex").setValue(total); _g().parameterCommit(); 3.6、导出按钮js(全参数自动传参): //获取它的原始值 var bl=_g().parameterEl.getWidgetByName("pageIndex").getValue(); var para = contentPane.parameterEl.getWidgetByName("PARA"); //获取参数面板 var urls = ''; //设置成1开始 contentPane.parameterEl.getWidgetByName("pageIndex").setValue(1); for (var i = 0; i < para.options.items.length; i++) { var widgetName = para.options.items.widgetName; //参数面板下控件的widgetName var type = para.options.items.type; //参数面板下控件的类型 var value = contentPane.parameterEl.getWidgetByName(widgetName).getValue(); var pagesize = FR.remoteEvaluate('=value("count",1,1)'); urls = urls + "&" + widgetName + "=" + value; } var reportname = '${=reportname}'; var REPORT_URL = '${servletURL}?viewlet=' + reportname + urls + '&pagesize=' + pagesize + '&format=excel&extype=simple'; setTimeout(function() { window.location = (encodeURI(encodeURI(REPORT_URL))); }, 300); //再把页码改回去 contentPane.parameterEl.getWidgetByName("pageIndex").setValue(bl); 备注:感谢 CD20160914  对导出存在BUG的修复。 3.7、刷新按钮js: location.reload(); 3.8、查询按钮新增js: this.options.form.getWidgetByName("pageIndex").setValue(1); parent.window._g().parameterCommit(); 这里需要加入该代码的原因是 当到第N(N大于1)页的时候,再进行其他参数查询时,肯能存在数据比较少的情况,入只有1页数据集,但是当前页还在N页,导致数据显示不出来的问题。   备注:如果系统“此调用存在安全风险,如需使用请在安全管理中修改脚本调用公式限制”,由于总页数使用了FR.remoteEvaluate('=value("count",1,1)') 请关闭脚本调用公式限制。 页面运行效果如下,①数据秒出,②对于N页内某一数据修改后,关闭修改子页面,重新刷新父页面,依旧还在第N页,所有的参数也被保留下来了,体验性比较好。③如果要加入其他查询控件,可以在ds1和count数据集中加入${if(LEN(name)=0,""," AND 人员姓名 LIKE '%"+name+"%'")} 类似的参数即可,页面维护简单。   参考模板:分页模板.zip (6.82 K) 最后的建议: 1、隐藏当前页的控件,保留和隐藏每页对应行数。 2、页面可以作为模板使用,只需要修改对应数据集即可。
kkFileView 开源在线预览 支持pc端和移动端
一、前言 网页端一般会遇到各种文件,比如:txt、doc、docx、ofd、pdf、xml、xls、xlsx、ppt、pptx、zip、png、jpg等等。 有时候我们不想要把文件下载下来,而是想在线打开文件预览 ,这个时候如果每一种格式都需要我们去写代码造轮子去实现预览功能就太复杂了,并且自己实现的话会有很多兼容性问题。 这个时候 kkFileView 的出现就解决了我们的问题。 二、kkFileView介绍 kkFileView 为文件文档在线预览解决方案,该项目使用流行的spring boot搭建,易上手和部署,基本支持主流办公文档的在线预览,如doc,docx,xls,xlsx,ppt,pptx,pdf,txt,zip,rar,图片,视频,音频等等 三、kkFileView安装   部署指南参考kkFileView - 在线文件预览 下面介绍Windows、Linux、docker三种安装方式。 1.下载Windows或Linux的 v4.0.0 安装包 : 1.1 windows安装包下载 (链接:https://pan.baidu.com/s/1hZCP5jcD5cKd-xCsMHfYxg 提取码:7uwd) 1.2 linux安装包下载 (链接:https://pan.baidu.com/s/1grhyoIQ_Tr2NHyCZPFYDWg 提取码:13hj)   2.Windows上安装: 2.1 下载的 zip 压缩包解压后进入 bin 目录,双击 startup.bat 启动 kkFileView 2.2 30秒后进入 log 目录查看 kkFileView.log 日志,打印【kkFileView 服务启动完成,耗时:26.8350973s,演示页请访问: http://127.0.0.1:8012 】则说明启动成功。   3.Linux上安装(centos为例): 3.1 root用户下将 kkFileView-4.0.0.tar.gz 上传到服务器 ,使用命令 tar -zxvf kkFileView-4.0.0.tar.gz 解压,开放 8012 端口。 3.2 root用户下解压后进入 kkFileView-4.0.0/bin 目录,执行 ./startup.sh 开始安装和启动,安装过程中会下载需要的组件需要输入y 3.3 安装字体。若不安装字体转化出的pdf文件可能会因为缺少字体乱码。 字体下载(链接:http://kkfileview.keking.cn/fonts.zip) 或者 百度云下载(链接:https://pan.baidu.com/s/1VMGERMHAI7W_Ys-MZC_YTQ 提取码:p6hq) 将下载的字体fonts.zip上传到 /usr/share/fonts 目录解压后执行命令 mkfontscale 若 mkfontscale 提示没有命令则先 yum install mkfontscale 安装命令 再分别依次执行 mkfontscale、mkfontdir、fc-cache 命令。   3.4 安装完成后 kkFileView-4.0.0/bin/ 目录下使用命令 ./showlog.sh 查看日志 如果出现: 【kkFileView 服务启动完成,耗时:5.99157928s,演示页请访问: http://127.0.0.1:8012 】,则表示安装启动成功。 3.5 如果日志提示报错信息【找不到office组件,请确认’office.home’配置是否有误 】。 (1)可能是 install.sh 中脚本有问题,尝试将脚本中的: wget https://kkfileview.keking.cn/LibreOffice_7.1.4_Linux_x86-64_deb.tar.gz -cO LibreOffice_7_deb.gz && tar -zxf /tmp/LibreOffice_7_deb.tar.gz && cd /tmp/LibreOffice_7.1.4.2_Linux_x86-deb/RPMS 改为如下: wget https://kkfileview.keking.cn/LibreOffice_7.1.4_Linux_x86-64_deb.tar.gz -cO LibreOffice_7_deb.tar.gz && tar -zxf /tmp/LibreOffice_7_deb.tar.gz && cd /tmp/LibreOffice_7.1.4.2_Linux_x86-64_deb/DEBS 然后重启 kkFileView 看问题是否还存在 (2) 若 install.sh 修改后问题依然存在,则需要下载 LibreOffice 组件安装。 LibreOffice下载 (链接:https://downloadarchive.documentfoundation.org/libreoffice/old/7.1.4.2/rpm/x86_64/) 或者: 百度云下载(链接:https://pan.baidu.com/s/18tLufbFQCOm11R7-U2f0-Q 提取码:0npj)将 LibreOffice_7.1.4.2_Linux_x86-64_rpm.tar.gz 上传服务器,然后解压后进入RPMS目录执行 yum localinstall *.rpm 进行安装。 3.6 如果日志提示报错信息【Caused by: java.lang.IllegalStateException: a process with acceptString ‘socket,host=127.0.0.1,port=2001’ is already running】 (1)用 ps -ef|grep java 命令查询出Java相关运行的进程,然后关闭kkFileView相关的进程, 并查看2001和2002端口的进程并关闭该进程。然后再执行 ./startup.sh 启动并查看日志。 (2)如果是安装在Linux上并且关闭了kkFileView相关的进程以及2001和2002端口,启动日志任 然存在该问题,那么可能是你远程连接服务器的软件导致的这个问题,改用window的cmd, 用ssh连接服务器启动程序尝试。 3.7 如果日志提示报错信息【Caused by: org.artofsolving.jodconverter.office.OfficeException: could not establish connection】,可参考 centos下启动失败:启动office组件失败,请检查office组件是否可用 四、kkFileView的配置和使用 1.修改启动脚本 测试发现如果 kkfileview 安装在 Windows 上预览 txt 文件会乱码,所以需要修改 kkfileview 的 bin 目录下的 startup.bat 脚本。 在最后一行的 java 后添加 -Dfile.encoding=UTF-8 修改后如下: @echo off set "KKFILEVIEW_BIN_FOLDER=%cd%" cd "%KKFILEVIEW_BIN_FOLDER%" echo Using KKFILEVIEW_BIN_FOLDER %KKFILEVIEW_BIN_FOLDER% echo Starting kkFileView... echo Please check log file in ../log/kkFileView.log for more information echo You can get help in our official homesite: https://kkFileView.keking.cn echo If this project is helpful to you, please star it on https://gitee.com/kekingcn/file-online-preview/stargazers java -Dfile.encoding=UTF-8 -Dspring.config.location=..\config\application.properties -jar kkFileView-4.0.0.jar -> ..\log\kkFileView.log   2.关闭演示页面 kkFileView安装启动成功后可以打开 http://安装的ip:8012 (或者本机 http://127.0.0.1:8012) 查看演示页面上传文件以及查看预览效果。 如果项目上线后为了安全要关闭演示页面,可以在修改 kkFileView 安装目录的config文件夹中的 application.properties配置文件,将 file.upload.disable 设置为 true 禁用演示首页的文件上传。 如果你要隐藏演示页面,可以使用 ngnix 将 http://ip:8012 和 http://ip:8012/index 代理到其他页面。 其他配置可根据 官网配置说明 进行配置。   4.kkFileView的使用 kkFileView 的使用有两种方式,一种是通过提供文件的 url 地址来预览;一种是通过提供一个接口,该接口返回文件流来预览。 (参照官网使用说明:使用说明) (1) 通过文件的 url 地址预览 示例 : var url = 'http://127.0.0.1:8080/file/test.txt'; //要预览文件的访问地址 window.open('http://127.0.0.1:8012/onlinePreview?url='+encodeURIComponent(url)); (2) 通过文件接口返回文件流预览 示例: <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/js-base64@3.6.0/base64.min.js"></script> //假设你项目的后端文件接口是 http://127.0.0.1:8080/filedownload 该接口返回文件流,并且假设该接口接受fileId 参数 var originUrl = 'http://127.0.0.1:8080/filedownload?fileId=1'; //要预览文件的访问地址,该接口返回文件流 var previewUrl = originUrl + '&fullfilename=test.txt'//fullfilename是必须的,有了该参数kkFileView才知道文件名是什么 //kkFileView 的 onlinePreview 接口就会拿着参数去请求 http://127.0.0.1:8080/filedownload 接口,把文件下载到安装目录的 file/demo 文件夹下,然后转换后把预览界面展示到浏览器。 window.open('http://127.0.0.1:8012/onlinePreview?url='+encodeURIComponent(Base64.encode(previewUrl))); 当然,为了文件安全和实效性,你可以在你的接口中加入token或者其他校验参数,满足了才能下载文件。 比如: <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/js-base64@3.6.0/base64.min.js"></script> var originUrl = 'http://127.0.0.1:8080/filedownload?token=sgdfhkkmlk&time=1659006176&fileID=4564sfd&filename=test.xls'; //要预览文件的访问地址,该接口返回文件流 var previewUrl = originUrl + '&fullfilename=test.xls'//fullfilename是必须的,该参数是kkFileView保存的文件名 window.open('http://127.0.0.1:8012/onlinePreview?url='+encodeURIComponent(Base64.encode(previewUrl))); 注意: encodeURIComponent(Base64.encode(previewUrl)) 这里因为编码问题我踩过坑,所以需要注意下当使用 base64 对 previewUrl 进行编码时,如果采用MIME友好型 base64 加密会导致长度每大于 76 就会加入\r 或者 \n 这样的换行控制符,这样再使用encodeURIComponent进行编码就会产生 %0A 这样的字符,就会导致预览不了。解决办法就是base64编码后去除 \r 和 \n 然后再使用 encodeURIComponent 编码,encodeURIComponent 编码后再去除 %0A  
FineReport
FineReport 报表设计器
文档在线预览集成OfficeToHtml(支撑pc端和移动端在线预览)
近期项目中需要用到PC和移动端在线预览的功能,起初下载在线预览插件(试用版)发现无法支持移动端,无法满足项目要求。 集成pdf在线预览时发现了PDF.js (mozilla.github.io) ,可以通过url传参(附件路径)方式,在viewer.html中调用pdf.js代码实现pdf文件PC端和移动端在线预览的功能。 因为业务中上传了word等文件,于是继续寻找可在线预览docx、xlsx、pptx等后缀文件的工具,主要还是解决移动端的问题。 最终在一片博客中(纯前端文档预览,还要支持所有主流格式,有这一篇就足够了_docx-preview.js_喵喵喵更多的博客-CSDN博客),发现了一句话: 意外的收获 到此为止,所有的方案都被pass掉了,非常绝望。无果后,我搭上梯子,疯狂Google,终于找到了一个jquery的开源插件,叫做officeToHtml,出于对开源的尊重,这里提供一下人家的访问链接:OfficeJs | Demos,这个开源项目非常好用,引用它的demo就能直接预览主流格式,但是它是基于JQuery的。 经过半天的测试和代码合并,终于实现了一套简单的demo,具体代码如下: officetohtml.zip (18.48 M) 详细的操作方法如下: 1、将文件解压缩后放入到webroot下。 2、拼接url参数,实现本地文件在线预览 例如本地路径下有个文件 需要对demo.docx在线预览,可以在cpt里面写如下js脚本 //移动端js代码 var file_path="/webroot/officetohtml/pages/files/demo.docx";//文件路径从webroot开始。 var furl = "http://ip:port/webroot/officetohtml/pages/viewer.html?file=" + file_path; var url = encodeURI(furl); FR.doHyperlinkByGet({ url: url, target: '_self' }); //PC端js代码 var file_path="/webroot/officetohtml/pages/files/demo.docx";//文件路径从webroot开始。 var furl = "http://ip:port/webroot/officetohtml/pages/viewer.html?file=" + file_path; window.open(furl);   说明:pages/viewer.html 文件是我参考demos.html为移动端写的,主要用于传参和预览,非系统自带,其他的代码几乎没有变化(除了css的所调整外)。如开源版本有更新,下载新版本后直接覆盖整套系统就可实现完整替代,保证viewer.html文件不变即可,里面涉及到css和js,可以根据实际情况调整。 可在线预览文件类型为:pptx,docx,xlsx,pdf以及各种图片格式。  
个人成就
内容被浏览19,299
加入社区7年363天
返回顶部