仓酷云
标题:
JAVA网站制作之水晶报表的jsp完成(开辟工具:bea weblo...
[打印本页]
作者:
冷月葬花魂
时间:
2015-1-18 11:32
标题:
JAVA网站制作之水晶报表的jsp完成(开辟工具:bea weblo...
从一个编程语言的普及程度来将,一个好的IDE是至关中要的,而现在的java的IDE虽然已经很好了,但是和.net比起来还是稍微差一些的,这是个客观事实。java要想普及的更好。DE是必须加以改进的。js|web|水晶报表比来为客户开辟一个mis体系,java手艺,b/s布局.客户请求体系的报表接纳水晶报表.
如何在jsp中完成水晶报表呢?找遍了一切的材料,水晶报表的web完成却是良多,但都讲的是微软的.net计划.jsp中怎样完成水晶报表的静态显现呢?
经由一段工夫的疾苦探索,如今把我的计划先容给人人,但愿列位年老品评斧正
我的成绩:
必要静态的显现水晶报表,而且要依据我传送的一个参数(BH)的值静态的显现数据.而且要能够把水晶报表导出为word,excel,pdf等格局
我的办理计划:
一:下载crystalreports10forBEAweblogicworkshop
二:安装crystalreports10forBEAweblogicworkshop;
三:假如安装乐成,则在C:ProgramFilesCommonFilesCrystalDecisions2.5in目次下,能够找到CRDB_JavaServer.ini文件.该文件很主要,内里的内容
干系到水晶报表怎样会见数据库.我的水晶报表接纳jdbc的体例会见oracle数据库,设置以下:
[Common]
PATH=C:eajdk141_05in
CLASSPATH=C:ProjectsDriversjdbcclasses12.jar;
C:ProjectsDriversjdbcmsbase.jar;
C:ProjectsDriversjdbcmssqlserver.jar;
C:ProjectsDriversjdbcmsutil.jar;
C:ProjectsDriversjdbccommon.jar;
C:ProjectsDriversjdbcdb2fs.jar;
C:ProjectsDriversjdbcdb2java.zip;
C:ProjectsDriversjdbcdb2jcc.jar;
C:ProjectsDriversjdbcweblogic.jar;
D:/Progra~1/IBM/WebSph~1/Applic~1v5.1.1untimesase_v51lib
aming.jar;
D:/Progra~1/IBM/WebSph~1/Applic~1v5.1.1untimesase_v51lib
amingclient.jar;
D:/Progra~1/IBM/WebSph~1/Applic~1v5.1.1untimesase_v51lib
amingserver.jar;
D:/Progra~1/IBM/WebSph~1/Applic~1v5.1.1untimesase_v51libcmImpl.jar;
D:/Progra~1/IBM/WebSph~1/Applic~1v5.1.1untimesase_v51libj2cImpl.jar;
C:/projects/drivers/jdbc/weblogic.jar;
C:ProgramFilesCommonFilesCrystalDecisions2.5inCRDBJavaServer.jar;
C:eaweblogic81serverlibojdbc14.jar
IORFileLocation=${TEMP}
JavaServerTimeout=1800
JVMMaxHeap=64000000
JVMMinHeap=32000000
[CRDB_JDBC]
CacheRowSetSize=100
JDBCURL=jdbc:oracle:thin:@192.168.1.99:1521:pwsc
JNDIURL=
JDBCUserName=testuser
JDBCDriverName=oracle.jdbc.driver.OracleDriver
JNDIUserName=weblogic
JNDIConnectionFactory=
JNDIInitContext=/
GenericJDBCDriverBehavior=DB2
[CRDB_XML]
PREREADNBYTE=5000
CacheRowSetSize=100
XMLLOCALURL=
SCHEMALOCALURL=
XMLHTTPURL=
SCHEMAHTTPURL=
USETEMPFile=TRUE
以上是设置文件,必要申明的是:
1:因为我接纳的是jdbc的体例会见数据库,以是CLASSPATH中必定要把C:eaweblogic81serverlibojdbc14.jar加出来,它是jdbc的驱动
2:[CRDB_JDBC]中的:JDBCURL=jdbc:oracle:thin:@192.168.1.99:1521:pwsc是我要会见的数据库称号.JDBCUserName=testuser是设置用户名,
JDBCDriverName=oracle.jdbc.driver.OracleDriver是jdbc驱动称号
四:在水晶报表编纂器中编纂我要用的报表.因为我必要静态的给报表传送参数,以是我在报表中设置了一个参数字段,水晶报表依据这个参数字段,就能够显现响应的
数据,参数字段定名为BH,在公式编纂器中编写以下代码:
IF{?BH}""THEN
{GG_BPBJ.JLBH}={?BH}
ELSE
{GG_BPBJ.JLBH}="1"OR{GG_BPBJ.JLBH}"1"
以上代码的意义是:假如bh参数不为空,则显现{GG_BPBJ.JLBH}即是参数BH的纪录,不然显现出一切的纪录
(人人大概以为{GG_BPBJ.JLBH}="1"OR{GG_BPBJ.JLBH}"1"很好笑,是啊,我入手下手是写成"true"了,在水晶报表编纂器中能够很好的运转,但方到web上显现就有
成绩,万般无法,只要云云了,:()
五:在weblogicworkshop中新建一个web项目,用右键选择该项目文件夹,选择"新建",选择"crystalreport",则在该web项目根目次下主动新建了一个
crystalreportviewers10目次,内里有显现水晶报表必要的页面元素体系主动增加了开辟水晶报表必要的jar包,共有13个jar文件(位于WEB_INFLIB目次下),
并增添了一些水晶报表公用的标签(在WEB_INFSRC下)
六:必要出格注重的是:在WEB_INF下的web.xml文件也随之修改,修改后的web.xml文件以下:
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPEweb-appPUBLIC"-//SunMicrosystems,Inc.//DTDWebApplication2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd">
<!--Theweb.xmlfileisaconfigurationfileusedtocontrolthebehaviorofWebLogicserver.
Inmostcases,youwillnotneedtomodifythisfile.Formoreinformationonweb.xml,please
consulttheWeb.xmlDeploymentDescriptorElementschapterofthe"DevelopingWebLogicServer
Applications"documentationonedocs.bea.com.-->
<web-app>
<display-name>WorkshopApplication</display-name>
<context-param>
<param-name>weblogic.httpd.inputCharset./*</param-name>
<param-value>GBK</param-value>
</context-param>
<context-param>
<param-name>crystal_image_uri</param-name>
<param-value>/webmis/crystalreportviewers10</param-value>
</context-param>
<filter>
<filter-name>PageFlowJspFilter</filter-name>
<filter-class>com.bea.wlw.netui.pageflow.PageFlowJspFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>PageFlowJspFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<listener>
<listener-class>com.bea.wlw.runtime.core.servlet.WebappContextListener</listener-class>
</listener>
<!--StandardActionServletConfiguration(withdebugging)-->
<servlet>
<servlet-name>messageServlet</servlet-name>
<servlet-class>com.infoearth.servlets.getTaskServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>action</servlet-name>
<servlet-class>com.bea.wlw.netui.pageflow.DynamicSubappActionServlet</servlet-class>
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/jpf-struts-config.xml</param-value>
</init-param>
<init-param>
<param-name>config/-global</param-name>
<param-value>/WEB-INF/jpf-struts-config--global.xml</param-value>
</init-param>
<init-param>
<param-name>debug</param-name>
<param-value>2</param-value>
</init-param>
<init-param>
<param-name>detail</param-name>
<param-value>2</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet>
<servlet-name>drawImage</servlet-name>
<servlet-class>com.infoearth.drawimage.DrawImageServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>drawImage</servlet-name>
<url-pattern>drawImage</url-pattern>
</servlet-mapping>
<!--StrutsActionServletMappings-->
<!--NotethatbecauseStrutstakesthe*last*mappinghereastheextensiontoaddto
actionspostedfromforms,wemusthave*.docomeafter*.jpf.-->
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.jpf</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>messageServlet</servlet-name>
<url-pattern>/messageServlet</url-pattern>
</servlet-mapping>
<mime-mapping>
<extension>doc</extension>
<mime-type>application/msword</mime-type>
</mime-mapping>
<mime-mapping>
<extension>xls</extension>
<mime-type>application/msexcel</mime-type>
</mime-mapping>
<welcome-file-list>
<welcome-file>Login/loginController.jpf</welcome-file>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<error-page>
<error-code>500</error-code>
<location>/error.jsp</location>
</error-page>
<!--DefinetheNetUItaglibraryTLDs-->
<taglib>
<taglib-uri>netui-tags-html.tld</taglib-uri>
<taglib-location>/WEB-INF/netui-tags-html.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>netui-tags-databinding.tld</taglib-uri>
<taglib-location>/WEB-INF/netui-tags-databinding.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>netui-tags-template.tld</taglib-uri>
<taglib-location>/WEB-INF/netui-tags-template.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>/crystal-tags-reportviewer.tld</taglib-uri>
<taglib-location>/WEB-INF/crystal-tags-reportviewer.tld</taglib-location>
</taglib>
</web-app>
个中:
<context-param>
<param-name>crystal_image_uri</param-name>
<param-value>/webmis/crystalreportviewers10</param-value>
</context-param>
很关头,它设置了水晶报表公用的crystalreportviewers10路径(第五步中主动建的crystalreportviewers10目次),假如设置毛病,未来点击水晶报表自带的
导出和打印按钮是就会报页面毛病,而且水晶报表本人的各类翻页,导出等图标也没法一般显现.
七:把编纂好的水晶报表(后缀命为rpt)放在一个目次下(我本人建了一个report目次,专门寄存报表文件)
八:能够写程序了:
1.编写ReportInit类.感化:用于传送参数BH.这个类很关头,卖力把java的参数值传送到水晶报表文件.
2.在页面流中增添showRpt操纵:实在就是实例化一个ReportInit类.
3.编写viewer.jsp文件用来静态显现水晶报表.
前面有我的源代码,请人人品评斧正.
存在的成绩:
1:水晶报表导出成pdf文件时有成绩:汉字显现为乱码,不知何以?此成绩困扰我几个月了,没法办理
2:没法把打印/导出页面汉化:在crystalreportviewers10js目次下有一系列strings定名的js文件,我推测是用来国际化页面的,但是我修正
strings_zh,js,strings_en.js,没有甚么效果.
3:在扫瞄器中显现水晶报表后,封闭显现页面,该水晶报表仍然和数据库毗连,(可由select*fromv$session检察oracle的毗连数).假如在
viewer.jsp中到场断开毗连的语句:
viewer.dispose();
rptSource.dispose();
则只能显现一页报表.而且打印和导出不克不及事情.
以上成绩困扰我好久,固然其实不影响利用,但心中仍是不是很爽.但愿妙手指导.
源程序:
/*
*CreateDate:2004-8-1411:06
*CreateBy:李春雷
*purpose:设置水晶报表的查询参数(今朝撑持7个参数的查询,有效的参数为编号)
*/
packagecom.infoearth.report;
importcom.crystaldecisions.report.web.viewer.*;
importcom.crystaldecisions.sdk.occa.report.data.*;
importcom.crystaldecisions.reports.reportengineinterface.JPEReportSourceFactory;
importcom.crystaldecisions.sdk.occa.report.reportsource.IReportSourceFactory2;
importcom.crystaldecisions.sdk.occa.report.reportsource.IReportSource;
publicclassReportInit
{
privateIReportSourcerptSource;
privateFieldsfields;
publicReportInit(){
rptSource=null;
fields=null;
}
publicIReportSourcegetRptsource(){
returnrptSource;
}
publicFieldsgetFields(){
returnfields;
}
publicbooleansetReport(Stringfname,StringrptID){
//取得查询前提
StringFileName=fname+".rpt";
StringBH=rptID;
Stringpath="report/"+FileName;//报表文件路径
try{
IReportSourceFactory2rsf=newJPEReportSourceFactory();
java.util.Localelocaletest=java.util.Locale.CHINA;
rptSource=(IReportSource)rsf.createReportSource(path,localetest);
fields=newFields();
ParameterFieldpfield1=newParameterField();//编号
ParameterFieldpfield2=newParameterField();//单元
ParameterFieldpfield3=newParameterField();//人
ParameterFieldpfield5=newParameterField();//FIELD5
ParameterFieldpfield6=newParameterField();//FIELD6
ParameterFieldpfield4_KSSJ=newParameterField();//入手下手工夫
ParameterFieldpfield4_JSSJ=newParameterField();//停止工夫
Valuesvals1=newValues();
Valuesvals2=newValues();
Valuesvals3=newValues();
Valuesvals5=newValues();
Valuesvals6=newValues();
Valuesvals4_KSSJ=newValues();
Valuesvals4_JSSJ=newValues();
ParameterFieldDiscreteValuepfieldDV1=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV2=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV3=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV5=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV6=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV4_KSSJ=newParameterFieldDiscreteValue();
ParameterFieldDiscreteValuepfieldDV4_JSSJ=newParameterFieldDiscreteValue();
//设置第一个参数:编号
pfield1.setReportName("");
pfield1.setName("BH");
pfieldDV1.setValue(BH);
pfieldDV1.setDescription("编号");
vals1.add(pfieldDV1);
pfield1.setCurrentValues(vals1);
//设置第二个参数:单元部门
pfield2.setReportName("");
pfield2.setName("DW");
pfieldDV2.setValue("");
pfieldDV2.setDescription("发单部门");
vals2.add(pfieldDV2);
pfield2.setCurrentValues(vals2);
//设置第三个参数:人
pfield3.setReportName("");
pfield3.setName("REN");
pfieldDV3.setValue("");
pfieldDV3.setDescription("请求人、下达人、操纵人、卖力人等");
vals3.add(pfieldDV3);
pfield3.setCurrentValues(vals3);
//设置第五个查询字段
pfield5.setReportName("");
pfield5.setName("FIELD5");
pfieldDV5.setValue("");
pfieldDV5.setDescription("查询字段5:义务来历线路称号等");
vals5.add(pfieldDV5);
pfield5.setCurrentValues(vals5);
//设置第六个查询字段
pfield6.setReportName("");
pfield6.setName("FIELD6");
pfieldDV6.setValue("");
pfieldDV6.setDescription("查询字段6:变动缘故原由、事情内容等");
vals6.add(pfieldDV6);
pfield6.setCurrentValues(vals6);
//设置入手下手工夫
pfield4_KSSJ.setReportName("");
pfield4_KSSJ.setName("KSSJ");
pfieldDV4_KSSJ.setValue("");
pfieldDV4_KSSJ.setDescription("入手下手工夫");
vals4_KSSJ.add(pfieldDV4_KSSJ);
pfield4_KSSJ.setCurrentValues(vals4_KSSJ);
//设置停止工夫
pfield4_JSSJ.setReportName("");
pfield4_JSSJ.setName("JSSJ");
pfieldDV4_JSSJ.setValue("");
pfieldDV4_JSSJ.setDescription("停止工夫");
vals4_JSSJ.add(pfieldDV4_JSSJ);
pfield4_JSSJ.setCurrentValues(vals4_JSSJ);
//参数字段和报表联系关系
fields.add(pfield1);
fields.add(pfield2);
fields.add(pfield3);
fields.add(pfield5);
fields.add(pfield6);
fields.add(pfield4_KSSJ);
fields.add(pfield4_JSSJ);
returntrue;
}
catch(Exceptione){
System.out.println("Class:ReportInit毛病:"+e);
returnfalse;
}
}
}
//在页面流中增添以下操纵:
/**
*@jpf:action
*@jpf:forwardname="false"path="error.jsp"
*@jpf:forwardname="success"path="viewer.jsp"
*/
protectedForwardshowRpt()
{
Stringrptid=this.getRequest().getParameter("rptID");
StringrptBH=this.getRequest().getParameter("rptBH");
StringrptName=dbCtrl.getRptCNName(rptid);
if((rptName!=null)&&(rptBH!=null)){
ReportInitrpt=newReportInit();
booleanresult=rpt.setReport(rptName,rptBH);
if(result==true){
Fieldsfields=rpt.getFields();
IReportSourcerptSource=rpt.getRptsource();
this.getSession().setAttribute("fields",fields);
this.getSession().setAttribute("rptSource",rptSource);
returnnewForward("success");
}else{
returnnewForward("false");
}
}
returnnewForward("false");
}
//viewer.jsp用来静态显现水晶报表.viewer.jsp的内容以下:
<%@pagelanguage="java"contentType="text/html;charset=utf-8"%>
<%@pageimport="com.crystaldecisions.report.web.viewer.*,
com.crystaldecisions.sdk.occa.report.data.*,
com.crystaldecisions.reports.reportengineinterface.JPEReportSourceFactory,
com.crystaldecisions.sdk.occa.report.reportsource.IReportSourceFactory2,
com.crystaldecisions.sdk.occa.report.reportsource.IReportSource"%>
<%@tagliburi="netui-tags-html.tld"prefix="netui"%>
<%
//fieldsrptSource
//Stringname=(String)request.getAttribute("nametest");
//System.out.println("name="+name);
%>
<!--../crystalreportviewers10/css/default.css-->
<LINKrel="stylesheet"type="text/css"href="../crystalreportviewers10/css/default.css">
<%
IReportSourcerptSource=(IReportSource)session.getAttribute("rptSource");
Fieldsfields=(Fields)session.getAttribute("fields");
ConnectionInfosconnInfos=newConnectionInfos();
IConnectionInfoconnInfo1=newConnectionInfo();
connInfo1.setUserName("testuser");
connInfo1.setPassword("test");
connInfos.add(connInfo1);
CrystalReportViewerviewer=newCrystalReportViewer();
viewer.setReportSource(rptSource);
viewer.setDatabaseLogonInfos(connInfos);
viewer.setParameterFields(fields);
viewer.setEnableParameterPrompt(true);
viewer.setOwnPage(true);
viewer.setOwnForm(true);
viewer.setPrintMode(CrPrintMode.ACTIVEX);
viewer.setHasExportButton(true);
viewer.setHasPrintButton(true);
viewer.setHasLogo(false);
viewer.processHttpRequest(request,response,getServletConfig().getServletContext(),out);
viewer.refresh();
//viewer.dispose();
//rptSource.dispose();
%>
为什么外国人还要写那些框架进行代码封装,他们不就是为了别人使用时可以更简单么!如果要达到一个企业级项目的不用框架是很难的。小一些的项目还行,大的光是MVC模式的设计的编码量就够大的了。还有性能方面,单轮windows,这个工具是微软写的,。
作者:
海妖
时间:
2015-1-21 09:38
其实说这种话的人就如当年小日本号称“三个月拿下中国”一样大言不惭。不是Tomjava泼你冷水,你现在只是学到了Java的骨架,却还没有学到Java的精髓。接下来你得研究设计模式了。
作者:
小女巫
时间:
2015-1-22 06:36
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
作者:
活着的死人
时间:
2015-1-26 20:30
是一种由美国SUN计算机公司(Sun Microsystems, Inc.)所研究而成的语言
作者:
灵魂腐蚀
时间:
2015-2-3 12:40
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
作者:
山那边是海
时间:
2015-2-6 01:26
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
作者:
简单生活
时间:
2015-2-12 23:50
一直感觉JAVA很大,很杂,找不到学习方向,前两天在网上找到了这篇文章,感觉不错,给没有方向的我指了一个方向,先不管对不对,做下来再说。
作者:
金色的骷髅
时间:
2015-3-3 11:17
Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。
作者:
莫相离
时间:
2015-3-11 02:32
关于设计模式的资料,还是向大家推荐banq的网站 [url]http://www.jdon.com/[/url],他把GOF的23种模式以通俗易懂的方式诠释出来,纯Java描述,真是经典中的经典。
作者:
精灵巫婆
时间:
2015-3-11 11:28
是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能
作者:
小魔女
时间:
2015-3-17 17:08
Java是一种计算机编程语言,拥有跨平台、面向对java
作者:
第二个灵魂
时间:
2015-3-22 01:09
科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
作者:
分手快乐
时间:
2015-3-23 17:33
那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧!
作者:
柔情似水
时间:
2015-3-28 07:00
应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展
作者:
谁可相欹
时间:
2015-4-6 16:29
所以现在应用最广泛又最好学的就是J2EE了。 J2EE又包括许多组件,如Jsp,Servlet,JavaBean,EJB,JDBC,JavaMail等。要学习起来可不是一两天的事。那么又该如何学习J2EE呢?当然Java语法得先看一看的,I/O包,Util包,Lang包你都熟悉了吗?然后再从JSP学起。
作者:
不帅
时间:
2015-4-8 11:04
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
作者:
透明
时间:
2015-4-11 17:48
其实说这种话的人就如当年小日本号称“三个月拿下中国”一样大言不惭。不是Tomjava泼你冷水,你现在只是学到了Java的骨架,却还没有学到Java的精髓。接下来你得研究设计模式了。
作者:
再现理想
时间:
2015-4-12 17:50
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
作者:
深爱那片海
时间:
2015-4-18 09:07
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
欢迎光临 仓酷云 (http://ckuyun.com/)
Powered by Discuz! X3.2