java poi如何将Excel的03和07转成html(图片一定要显示出来)

java poi如何将Excel的03和07转成html(图片一定要显示出来),我已经做出一个版本,成功将xls和xlsx转html,但是图片显示不出来,急死我啦

3个回答

0000000000

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java poi讲doc或者excel的文件转成html格式后不能显示图片问题
java poi讲doc或者excel的文件转成html格式后不能显示图片问题,忘大神指点(最好现成代码)
java POI 读取excel文件报错误Invalid header signature
java POI 读取excel文件报错误Invalid header signature 查找了资料说是读取的是非标准的excel文件,我用文本编辑器打开文件是把html的table转换成的excel文件 ,请问你这个怎么解决呢?(不需要打开另存为的方式来解决哦,另存为excel文件就可以导入)
我用poi将doc或者Excel文件转为html格式在页面显示但是出现了一个问题
java 我用poi将doc或者Excel文件转为html格式在页面显示,首先创建一个html页面用于存放文件转换为html后的代码,比如我首先打开doc的文件,成功显示出来,但是第二次打开Excel的文件,页面却显示的还是doc的文件,再打开idea看代码,那html文件明明是Excel的。(我怀疑是页面缓存,但不知道该如何设置,html页面都是自动生成的无法修改头)
如何实现java将excel表格转成HTML实现在线编辑?
本地一张需要填写的EXCEL报表,用java代码转成html后,有什么办法可以实现在线编辑,填表
如何将word,excel,powerpoint等转换成html或pdf
如何将word,excel,powerpoint等转换成html或pdf 最项目要实现在线预览word,excel等功能,类似163邮箱的附件预览功能,找了很长时间也就是 POI 解析,但是都是解析为txt 纯文本的信息,虽然也可以解析图片出来,但样式已经破坏了。单单再window上部署的话可以有jcom,jacob这个几种方法来实现,但都依赖于 dll文件,在linux部署不了。想用Flexpaper来实践,但有几点疑问: 如果使用 Flexpaper 是不是要先将 word, excel等转换成 PDF,然后在使用 swftools 将PDF转换成 swf 疑问: 1. 将 word, excel, ppt 等转换成 PDF 应该使用什么开源的java类库? 2. java 如何调用 swftools 在 Linux 上将PDF转换成 swf文件?
poi 写入内置对象(excel内嵌excel对象)
最近需要使用poi生成一个excel,生成的excel内部有embed object--内置对象。此时我就不会做了,在poi的官网上有一个读取内置对象的例子(http://poi.apache.org/spreadsheet/quick-guide.html#Embedded---中的Embedded Objects#),但没看到怎么写入的! 请哪位大牛给一个例子,最好是写入excel对象到excel的!
关于java解析EXCEL问题
有份 EXCEL 文件无法用jxl和poi解析。poi解析时报错: Exception in thread "main" java.io.IOException: Invalid header signature; read 0x7265562D454D494D, expected 0xE11AB1A1E011CFD0 后来网上一查这个错,知道这个Excel文件 原来是一个mht/mhtml格式的文件,当然解析不了,可以通过打开这个Excel,在另存为Excel97-2003工作薄解决。 问题来了: 现在这些Excel是别人第三方平台批量生成的,来到我们这边的时候数量很庞大,不可能逐个点开另存为;当我想以解析html的方式解析这些Excel时,打开后发现其中里面的信息是这样的: <td>2015-05-27</td> <td>=E4=B8=9C=E6=96=B9=E6=97=A5=E5=8D=87=EF=BC=88300118=EF=BC=89=EF=BC=9A=E5=B8=83=E5=B1=80=E7=94=B5=E7=AB=99=E8=BF=90=E7=BB=B4=EF=BC=8C=E5=AE=8C=E5=96=84=E8=83=BD=E6=BA=90=E4=BA=92=E8=81=94=E7=BD=91=E6=88=98=E7=95=A5</td> <td>=E4=B8=9C=E6=96=B9=E6=97=A5=E5=8D=87</td> <td>=E9=95=BF=E6=B1=9F=E8=AF=81=E5=88=B8</td> <td>=E9=82=AC=E5=8D=9A=E5=8D=8E</td> 各种乱码不说,还有这些莫名其妙的东西,读出来也没意义。 问:怎样不打开另存为的情况下解析这些mht格式的Excel文件?或者有什么办法可以批量把这些mht格式的Excel文件自动另存为成Excel97-2003工作薄
使用了 FreeMarker+FTL模版导出word, 再通过 poi 将word转HTML会报错
FreeMarker导出的word能正常打开,就是 poi 转word 会报错。 这个问题在网上找了挺多资料的,基本上使用poi 的都是转excel 时报错的, 自己试验过,得出: 一般 的word是能被 poi 转 HTML, FreeMarker导出的word却不能poi 转 HTML 有以下报错 ``` java.io.IOException: Invalid header signature; read 0x6576206C6D783F3C, expected 0xE11AB1A1E011CFD0 at org.apache.poi.poifs.storage.HeaderBlock.<init>(HeaderBlock.java:140) at org.apache.poi.poifs.storage.HeaderBlock.<init>(HeaderBlock.java:104) at org.apache.poi.poifs.filesystem.POIFSFileSystem.<init>(POIFSFileSystem.java:138) at org.apache.poi.hwpf.HWPFDocumentCore.verifyAndBuildPOIFS(HWPFDocumentCore.java:106) at org.apache.poi.hwpf.HWPFDocument.<init>(HWPFDocument.java:174) at com.dayuan.util.PoiWordToHtml.creadHTML(PoiWordToHtml.java:35) at com.dayuan.controller.sampling.SamplingController.exportSimpleWord(SamplingController.java:263) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:213) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:126) at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:96) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:617) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:578) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:923) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778) at javax.servlet.http.HttpServlet.service(HttpServlet.java:635) at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:475) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:624) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:498) at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:796) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1366) at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Unknown Source) ``` 求大神支招
poi如何获得excel中多选框的值,如何判断当前是否是多选框
应要求要把excel转成html 还要把 文本框 多选框 单选框 下拉框 带过来, 看了一下api只找到了 HSSFTextbox 文本框的,问一下 多选框 单选框 下拉框,求大神解答
excel显示在页面上,包括格式
最近想着能否实现将excel的数据包括格式完整显示到页面来预览,用poi解析太繁琐,不知有没过来人
node转发请求,后台poi下载excel为什么一直不成功
![前台用form提交查询用的参数](https://img-ask.csdn.net/upload/201702/10/1486719189_743871.png) ![node转发到后台](https://img-ask.csdn.net/upload/201702/10/1486719212_142011.png) ![后台](https://img-ask.csdn.net/upload/201702/10/1486719224_827766.png) ![一直返回乱码,不下载](https://img-ask.csdn.net/upload/201702/10/1486719235_766177.png) ps:excel里面的数据是正确的,我用绝对路径输出,电脑里面有.xls文件。 求各位大神告诉我原因
Java下载文件时如何给前台返回一个值?
前台是用html写的不是jsp, 用poi生成excel直接通过流写回浏览器来下载 想到使用ajax,但是ajax是不支持文件下载的,但是用其他的方法如何在下载文件的代码 执行完毕以后给前台返回一个状态码来通知下载完成?
关于IE8导出POI生成的文件丢失文件名
response.addHeader("Content-Disposition", "attachment;filename=utf-8'zh_cn'" + fileName + ".xls"); 在IE11和其他浏览器正常,但是IE导出之后没有文件名和文件类型,文件名就是接口名称(但是手动给导出的文件添加类型之后可正常打开且内容是对的)例如: IE11、Chrome等浏览器导出文件为:我的Excel表格.xls IE8导出的文件为:exportExcel
在java web工程中·,利用ireport生成的jasper文件,导出pdf文件
我已经用ireport工具生成了jasper文件,并且利用ireport已经可以成功预览并生成pdf文件,但是现在需要在java web工程中,利用jasper文件生成相应的pdf文件,自己测视了好久,在网上也搜了好久,没有找到解决办法,现在把相应代码及错误贴出来,希望会做的朋友帮忙改正一下! 主要的servlet文件,在web.xml中都已将其配置好了 import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.File; import java.sql.Connection; import java.sql.SQLException; import java.util.HashMap; import java.util.Map; import util.JDBCConnection; import net.sf.jasperreports.engine.JRException; import net.sf.jasperreports.engine.JRExporterParameter; import net.sf.jasperreports.engine.JasperFillManager; import net.sf.jasperreports.engine.JasperPrint; import net.sf.jasperreports.engine.JasperReport; import net.sf.jasperreports.engine.JasperRunManager; import net.sf.jasperreports.engine.export.JRHtmlExporter; import net.sf.jasperreports.engine.export.JRHtmlExporterParameter; import net.sf.jasperreports.engine.export.JRPdfExporter; import net.sf.jasperreports.engine.export.JRXlsExporter; import net.sf.jasperreports.engine.export.JRXlsExporterParameter; import net.sf.jasperreports.engine.util.JRLoader; public class JRHTMLServlet extends HttpServlet { private Connection conn = JDBCConnection.getConnection(); //这个是连接mysql数据库 public JRHTMLServlet() { super(); } public void destroy() { super.destroy(); // Just puts "destroy" string in log // Put your code here } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String type = request.getParameter("type"); try { ServletContext servletContext = this.getServletContext(); File reportFile = new File(servletContext.getRealPath("/")+"/WEB-INF/report/Untitled_report_1.jasper"); Map parameters = new HashMap(); if("pdf".equals(type)){ byte[] bytes = JasperRunManager.runReportToPdf(reportFile.getPath(), parameters, conn); response.setContentType("application/pdf"); response.addHeader("Content-Disposition", "attachment; filename=report.pdf"); response.setContentLength(bytes.length); ServletOutputStream ouputStream = response.getOutputStream(); ouputStream.write(bytes, 0, bytes.length); ouputStream.flush(); ouputStream.close(); } else if ("excel".equals(type)){ JRXlsExporter exporter = new JRXlsExporter(); ByteArrayOutputStream oStream = new ByteArrayOutputStream(); JasperPrint jasperPrint = JasperFillManager.fillReport(reportFile.getPath(), parameters, conn); exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint); exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, oStream); exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE); exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET, Boolean.FALSE); exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, Boolean.FALSE); exporter.exportReport(); byte[] bytes = oStream.toByteArray(); response.setContentType("application/vnd.ms-excel"); response.addHeader("Content-Disposition", "attachment; filename=report.xls"); response.setContentLength(bytes.length); ServletOutputStream ouputStream = response.getOutputStream(); ouputStream.write(bytes, 0, bytes.length); ouputStream.flush(); ouputStream.close(); } else { JRHtmlExporter exporter = new JRHtmlExporter(); ByteArrayOutputStream oStream = new ByteArrayOutputStream(); JasperPrint jasperPrint = JasperFillManager.fillReport(reportFile.getPath(), parameters, conn); exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.FALSE); exporter.setParameter(JRHtmlExporterParameter.JASPER_PRINT, jasperPrint); exporter.setParameter(JRHtmlExporterParameter.CHARACTER_ENCODING, "utf-8"); exporter.setParameter(JRHtmlExporterParameter.OUTPUT_STREAM, oStream); exporter.exportReport(); byte[] bytes = oStream.toByteArray(); response.setContentType("text/html"); response.setContentLength(bytes.length); response.setCharacterEncoding("utf-8"); ServletOutputStream ouputStream = response.getOutputStream(); ouputStream.write(bytes, 0, bytes.length); ouputStream.flush(); ouputStream.close(); } } catch (JRException jre) { System.out.println("JRException:" + jre.getMessage()); } catch (Exception e) { System.out.println("Exception:" + e.getMessage()); } finally{ try { conn.close(); } catch (SQLException ex) { // TODO Auto-generated catch block ex.printStackTrace(); } } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); } } 在jsp文件中的主要代码: <a href="JRHTMLServlet?type=pdf">Servlet中生成pdf</a> <a href="JRHTMLServlet?type=excel">Servlet中生成excel</a> <a href="JRHTMLServlet?type=html">Servlet中生成html</a> 然后编译都没有问题,在执行时,如果点击了“Servlet中生成pdf”超链接,就会提示错误: JRException:Error evaluating expression : Source text : new java.lang.Integer(1) 若点击“Servlet中生成excel”超链接,就会提示错误: 严重: Servlet.service() for servlet JRHTMLServlet threw exception java.lang.ClassNotFoundException: org.apache.poi.ss.usermodel.Sheet 若点击“Servlet中生成html”超链接,就会提示错误: JRException:Error preparing statement for executing the report query : SELECT customer.`ID` AS customer_ID, customer.`USERNAME` AS customer_USERNAME, customer.`PASSWORD` AS customer_PASSWORD, customer.`REALNAME` AS customer_REALNAME, customer.`ADDRESS` AS customer_ADDRESS, customer.`MOBILE` AS customer_MOBILE, customer.`IDCARD_ID` AS customer_IDCARD_ID FROM `customer` customer 以上三种都试了,执行时,页面都可以跳转,但是跳转之后,都没有显示,直接出错了,我尝试了好久好久,确实不知道是什么问题,还请各位帮忙看看啊,在这里先谢谢你们啦 附:数据库的连接: String url = "jdbc:mysql://localhost/test"; String userName = "root"; String password = "123456"; Class.forName("com.mysql.jdbc.Driver"); Connection connection = DriverManager.getConnection(url, userName,password); 数据库表里面有中文,应该没有影响,现在只要求可以在web工程中导出pdf就可以了
使用Springmvc开发微信公众号数据传输问题
返回给微信服务器的XML格式的字符串,发现在公网Linux服务器中,tomcat的catalina.out文件打印的该字符串少了<ToUserName><![CDATA[toUser]]></ToUserName> <FromUserName><![CDATA[FromUser]]></FromUserName> <CreateTime>123456789</CreateTime> 这几行标签,手机微信提示该订阅号无法提供服务,请稍后再试。 该问题找了好久都找不出原因。是springmvc的数据传输有问题吗? 我贴一下springmvc.xml配置,求帮忙解答!!~ <!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 --> <!-- 加载controller的时候,不加载service,因为此时事物并未生效,若此时加载了service,那么事物无法对service进行拦截 --> <context:component-scan base-package="org.jeecgframework.web.*,weixin.*"> <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" /> </context:component-scan> <!-- ApplicationContext --> <bean class="org.jeecgframework.core.util.ApplicationContextUtil"></bean> <!-- 避免IE执行AJAX时,返回JSON出现下载文件 --> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> </list> </property> </bean> <!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射, 配置一个基于注解的定制的WebBindingInitializer,解决日期转换问题,方法级别的处理器映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="cacheSeconds" value="0" /> <property name="messageConverters"> <list> <ref bean="mappingJacksonHttpMessageConverter" /><!-- json转换器 --> </list> </property> <property name="webBindingInitializer"> <bean class="org.jeecgframework.core.interceptors.MyWebBinding" /> </property> </bean> <!-- 默认的视图解析器 在上边的解析错误时使用 (默认使用html)- --> <bean id="defaultViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:order="3"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" /> <property name="contentType" value="text/html" /> <property name="prefix" value="/webpage/" /> <property name="suffix" value=".jsp" /> </bean> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" p:defaultEncoding="UTF-8"> <property name="maxUploadSize"> <value>104857600</value> </property> <property name="maxInMemorySize"> <value>4096</value> </property> </bean> <!-- Bean解析器,级别高于默认解析器,寻找bean对象进行二次处理 --> <bean id="beanNameViewResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver" p:order="0"> </bean> <!-- Excel 处理 根据用户输入进行对象处理 --> <bean id="jeecgExcelView" class="org.jeecgframework.poi.excel.view.JeecgSingleExcelView" /> <!-- 方言 --> <bean id="dialect" class="org.jeecgframework.core.common.hibernate.dialect.DialectFactoryBean"> <property name="dbType" value="${jdbc.dbType}" /> </bean> <!-- 异常处理类 --> <bean id="exceptionHandler" class="org.jeecgframework.core.common.exception.MyExceptionHandler" /> <!-- 系统错误转发配置[并记录错误日志] --> <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <property name="defaultErrorView" value="500"></property> <!-- 默认为500,系统错误(error.jsp) --> <property name="defaultStatusCode" value="404"></property> <property name="statusCodes"><!-- 配置多个statusCode --> <props> <prop key="error">500</prop> <!-- error.jsp --> <prop key="error1">404</prop> <!-- error1.jsp --> </props> </property> <property name="exceptionMappings"> <props> <!-- 这里你可以根据需要定义N多个错误异常转发 --> <prop key="java.sql.SQLException">dbError</prop> <!-- 数据库错误(dbError.jsp) --> <prop key="org.springframework.web.bind.ServletRequestBindingException">bizError</prop> <!-- 参数绑定错误(如:必须参数没传递)(bizError.jsp) --> <prop key="java.lang.IllegalArgumentException">bizError</prop> <!-- 参数错误(bizError.jsp) --> <prop key="org.springframework.validation.BindException">bizError</prop> <!-- 参数类型有误(bizError.jsp) --> <prop key="java.lang.Exception">unknowError</prop> <!-- 其他错误为'未定义错误'(unknowError.jsp) --> </props> </property> </bean> <!-- 拦截器 --> <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**" /> <bean class="org.jeecgframework.core.interceptors.EncodingInterceptor" /> </mvc:interceptor> <mvc:interceptor> <mvc:mapping path="/**" /> <bean class="org.jeecgframework.core.interceptors.AuthInterceptor"> <property name="excludeUrls"> <list> <value>loginController.do?goPwdInit</value> <value>loginController.do?pwdInit</value> <value>loginController.do?login</value> <value>loginController.do?checkuser</value> <value>repairController.do?repair</value> <value>repairController.do?deleteAndRepair</value> <value>cmsMenuController.do?index</value> <value>cmsArticleController.do?cmsArticleListShow</value> <value>cmsArticleController.do?datagridwx</value> <value>cmsArticleController.do?cmsArticleShow</value> <value>cmsController.do?goPage</value> <value>cmsController.do?getMenuList</value> <value>wechatController.do?wechat</value> <value>zpController.do?iscontinue</value> <value>zpController.do?saveZpPrize</value> <value>zpController.do?getZpPize</value> <value>zpController.do?saverecord</value> <value>zpController.do?ggl_new</value> <value>zpController.do?ggl</value> <value>zpController.do?zp</value> <value>zpController.do?goZhuanpan</value> <value>weixinCmsStyleController.do?upload</value> <value>newsItemController.do?newscontent</value> <!-- 保存用户 --> <value>userController.do?saveUser</value> </list> </property> </bean> </mvc:interceptor> </mvc:interceptors>
关于excel文件导入到mysql数据没有读取到文件问题
<p>  我最近在做一个oa项目,其中有一个excel文件导入到数据中去,用poi做的。我现在在后台能够得到文件的完整路径,但是HSSFWorkbook并没有创建一个工作簿。在网上找了很多资料,并没有找到解决方案,本人是只菜鸟,望各位大侠指路,帮忙看看。谢谢!</p> <p>前台import.jsp代码:</p> <div class="quote_title">写道</div> <div class="quote_div">&lt;%@ page contentType="text/html;charset=GBK"%&gt; <br>&lt;%@ page session="true" %&gt; <br>&lt;%@ page isThreadSafe="true" %&gt; <br>&lt;head&gt; <br><br>&lt;style type="text/css"&gt; <br>&lt;!-- <br>body,td,th { <br>font-size: 12px; <br>} <br>--&gt; <br>&lt;/style&gt; <br>&lt;title&gt;&lt;/title&gt; <br>&lt;/head&gt; <br>&lt;body &gt; <br><br>&lt;script language="javascript"&gt; <br>function add(){ <br>var filePath = document.myform.Urlexcel.value; <br>alert(filePath); <br>myform.action="saveExcel.jsp?filePath="+filePath ; <br>myform.submit(); <br>} <br><br>&lt;/script&gt; <br>&lt;form action="saveExcel.jsp" enctype="multipart/form-data" name="myform" method="post" onSubmit="return check(this)"&gt; <br><br>&lt;p&gt; &lt;/p&gt; <br>&lt;p&gt; &lt;/p&gt; <br>&lt;p&gt; &lt;/p&gt; <br>&lt;table width="80%" border="0" align="center" cellpadding="0" cellspacing="0"&gt; <br>&lt;tr&gt; <br>&lt;td height="50" align="center" valign="middle"&gt; &lt;/td&gt; <br>&lt;td height="50" align="left" valign="middle"&gt; Excel文件: <br>&lt;input name="Urlexcel" type="file" id="Urlexcel" size="41" /&gt;&lt;/td&gt; <br>&lt;td&gt; &lt;/td&gt; <br>&lt;/tr&gt; <br>&lt;tr&gt; <br><br>&lt;td height="50" align="center" valign="middle" colspan="2"&gt; <br>&lt;input type="button" onClick="add();" name="Submit1" value="确认提交" /&gt; <br>         <br>&lt;input type="submit" name="Submit2" value="取消重置" /&gt; <br>&lt;/td&gt; <br>&lt;td&gt; &lt;/td&gt; <br>&lt;/tr&gt; <br>&lt;/table&gt; <br>&lt;/form&gt; <br><br>&lt;/body&gt; <br>&lt;/html&gt;</div> <p> </p> <p>后台saveExcel.jsp代码:</p> <pre name="code" class="java">&lt;%@ page language="java"%&gt; &lt;%@ page session="true"%&gt; &lt;%@ page isThreadSafe="true"%&gt; &lt;%@ page contentType="text/html;charset=GBK"%&gt; &lt;%@page import="org.apache.poi.hssf.usermodel.HSSFWorkbook"%&gt; &lt;%@page import="java.io.FileInputStream"%&gt; &lt;%@page import="org.apache.poi.hssf.usermodel.HSSFSheet"%&gt; &lt;%@page import="org.apache.poi.hssf.usermodel.HSSFCell"%&gt; &lt;%@page import="org.apache.poi.hssf.usermodel.HSSFRow"%&gt; &lt;%@page import="java.io.FileNotFoundException"%&gt; &lt;%@page import="java.io.IOException"%&gt; &lt;%@page import="org.apache.poi.poifs.filesystem.POIFSFileSystem"%&gt; &lt;% String filePath = request.getParameter("filePath"); out.println(filePath); try { // 创建对Excel工作簿文件的引用 FileInputStream fis = new FileInputStream(filePath); POIFSFileSystem fs = new POIFSFileSystem(fis); HSSFWorkbook wookbook = new HSSFWorkbook(fs); out.println(wookbook);//此处并没有打印出能容 HSSFSheet sheet = wookbook.getSheet("Sheet1"); // 获取到Excel文件中的所有行数 int rows = sheet.getPhysicalNumberOfRows(); out.println(rows); // 遍历行 for (int i = 0; i &lt; rows; i++) { // 读取左上端单元格? HSSFRow row = sheet.getRow(i); // 行不为空 if (row != null) { // 获取到Excel文件中的所有的列 int cells = row.getPhysicalNumberOfCells(); String value = ""; // 遍历列 for (short j = 0; j &lt; cells; j++) { // 获取到列的值 HSSFCell cell = row.getCell(j); if (cell != null) { switch (cell.getCellType()) { case HSSFCell.CELL_TYPE_FORMULA: break; case HSSFCell.CELL_TYPE_NUMERIC: value += cell.getNumericCellValue() + ","; break; case HSSFCell.CELL_TYPE_STRING: value += cell.getStringCellValue() + ","; break; default: value += "0"; break; } } } // 将数据插入到mysql数据库中 String[] val = value.split(","); Nsxxb1 entity = new Nsxxb1() ; entity.setGLM(val[0]); entity.setQYMC(val[1]); entity.setXSE1(Double.parseDouble(val[2])); entity.setZZS1(Double.parseDouble(val[3])); entity.setYYS1(Double.parseDouble(val[4])); entity.setXFS1(Double.parseDouble(val[5])); entity.setQYSDS1(Double.parseDouble(val[6])); entity.setGRSDS1(Double.parseDouble(val[7])); entity.setYHS1(Double.parseDouble(val[8])); entity.setTDZZS1(Double.parseDouble(val[9])); entity.setCJS1(Double.parseDouble(val[10])); Nsxxb1Service.insert(entity); } } catch (FileNotFoundException e) { out.println("导入失败"); e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } %&gt; </pre> <p> </p>
问下前端form表单验证怎么做
_不好意思新手 1、就是点击提交 比如没有选择文件 就前端提示请选择excel文件,不晓得前端怎么验证 ,现在点一下直接跳出来"success":false,"msg":"请选择excel文件"} 2、后端验证有好几个 这么多一起是怎么写前端验证的 java 和html代码附上 ``` public Object importExcel(UploadFile files) { Map<String, Object> map=new LinkedHashMap<String, Object>(); if (files==null||StrKit.isBlank(files.getFileName())) { map.put("success", false); map.put("msg", "请选择excel文件"); return map; } else { String filename = PathKit.getWebRootPath() + "/upload/" + files.getFileName(); filename = filename.replaceAll("\\\\", "/"); int cells = 0; int rows=0; int ColCount=5;//导入的字段数 try { HSSFWorkbook wookbook =new HSSFWorkbook(new FileInputStream(filename)); HSSFSheet sheet = wookbook.getSheetAt(0); rows = sheet.getPhysicalNumberOfRows(); Object[][] paras = new Object[rows-1][ColCount]; for (int i = 0; i < rows; i++) { HSSFRow row = sheet.getRow(i); cells = row.getPhysicalNumberOfCells(); if (row != null) { if (i==0) { if (cells!=ColCount) { map.put("success", false); map.put("msg", "数据有误,请查看注意事项!"); return map; } } else { for (int j = 0; j < cells; j++) { HSSFCell cell = row.getCell(j); if (cell != null) { switch (cell.getCellType()) { case HSSFCell.CELL_TYPE_FORMULA: break; case HSSFCell.CELL_TYPE_NUMERIC: if (HSSFDateUtil.isCellDateFormatted(cell)) {// 处理日期格式 SimpleDateFormat sdf = null; if (cell.getCellStyle().getDataFormat() == HSSFDataFormat .getBuiltinFormat("h:mm")) { sdf = new SimpleDateFormat("HH:mm"); } else {// 日期 sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); } Date date = cell.getDateCellValue(); paras[i-1][j] = sdf.format(date); } else if (cell.getCellStyle().getDataFormat() == 58) { // 处理自定义日期格式:m月d日(通过判断单元格的格式id解决,id的值是58) SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); double value = cell.getNumericCellValue(); Date date = org.apache.poi.ss.usermodel.DateUtil .getJavaDate(value); paras[i-1][j] = sdf.format(date); } else { double value = cell.getNumericCellValue(); CellStyle style = cell.getCellStyle(); DecimalFormat format = new DecimalFormat(); String temp = style.getDataFormatString(); // 单元格设置成常规 if (temp.equals("General")) { format.applyPattern("#"); } paras[i-1][j] = format.format(value); } // paras[i-1][j] = cell.getNumericCellValue(); break; case HSSFCell.CELL_TYPE_STRING: paras[i-1][j] = cell.getStringCellValue(); break; default: paras[i-1][j] = null; break; } } } } } } for (int i = 0; i < paras.length; i++) { for (int j = 0; j < paras[i].length; j++) { if (j==0||j==1||j==2||j==4||j==5) {//非空的列 if (paras[i][j]==null||validateIsBlank((String)paras[i][j])) { map.put("success", false); map.put("msg", "第"+(i+2)+"行,第"+(j+1)+"列不能为空!"); return map; } if(j==0){//检测联系电话 if (!validateSensorId((String) paras[i][j])) { map.put("success", false); map.put("msg", "第"+(i+2)+"行,第"+(j+1)+"列的\"联系电话传感器Id\"必须为数字"); return map; } } } } } int[] ret=null; String sql="insert into `repairs`(name,address,tel,type,baddescribe)values(?,?,?,?,?)"; try { ret = Db.batch(sql, paras, 100); int s = 0, l = 0; for (int i = 0; i < ret.length; i++) if (ret[i] == 1) s++; else l++; map.put("success", true); map.put("msg", "导入成功,共导入"+s+"行数据,丢失"+l+"行数据"); wookbook = null; } catch (Exception e) { e.printStackTrace(); map.put("success", false); map.put("msg", "系统异常,稍后再试"); } } catch (IOException e) { e.printStackTrace(); map.put("success", false); map.put("msg", "系统异常,稍后再试"); } ExcelImportUtil.deleteFile(new File(filename));//录入完将上传的文件删除 return map; } } 前端 <form action="/repairs/importExcel" id="addListForm" class="am-form tpl-form-line-form" enctype="multipart/form-data" method="post" onsubmit="return checkIP();"> <div class="am-form-group"> <label for="user-name" class="am-u-sm-3 am-form-label">上传文件(.xls格式)</label> <div class="am-u-sm-9"> <input type="file" name="excel" id="excel" class="tpl-form-input" > </div> </div> <div class="am-form-group"> <div class="am-u-sm-9 am-u-sm-push-3"> <a href="/repairs" class="" >取消</a> <input class=" " id="addList" value="提交" type="submit"> </div> </div> </form> ``` _
win7系统报错getOutputStream() has already been called for this response.但是xp系统没问题...
<div class="iteye-blog-content-contain" style="font-size: 14px;"> <p>    最近这个问题搞的很头疼,debug过了,action中执行到return "SUCCESS"就报出错误堆栈了,所以应该是jsp文件写的有问题,JSP文件中根本就没有发现getOutputStream(),引入的文件中也没有</p> <p>    而且更奇怪的是,在我开发的机器上和经理的电脑上都报这个错误,但是在业务的员工的电脑上没出现这个错误,所以推测是代码的某些部分可能存在不兼容的问题,因为我的电脑和经理的电脑是win7的系统,业务的员工的电脑是XP的系统,然后再测试人员的电脑上面进xp的虚拟机也不会报这样的问题</p> <p>    但是实在看不出来代码存在什么样的问题,百度了N条记录,说是加入2行代码的什么的,但是JSP文件中压根就没有getOutputStream()的语句存在.</p> <p>     贴上几段代码吧,希望大神能帮忙分析下问题:</p> <p>     首先是错误堆栈(win7系统):</p> <p>    </p> <pre name="code" class="java">2013-1-24 16:26:02 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() for servlet default threw exception java.lang.IllegalStateException: getOutputStream() has already been called for this response at org.apache.catalina.connector.Response.getWriter(Response.java:601) at org.apache.catalina.connector.ResponseFacade.getWriter(ResponseFacade.java:196) at javax.servlet.ServletResponseWrapper.getWriter(ServletResponseWrapper.java:157) at org.apache.jasper.runtime.JspWriterImpl.initOut(JspWriterImpl.java:125) at org.apache.jasper.runtime.JspWriterImpl.flushBuffer(JspWriterImpl.java:118) at org.apache.jasper.runtime.JspWriterImpl.write(JspWriterImpl.java:326) at org.apache.jasper.runtime.JspWriterImpl.write(JspWriterImpl.java:342) at org.apache.jsp.jsp.query.integrative.integrative_jsp._jspx_meth_c_005fotherwise_005f1(integrative_jsp.java:1180) at org.apache.jsp.jsp.query.integrative.integrative_jsp._jspx_meth_c_005fchoose_005f1(integrative_jsp.java:1119) at org.apache.jsp.jsp.query.integrative.integrative_jsp._jspx_meth_c_005fforEach_005f1(integrative_jsp.java:1079) at org.apache.jsp.jsp.query.integrative.integrative_jsp._jspService(integrative_jsp.java:362) at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:98) at javax.servlet.http.HttpServlet.service(HttpServlet.java:856) at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:328) at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:315) at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265) at javax.servlet.http.HttpServlet.service(HttpServlet.java:856) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:691) at org.apache.catalina.core.ApplicationDispatcher.doInclude(ApplicationDispatcher.java:594) at org.apache.catalina.core.ApplicationDispatcher.include(ApplicationDispatcher.java:505) at org.apache.struts2.dispatcher.ServletDispatcherResult.doExecute(ServletDispatcherResult.java:141) at org.apache.struts2.dispatcher.StrutsResultSupport.execute(StrutsResultSupport.java:178) at com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:343) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248) at com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:213) at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:150) at org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:48) at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:123) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ParametersInterceptor.intercept(ParametersInterceptor.java:161) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:105) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:83) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:207) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:74) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:107) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:206) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:115) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.PrepareInterceptor.intercept(PrepareInterceptor.java:115) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:170) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:123) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at com.mangocity.ds.framework.common.controller.ActionInfoInterceptor.intercept(ActionInfoInterceptor.java:55) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219) at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218) at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455) at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216) at org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:50) at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:507) at org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:421) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:264) at org.acegisecurity.intercept.web.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:107) at org.acegisecurity.intercept.web.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:72) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.ui.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:110) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.providers.anonymous.AnonymousProcessingFilter.doFilter(AnonymousProcessingFilter.java:125) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.wrapper.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:81) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:217) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.ui.logout.LogoutFilter.doFilter(LogoutFilter.java:106) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:229) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:274) at org.acegisecurity.util.FilterChainProxy.doFilter(FilterChainProxy.java:148) at org.acegisecurity.util.FilterToBeanProxy.doFilter(FilterToBeanProxy.java:98) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:210) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:174) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:151) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:870) at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665) at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528) at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81) at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:685) at java.lang.Thread.run(Thread.java:619) </pre> <p> action的代码,请求到的方法:</p> <p>   </p> <pre name="code" class="java">/** * 2008-05-06 V2.6.0 SR029 常锐 导出配送单信息 * * @return * @throws Exception */ public String exportExcelDeliveryBill() throws Exception { init(); List&lt;String&gt; unitIdList = new ArrayList&lt;String&gt;(); List&lt;String&gt; centerIdList = new ArrayList&lt;String&gt;(); // 判断是否有权限 if (null != getSystemType().getUnitList() &amp;&amp; 0 &lt; getSystemType().getUnitList().size() &amp;&amp; null != getSystemType().getCenterList() &amp;&amp; 0 &lt; getSystemType().getCenterList().size()) { for (int i = 0; i &lt; getSystemType().getUnitList().size(); i++) { unitIdList.add(((DeliveryUnit) getSystemType().getUnitList().get(i)).getId()); } for (int i = 0; i &lt; getSystemType().getCenterList().size(); i++) { centerIdList.add(((DeliveryCenter) getSystemType().getCenterList().get(i)).getId()); } showOther = ((IntegrativeService) getDBService()).getDeliveryBillList(getParams(), getPage(), unitIdList, centerIdList); } showDeliveryList = "yes"; HttpServletResponse response = super.getHttpServletResponse(); response.reset(); response.setContentType("application/vnd.ms-excel");// "application/msexcel" response.setCharacterEncoding("GBK"); response.setHeader("Content-disposition", "attachment;filename=配送单综合查询.xsl"); OutputStream outStrean = response.getOutputStream(); // 获取addressList List addressList = this.getSystemType().getAreaAddressList(); HSSFWorkbook demoWorkBook = ((IntegrativeService) getDBService()).exportExcelDeliveryBill( getParams(), unitIdList, centerIdList, addressList); demoWorkBook.write(outStrean); outStrean.flush(); outStrean.close(); return SUCCESS; }</pre> <p> </p> <p>返回到的JSP页面(发出请求的也是这个页面):</p> <p>   </p> <pre name="code" class="java">&lt;%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%&gt; &lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"&gt; &lt;html&gt; &lt;head&gt; &lt;%@ page import="org.apache.poi.hssf.usermodel.HSSFWorkbook" %&gt; &lt;%@ page import="com.opensymphony.xwork2.util.*" %&gt; &lt;%@ include file="/jsp/common/commonheader.jsp"%&gt; &lt;script src="&lt;%=webPath%&gt;/js/query.js"&gt;&lt;/script&gt; &lt;script src="&lt;%=webPath%&gt;/js/operate.js"&gt;&lt;/script&gt; &lt;script type="text/javascript"&gt; function exportExcel() { if(checkQueryForm()) { queryform.action ="IntegrativeAction_exportExcelDeliveryBill.do"; queryform.submit(); } else return false; } function submitForm(){ if(checkQueryForm()) { queryform.action ="IntegrativeAction_queryByDeliveryBill.do"; queryform.submit(); } else return false; } function checkQueryForm() { if(!validate_form(queryform))return false; if(!checkDeliveryDate("billcreatedatebegin","billcreatedateend")){ return false; } if(!checkDeliveryDate("deliverydatebegin","deliverydateend")){ return false; } if(!checkDeliveryDate("deliveryendbegin","deliveryendend")){ return false; } var deliveryCD = queryform.elements["params.deliveryCD"].value; var orderCD = queryform.elements["params.orderCD"].value; var billcreatedatebegin = document.getElementById("billcreatedatebegin").value; var deliverydatebegin = document.getElementById("deliverydatebegin").value; var deliveryendbegin = document.getElementById("deliveryendbegin").value; var billcreatedateend = document.getElementById("billcreatedateend").value; var deliverydateend = document.getElementById("deliverydateend").value; var deliveryendend = document.getElementById("deliveryendend").value; var deliveryCenter = document.getElementById("deliveryCenter").value; if(deliveryCD=="" &amp;&amp; orderCD==""){ if(deliveryCenter==""){ alert("请使用以下三种方式中的一种进行查询:\n\n1.配送中心+配送单创建时间\n2.配送中心+预约配送时间\n3.配送中心+配送完成时间"); return false; } if(billcreatedatebegin=="" &amp;&amp; deliverydatebegin=="" &amp;&amp; deliveryendbegin=="") { alert("请使用以下三种方式中的一种进行查询:\n\n1.配送中心+配送单创建时间或\n2.配送中心+预约配送时间或\n3.配送中心+配送完成时间"); return false; } } if(better_time(billcreatedatebegin,billcreatedateend)&gt;180){ alert(document.getElementById("billcreatedateend").title+"不应超过六个月!"); return false; } if(better_time(deliverydatebegin,deliverydateend)&gt;180){ alert(document.getElementById("deliverydateend").title+"不应超过六个月!"); return false; } if(better_time(deliveryendbegin,deliveryendend)&gt;180){ alert(document.getElementById("deliveryendend").title+"不应超过六个月!"); return false; } return true; } &lt;/script&gt; &lt;/head&gt; &lt;body&gt; &lt;form name="queryform" action="IntegrativeAction_queryByDeliveryBill.do" method="post"&gt; &lt;table width="20%" border="0" cellpadding="3" cellspacing="0"&gt; &lt;tr&gt; &lt;td height="18" &gt;&lt;strong&gt;&lt;img src="&lt;%=webPath%&gt;/images/arrow.gif" width="9" height="9"&gt; 综合查询&lt;/strong&gt;&lt;/td&gt; &lt;/tr&gt; &lt;/table&gt; &lt;table width="100%" class="table_bg" align="center" border="0" cellpadding="1" cellspacing="0"&gt; &lt;tr&gt; &lt;td&gt;&lt;input type="hidden" id="showother" value="${showOther}" /&gt; &lt;input type="hidden" id="showotherinfo" value="yesorno" /&gt; &lt;input type="hidden" id="showdeliverylist" value="${showDeliveryList }" /&gt; &lt;input type="hidden" id="urgencyCopy" value="${params.urgency }" /&gt; &lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td height="18"&gt;&lt;img src="&lt;%=webPath%&gt;/images/a2.gif" width="9" height="9"&gt; &lt;a href="#" onClick="javascript:playTableDelivery('deliverTbl')"&gt; &lt;font color="#FF9933"&gt;配送单信息&lt;/font&gt;&lt;/a&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr&gt; &lt;td&gt;&lt;table width="100%" class="table_bg" align="center" border="0" cellpadding="1" cellspacing="0" style="display:block" id="deliverTbl"&gt; &lt;tr class="search_bg"&gt; &lt;td width="15%"&gt;配送单编号&lt;/td&gt; &lt;td width="32%"&gt;&lt;input type="text" name="params.deliveryCD" value="${params.deliveryCD}" maxlength="50"&gt;&lt;/td&gt; &lt;td width="18%"&gt;订单编号&lt;/td&gt; &lt;td width="35%"&gt;&lt;input type="text" name="params.orderCD" value="${params.orderCD}" maxlength="50"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td width="15%"&gt;订单来源&lt;/td&gt; &lt;td width="32%"&gt;&lt;select id="billResouceOne" name="params.billResouce"&gt; &lt;option value=""&gt;-全部-&lt;/option&gt; &lt;c:forEach var="billResouce" items="${systemType.billResouce}"&gt; &lt;c:choose&gt; &lt;c:when test="${billResouce.value == params.billResouce}"&gt; &lt;option value="${billResouce.value}" selected&gt;${billResouce.label}&lt;/option&gt; &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;option value="${billResouce.value}"&gt;${billResouce.label}&lt;/option&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/c:forEach&gt; &lt;/select&gt;&lt;/td&gt; &lt;td&gt;配送方式&lt;/td&gt; &lt;td&gt;&lt;select name="params.deliveryType"&gt; &lt;option value=""&gt;-全部-&lt;/option&gt; &lt;c:forEach var="deliveryType" items="${systemType.deliveryType}"&gt; &lt;c:choose&gt; &lt;c:when test="${deliveryType.value == params.deliveryType}"&gt; &lt;option value="${deliveryType.value}" selected&gt;${deliveryType.label}&lt;/option&gt; &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;option value="${deliveryType.value}"&gt;${deliveryType.label}&lt;/option&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/c:forEach&gt; &lt;/select&gt; &lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;配送中心&lt;/td&gt; &lt;td&gt;&lt;select name="params.centerCD" id="deliveryCenter"&gt; &lt;option value=""&gt;--全部--&lt;/option&gt; &lt;/select&gt;&lt;/td&gt; &lt;td&gt;配送单位&lt;/td&gt; &lt;td&gt;&lt;select name="params.deliveryUnitCD" id="deliveryUnit"&gt; &lt;option value=""&gt;--全部--&lt;/option&gt; &lt;/select&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;配送任务状态&lt;/td&gt; &lt;td&gt;&lt;select name="params.deliveryState"&gt; &lt;option value=""&gt;-全部-&lt;/option&gt; &lt;c:forEach var="deliveryStateTwo" items="${systemType.deliveryState}"&gt; &lt;c:choose&gt; &lt;c:when test="${deliveryStateTwo.value == params.deliveryState}"&gt; &lt;option value="${deliveryStateTwo.value}" selected&gt;${deliveryStateTwo.label}&lt;/option&gt; &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;option value="${deliveryStateTwo.value}"&gt;${deliveryStateTwo.label}&lt;/option&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/c:forEach&gt; &lt;/select&gt;&lt;/td&gt; &lt;td&gt;收款任务状态&lt;/td&gt; &lt;td&gt;&lt;select name="params.gatheringState"&gt; &lt;option value=""&gt;-全部-&lt;/option&gt; &lt;c:forEach var="deliveryState" items="${systemType.deliveryState}"&gt; &lt;c:choose&gt; &lt;c:when test="${deliveryState.value == params.gatheringState}"&gt; &lt;option value="${deliveryState.value}" selected&gt;${deliveryState.label}&lt;/option&gt; &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;option value="${deliveryState.value}"&gt;${deliveryState.label}&lt;/option&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/c:forEach&gt; &lt;/select&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;配送员姓名&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.delivererName" value="${params.delivererName}" maxlength="50"&gt;&lt;/td&gt; &lt;td&gt;收件人&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.addresseeName" value="${params.addresseeName}" maxlength="50"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;配送接票时间&lt;/td&gt; &lt;td&gt;&lt;input type="text" id="deliveryconnect" name="params.deliveryConnect" value="${params.deliveryConnect }" size="15"&gt; &lt;a href="javascript:showCalendar('deliveryconnect',false,'deliveryconnect')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt;&lt;/td&gt; &lt;td&gt;收件人联系电话&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.addresseePhone" value="${params.addresseePhone}" maxlength="50"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;会员编号&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.memberName" value="${params.memberName}" maxlength="50"&gt;&lt;/td&gt; &lt;td&gt;收件人手机号&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.addresseeMobile" value="${params.addresseeMobile}" maxlength="50"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;第三方收件人&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.linkman" value="${params.linkman}" maxlength="50"&gt;&lt;/td&gt; &lt;td&gt;第三方收件人联系电话&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.linkmanPhone" value="${params.linkmanPhone}" maxlength="50"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;配送单创建时间&lt;/td&gt; &lt;td&gt;&lt;input type="text" size="10" id="billcreatedatebegin" name="params.billCreateDateBegin" value="${params.billCreateDateBegin }" dataType="date"&gt; &lt;a href="javascript:showCalendar('billcreatedatebegin',false,'billcreatedatebegin','billcreatedateend','billcreatedateend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt; &lt;input type="text" size="10" id="billcreatedateend" name="params.billCreateDateEnd" value="${params.billCreateDateEnd }" title="配送单创建时间" dataType="date"&gt; &lt;a href="javascript:showCalendar('billcreatedateend',false,'billcreatedateend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt;&lt;/td&gt; &lt;td&gt;预约配送时间&lt;/td&gt; &lt;td&gt;&lt;input type="text" size="10" id="deliverydatebegin" name="params.deliveryDateBegin" value="${params.deliveryDateBegin}" dataType="date"&gt; &lt;a href="javascript:showCalendar('deliverydatebegin',false,'deliverydatebegin','deliverydateend','deliverydateend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt; &lt;input type="text" size="10" id="deliverydateend" name="params.deliveryDateEnd" value="${params.deliveryDateEnd }" title="预约配送时间" dataType="date"&gt; &lt;a href="javascript:showCalendar('deliverydateend',false,'deliverydateend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td&gt;紧急程度&lt;/td&gt; &lt;td&gt;&lt;select id="urgencyOne" name="params.urgency"&gt; &lt;option value=""&gt;-全部-&lt;/option&gt; &lt;c:forEach var="urgency" items="${systemType.urgencyType}"&gt; &lt;c:choose&gt; &lt;c:when test="${urgency.value == params.urgency}"&gt; &lt;option value="${urgency.value}" selected&gt;${urgency.label}&lt;/option&gt; &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;option value="${urgency.value}"&gt;${urgency.label}&lt;/option&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/c:forEach&gt; &lt;/select&gt;&lt;/td&gt; &lt;td&gt;配送完成时间&lt;/td&gt; &lt;td&gt;&lt;input type="text" size="10" id="deliveryendbegin" name="params.deliveryEndBegin" value="${params.deliveryEndBegin}" dataType="date"&gt; &lt;a href="javascript:showCalendar('deliveryendbegin',false,'deliveryendbegin','deliveryendend','deliveryendend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt; &lt;input type="text" size="10" id="deliveryendend" name="params.deliveryEndEnd" value="${params.deliveryEndEnd }" title="配送完成时间" dataType="date"&gt; &lt;a href="javascript:showCalendar('deliveryendend',false,'deliveryendend')"&gt; &lt;img src="&lt;%=webPath%&gt;/images/i_date.gif" width="29" height="22" align="middle" border=0&gt;&lt;/a&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr&gt;&lt;td&gt;配送地址&lt;/td&gt; &lt;td&gt;&lt;input type="text" name="params.deliveryAddress" value="${params.deliveryAddress}" maxlength="100"&gt;&lt;/td&gt;&lt;/tr&gt; &lt;/table&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td height="18" colspan="4" valign="middle"&gt;&lt;img src="&lt;%=webPath%&gt;/images/a2.gif" width="9" height="9"&gt; &lt;a href="#" onClick="javascript:playTableOther('otherTbl')"&gt; &lt;font color="#FF9933"&gt;其他信息&lt;/font&gt;&lt;/a&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr&gt; &lt;td&gt;&lt;table width="100%" class="table_bg " align="center" border="0" cellpadding="1" cellspacing="0" style="display:none" id="otherTbl"&gt; &lt;tr class="search_bg"&gt; &lt;td width="15%"&gt;异常问题大类&lt;/td&gt; &lt;td&gt;&lt;select name="params.questionBigCode" id="billProblemBigType"&gt; &lt;option value=""&gt;--全部--&lt;/option&gt; &lt;/select&gt;&lt;/td&gt; &lt;td width="15%"&gt;异常问题小类&lt;/td&gt; &lt;td&gt;&lt;select name="params.questionSmallCode" id="billProblemSmallType" style="display:inline;width:340"&gt; &lt;option value=""&gt;--全部--&lt;/option&gt; &lt;/select&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td width="15%"&gt;问题处理&lt;/td&gt; &lt;td width="35%"&gt;&lt;input type="text" name="params.processMethod" value="${params.processMethod }"&gt;&lt;/td&gt; &lt;td&gt;建单原因&lt;/td&gt; &lt;td colspan="3"&gt;&lt;input type="text" name="params.createBillCause" value="${params.createBillCause }"&gt;&lt;/td&gt; &lt;/tr&gt; &lt;/table&gt;&lt;/td&gt; &lt;/tr&gt; &lt;tr class="search_bg"&gt; &lt;td align="right" colspan="4"&gt; &lt;input type="button" class="btn" value="导 出 EXCEL" style="width:100px" onClick="exportExcel();"&gt; &amp;nbsp; &lt;input type="submit" class="btn" value="查 询" onClick="return submitForm();"&gt; &amp;nbsp; &lt;input type="button" class="btn" value="重 置" onClick="javascript:clearForm('queryform');"&gt; &amp;nbsp; &lt;/td&gt; &lt;/tr&gt; &lt;/table&gt; &lt;table width="20%" border="0" cellpadding="3" cellspacing="0"&gt; &lt;tr&gt; &lt;td height="18" &gt;&lt;strong&gt;&lt;img src="&lt;%=webPath%&gt;/images/arrow.gif" width="9" height="9"&gt; 结果列表&lt;/strong&gt;&lt;/td&gt; &lt;/tr&gt; &lt;/table&gt; &lt;table width="100%" class="table_bg" align="center" border="1" cellpadding="1" cellspacing="0" id="orderlist"&gt; &lt;tr align="center" class="sub_bg"&gt; &lt;td width="1%"&gt;紧急度&lt;/td&gt; &lt;td width="10%"&gt;订单编号&lt;br&gt;订单类型&lt;/td&gt; &lt;td width="11%"&gt;配送单编号&lt;br&gt;配送单创建时间&lt;/td&gt; &lt;td width="8%"&gt;会员类型&lt;br&gt;VIP级别&lt;/td&gt; &lt;td width="6%"&gt;配送单位&lt;/td&gt; &lt;td width="9%"&gt;配送方式&lt;br&gt;任务类型&lt;/td&gt; &lt;td width="8%"&gt;配送城市&lt;br&gt;/城区&lt;/td&gt; &lt;td width="10%"&gt;配送地址&lt;/td&gt; &lt;td width="10%"&gt;配送时间&lt;/td&gt; &lt;td width="8%"&gt;配送员姓名&lt;br&gt;联系电话&lt;/td&gt; &lt;td width="7%"&gt;截余时间&lt;/td&gt; &lt;td width="6%"&gt;配送任务状态&lt;/td&gt; &lt;td width="6%"&gt;收款任务状态&lt;/td&gt; &lt;/tr&gt; &lt;c:forEach var="deliveryBill" items="${page.pageList}"&gt; &lt;tr align="center" class="row_bg"&gt; &lt;td&gt;&lt;c:forEach var="t" items="${systemType.urgencyType}"&gt; &lt;c:if test="${deliveryBill[0].urgency == t.value}"&gt; &lt;c:if test="${t.label == '紧急'}"&gt; &lt;img src="${webPath}/images/dot_11.gif"&gt;&lt;/c:if&gt; &lt;c:if test="${t.label == '非常紧急'}"&gt; &lt;img src="${webPath}/images/dot_12.gif"&gt;&lt;/c:if&gt; &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;td&gt;${deliveryBill[0].orderCD}&lt;br&gt; &lt;c:forEach var="b" items="${systemType.billResouce}"&gt; &lt;c:if test="${deliveryBill[0].billResouce == b.value}"&gt; ${b.label} &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;td&gt;&lt;a href="#" onClick="viewDetailForQuery('${deliveryBill[0].id}','9')"&gt;${deliveryBill[0].deliveryCD}&lt;/a&gt;&lt;br&gt;${deliveryBill[0].entityCreateDate} ${fn:substring(deliveryBill[0].entityCreateTime, 0, 5)}&lt;/td&gt; &lt;td&gt; &lt;c:forEach var="memberType" items="${systemType.memberType}"&gt; &lt;c:if test="${memberType.value eq deliveryBill[0].memberLevel}"&gt; ${memberType.label} &lt;/c:if&gt; &lt;/c:forEach&gt;&lt;br&gt; &lt;c:choose&gt; &lt;c:when test="${deliveryBill[0].vipType eq '1'}"&gt; &lt;font class="redone"&gt;*&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '2'}"&gt; &lt;font class="redone"&gt;**&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '3'}"&gt; &lt;font class="redone"&gt;***&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '4'}"&gt; &lt;font class="redone"&gt;****&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '5'}"&gt; &lt;font class="redone"&gt;*****&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '6'}"&gt; &lt;font class="redone"&gt;******&lt;/font&gt; &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].vipType eq '7'}"&gt; &lt;!--img src="&lt;%=request.getContextPath()%&gt;/images/star7.gif"&gt;--&gt; &lt;/c:when&gt; &lt;/c:choose&gt; &lt;/td&gt; &lt;td&gt;${deliveryBill[2]}&lt;/td&gt; &lt;td&gt;&lt;c:forEach var="t" items="${systemType.deliveryType}"&gt; &lt;c:if test="${deliveryBill[0].deliveryType == t.value}"&gt; ${t.label} &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;br&gt; &lt;c:forEach var="t" items="${systemType.taskType}"&gt; &lt;c:if test="${deliveryBill[1] == t.value}"&gt;${t.label}&lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;td&gt;&lt;c:forEach var="deliveryCityID" items="${systemType.areaAddressList}"&gt; &lt;c:if test="${deliveryBill[0].deliveryCityID == deliveryCityID.code}"&gt; ${deliveryCityID.name} &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;br&gt;&lt;c:forEach var="areaItem" items="${systemType.areaAddressList}"&gt; &lt;c:if test="${areaItem.code eq deliveryBill[0].deliveryZoneID &amp;&amp; areaItem.type eq '4' &amp;&amp; areaItem.fatherCode eq deliveryBill[0].deliveryCityID}"&gt; ${areaItem.name} &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;td title="${deliveryBill[0].deliveryAddress}"&gt; ${fn:substring(deliveryBill[0].deliveryAddress, 0, 12)} &lt;/td&gt; &lt;td&gt;${deliveryBill[0].deliveryDate}&lt;br&gt; ${fn:substring(deliveryBill[0].dsBeginTime, 0, 5)}-${fn:substring(deliveryBill[0].dsEndTime, 0, 5)}&lt;/td&gt; &lt;td&gt;${deliveryBill[3]}&lt;br&gt;${deliveryBill[4]}&lt;/td&gt; &lt;td id="${deliveryBill[0].id}~${deliveryBill[1]}"&gt;&lt;c:choose&gt; &lt;c:when test="${deliveryBill[0].deliveryState == 8 || (deliveryBill[0].deliveryState == 0 &amp;&amp; deliveryBill[0].gatheringState == 8 )}"&gt; 已完成 &lt;/c:when&gt; &lt;c:when test="${deliveryBill[0].deliveryState == 13 || deliveryBill[0].gatheringState == 13}"&gt; 已取消 &lt;/c:when&gt; &lt;c:otherwise&gt; &lt;script type="text/javascript"&gt; getDiffTime('${deliveryBill[0].id}~${deliveryBill[1]}', '${deliveryBill[0].deliveryDate}', '${deliveryBill[0].dsBeginTime}'); &lt;/script&gt; &lt;/c:otherwise&gt; &lt;/c:choose&gt; &lt;/td&gt; &lt;td&gt;&lt;c:forEach var="ds" items="${systemType.deliveryState}"&gt; &lt;c:if test="${deliveryBill[0].deliveryState == ds.value}"&gt;${ds.label}&lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;td&gt;&lt;c:forEach var="ds" items="${systemType.deliveryState}"&gt; &lt;c:if test="${deliveryBill[0].gatheringState == ds.value}"&gt;${ds.label}&lt;/c:if&gt; &lt;/c:forEach&gt; &lt;/td&gt; &lt;/tr&gt; &lt;/c:forEach&gt; &lt;tr height="30"&gt; &lt;td colspan="15" align="right"&gt;&lt;c:set value="queryform" var="form_name" scope="request" /&gt; &lt;jsp:include page="/jsp/common/page2.jsp" /&gt; &lt;/td&gt; &lt;/tr&gt; &lt;/table&gt; &lt;/form&gt; &lt;%@ include file="/jsp/common/commontail.jsp"%&gt; &lt;/body&gt; &lt;script&gt; init(); &lt;/script&gt; &lt;/html&gt; &lt;script language="javascript"&gt; var liandong=new CLASS_LIANDONG_YAO(array) liandong.firstSelectChange("根目录","deliveryCenter","${params.centerCD}"); liandong.subSelectChange("deliveryCenter","deliveryUnit","${params.deliveryUnitCD}"); &lt;/script&gt; &lt;script type="text/javascript"&gt; var array=new Array(); &lt;c:set scope="page" var="problemTypeBigSize" value="0"/&gt; &lt;c:set scope="page" var="problemTypeSmallSize" value="0"/&gt; &lt;c:forEach var="billProblemBigType" items="${systemType.billProblemTypeList}" &gt; &lt;c:if test="${billProblemBigType.classlevel==1}" &gt; array[&lt;c:out value='${problemTypeBigSize}'/&gt;]=new Array(); array[&lt;c:out value='${problemTypeBigSize}'/&gt;][0]="&lt;c:out value='${billProblemBigType.code}'/&gt;"; array[&lt;c:out value='${problemTypeBigSize}'/&gt;][1]="根目录"; array[&lt;c:out value='${problemTypeBigSize}'/&gt;][2]="&lt;c:out value='${billProblemBigType.questionDepict}'/&gt;"; &lt;c:set scope="page" var="problemTypeBigSize" value="${problemTypeBigSize+1}"/&gt; &lt;/c:if&gt; &lt;/c:forEach&gt; &lt;c:forEach var="billProblemSmallType" items="${systemType.billProblemTypeList}" &gt; &lt;c:if test="${billProblemSmallType.classlevel==2}" &gt; array[&lt;c:out value='${problemTypeSmallSize+problemTypeBigSize}'/&gt;]=new Array(); array[&lt;c:out value='${problemTypeSmallSize+problemTypeBigSize}'/&gt;][0]="&lt;c:out value='${billProblemSmallType.code}'/&gt;"; array[&lt;c:out value='${problemTypeSmallSize+problemTypeBigSize}'/&gt;][1]="&lt;c:out value='${billProblemSmallType.problemType.code}'/&gt;"; array[&lt;c:out value='${problemTypeSmallSize+problemTypeBigSize}'/&gt;][2]="&lt;c:out value='${billProblemSmallType.questionDepict}'/&gt;"; &lt;c:set scope="page" var="problemTypeSmallSize" value="${problemTypeSmallSize+1}"/&gt; &lt;/c:if&gt; &lt;/c:forEach&gt; var liandong=new CLASS_LIANDONG_YAO(array) liandong.firstSelectChange("根目录","billProblemBigType","${params.questionBigCode}"); liandong.subSelectChange("billProblemBigType","billProblemSmallType","${params.questionSmallCode}"); &lt;/script&gt; </pre> <p> </p> <p>感激不尽</p> </div>
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
Python新型冠状病毒疫情数据自动爬取+统计+发送报告+数据屏幕(三)发送篇
今天介绍的项目是使用 Itchat 发送统计报告 项目功能设计: 定时爬取疫情数据存入Mysql 进行数据分析制作疫情报告 使用itchat给亲人朋友发送分析报告 基于Django做数据屏幕 使用Tableau做数据分析 来看看最终效果 目前已经完成,预计2月12日前更新 使用 itchat 发送数据统计报告 itchat 是一个基于 web微信的一个框架,但微信官方并不允许使用这...
相关热词 c# 压缩图片好麻烦 c#计算数组中的平均值 c#获取路由参数 c#日期精确到分钟 c#自定义异常必须继承 c#查表并返回值 c# 动态 表达式树 c# 监控方法耗时 c# listbox c#chart显示滚动条
立即提问