ear反编译
Ⅰ 关于EXE文件如何能看里边的内容
查看exe文件的内容是可以的。
1.首先得准备好(夸夸其词)的apk和obb的安装包。
Ⅱ eclipse中jar包多导致项目大,如何处理
1. 把 jar 创建成一个 java 的 User Library,放在本地磁盘的目录下。然后在项目中添加 Library > User Library 类型。这种方法缺点是 jar 文件没办法在项目组 共用。每人都得手工复制一个分。
2. 把 jar 项目创建成单独的 Simple project,不是 java 的,然后在你的项目上引用这个相对路径的 jar,在 java build path 中添加 jar 找到 workspace 里面的,就是相对路径,以后把这个项目提交到 CVS 上,这样大家共用的,也是相对路径,以后打包只有第一次 需要发送 jar 的项目一次,其他的发布只需要导出项目本身。
如果你的项目是个 EAR,那把第三方 jar 添加到服务器的扩展 jar 库目录中,比如 websphere 和 weblogic 是在命令行添加 -Dws.ext.dirs=jarFolder (不需要写 jar 名,只需要目录),也可以在 websphere 上创建 Shared Library,以后部署 ear 时选择启用这个 shared library 的引用即可。
但不推荐把 jar 都放到服务器的 lib 目录下,因为你影响所有的项目,这会导致当多个项目使用不同版本的库时出现错误,比如一个用 hibernate 2.0 另一个使用 Hibernate 3.0 就不能同时工作,而这个项目不是你开发的,你不能要求别人也修改代码。
Ⅲ 为什么要打jar包
1 单个项目的多个文件整合在一起便于管理
2 部署时不用一个文件一个文件上传,传一个ear或war即可
3 压缩作用,减小体积
4 jar中用manifest文件可以做一些依赖设置,main-class设置等等
5 jar包可以做混淆加密,防止反编译
6 jar还可封装成exe
Ⅳ 如何打ear包
如何打ear包
需要一个application.xml放在meta-inf目录下,代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE application PUBLIC '-//Sun Microsystems, Inc.//DTD J2EE Application 1.3//EN'
<application>
<display-name>SEMP</display-name>
<mole>
<web>
<web-uri>SEMPWeb</web-uri>
<context-root>SEMPWeb</context-root>
</web>
</mole>
</application>
把buid.xml放在根目录下
<?xml version="1.0" encoding="UTF-8" ?>
<project name="buildEar" default="ear" basedir=".">
<property name="src.dir" value="src" />
<property name="web.dir" value="SEMPWeb" />
<property name="ext.doc.dir" value="ext" />
<property name="ear.path" value="${ext.doc.dir}/SEMP.ear" />
<property name="lib.dir" value="${web.dir}/WEB-INF/lib" />
<property name="build.dir" value="${web.dir}/WEB-INF/classes" />
<property name="metadata.dir" value="META-INF" />
<!-- 定义编译期的classpath -->
<path id="master-classpath">
<!-- 包含${lib.dir} -->
<fileset dir="${lib.dir}">
<include name="**/*.jar" />
</fileset>
<!-- 包含 WEB-INF/classes -->
<pathelement path="${build.dir}" />
</path>
<!-- 生成EAR文件 weblogic-application.xml 文件的加入未实现 -->
<target name="ear" description="创建WEB发布包">
<ear destfile="${ear.path}" appxml="${metadata.dir}/application.xml">
<fileset dir=".">
<include name="${web.dir}/**/*" />
</fileset>
</ear>
</target>
<target name="jar">
<jar destfile="${lib.dir}\semp.jar" basedir="${build.dir}">
<include name="**/*.*" />
</jar>
</target>
</project>
当然经过证实,build.xml可以简化为:
<?xml version="1.0" encoding="UTF-8"?>
<project default="ear" basedir=".">
<property name="ear.path" value="ext/RXFW.ear"/>
<target name="ear">
<ear destfile="${ear.path}" appxml="WebRoot/META-INF/application.xml">
<fileset dir=".">
<include name="WebRoot/**/*" />
</fileset>
</ear>
</target>
</project>
Ⅳ java的源代码隐藏问题
你要的功能其实是Java代码混淆,如果要了解Java编译成exe,可以看“参考资料”。
下面一段文字摘自《Java 手机/PDA 程序设计入门》一书,可以做为混淆器性能的大致观点:
笔者没用过DashO,所以无法对其作出个人评价。所以现在仅说明笔者曾用过的产品。以笔者的个人观点,如果就混淆的程度来说,ZKM最好,JAX中等,RetroGuard和ProGuard最差,一分钱一分货,这是千古不变的道理。如果就功能性而言,ZKM和JAX都不错,不过,JAX是IBM所开发的产品,因此也继承了大部分IBM产品的最大特色,就是“功能超强,可是不易使用”,可能光是要看完JAX的设定文件就是一个很大的问题。
下面分别介绍几种具有代表性的混淆器,对它们的产品性能进行对比。我们使用不同混淆器对同一段java代码进行混淆,分别列出混淆后代码反编译的结果,并给出使用的一些直接体会。
原始java代码:
public class SimpleBean implements Serializable {
private String[] name = {"name0","name1","name2","name3"};
private List myList = null;
public void SimpleBean() {
myList = new ArrayList(4);
}
public void init_public() {
myList.add("name");
for(int i= 1; i < 4; i++){
init_private(i);
}
}
private void init_private(int j) {
myList.add(name[j]);
}
private void writeObject(java.io.ObjectOutputStream out)
throws IOException {
}
}
一、ProGuard 4.5.1
ProGuard是一款免费的Java类文件压缩器、优化器和混淆器。它能发现并删除无用类、字段(field)、方法和属性值(attribute)。它也能优化字节码并删除无用的指令。最后,它使用简单无意义的名字来重命名你的类名、字段名和方法名。经过以上操作的jar文件 会变得更小,并很难进行逆向工程。eclipse已经把Proguard集成在一起了。它支持脚本控制,可以使用GUI界面,字符串不加密,支持 J2ME。
类似功能的开源混淆器:
RetroGuard yGuard(RetroGuard的一个升级版本) JODE
Jad反编译混淆后class得到的代码:
public class SimpleBean
implements Serializable
{
public SimpleBean()
{
a_java_util_List_fld = null;
}
public void SimpleBean()
{
a_java_util_List_fld = new ArrayList(4);
}
public void init_public()
{
a_java_util_List_fld.add("name");
for(int i = 1; i < 4; i++)
{
int j = i;
SimpleBean simplebean = this;
a_java_util_List_fld.add(simplebean.a_java_lang_String_array1d_fld[j]);
}
}
private String a_java_lang_String_array1d_fld[] = {
"name0", "name1", "name2", "name3"
};
private List a_java_util_List_fld;
}
优点:
1、对内部private方法的调用进行了内联,但基本达不到混淆效果;
2、使用文档详尽,混淆选项配置文件的编写示例多;
3、混淆选项粒度较细,可以使用GUI界面,支持本地方法的保护等;
4、支持j2me,可以集成到Eclipse;
5、开源。
缺点:
1、符号混淆的命名具有提示性,字符串未加密,没有其它的混淆措施;
2、混淆主要针对Xlet、Midlet等应用,混淆库文件时配置文件将会很复杂。
二、Jocky
Jocky是金蝶中间件技术领袖袁红岗先生的个人作品(旧有名称JOC)。原本是方便Apusic 应用服务器的开发,现在开放出来,供大家自由使用。Jocky混淆编译器是在Sun JDK中提供的Java编译器(javac)的基础上完成的,修改了其中的代码生成过程,对编译器生成的中间代码进行混淆,最后再生成class文件,这样编译和混淆只需要一个步骤就可以完成。也就是说,它是直接从源码上做文章,这是Jocky与其它混淆编译器最大的不同之处。另外可以在源程序中插入符号保留指令来控制哪些符号需要保留,将混淆过程与开发过程融合在一起,不需要单独的混淆选项配置文件。Jocky的上述特点较适合于java类库的混淆。
Jad反编译混淆后class得到的代码:
public class SimpleBean
implements Serializable
{
public SimpleBean()
{
this;
String as[] = new String[4];
as;
as[0] = "name0";
as;
JVM INSTR swap ;
1;
"name1";
JVM INSTR aastore ;
JVM INSTR p ;
JVM INSTR swap ;
2;
"name2";
JVM INSTR aastore ;
JVM INSTR p ;
JVM INSTR swap ;
3;
"name3";
JVM INSTR aastore ;
_$2;
_$1 = null;
return;
}
public void SimpleBean()
{
this;
JVM INSTR new #9 <Class ArrayList>;
JVM INSTR p ;
JVM INSTR swap ;
4;
ArrayList();
_$1;
}
public void init_public()
{
_$1.add("name");
for(int i = 1; i < 4; i++)
_$1(i);
}
private void _$1(int i)
{
_$1.add(_$2[i]);
}
private void writeObject(ObjectOutputStream objectoutputstream)
throws IOException
{
}
private String _$2[];
private List _$1;
}
优点:
1、除符号混淆外增加了数据混淆(字符数组初始化);
2、有一些语句反编译只能得到字节码指令;
3、在Sun JDK中提供的Java编译器(javac)的基础上完成,编译和混淆一体完成,不需要先生成class文件再混淆;
4、提供了Eclipse的插件,能够直接在Eclipse中使用Jocky。
缺点:
1、混淆选项粒度较粗,使用中可能要在具体代码中添加@preserve指令来实现,工作量大;
2、没有控制流混淆。
三、Allatori 3.1_demo
Allatori属于第二代混淆器,具有全方位保护你的知识产权的能力。Allatori具有以下几种保护方式:命名混淆,流混淆,调试信息混淆,字符串编码,以及水印技术。对于教育和非商业项目来说这个混淆器是免费的。2.1版本支持war和ear文件格式,并且允许对需要混淆代码的应用程序添加有效日期。
Jad反编译混淆后class得到的代码:
public class SimpleBean
implements Serializable
{
public void init_public()
{
d.add(c.k("{u{0"));
int i = 1;
goto _L1
_L3:
H(i);
++i;
_L1:
4;
JVM INSTR icmplt 21;
goto _L2 _L3
_L2:
}
public void SimpleBean()
{
d = new ArrayList(4);
}
private void H(int a)
{
d.add(c[a]);
}
public SimpleBean()
{
d = null;
}
private void H(ObjectOutputStream objectoutputstream)
throws IOException
{
}
private String c[] = {
c.k("\177q\177te"), c.k("\177q\177td"), c.k("\177q\177tg"), c.k("\177q\177tf")
};
private List d;
}
注:c.k是为进行字符串加密额外生成的类c的静态方法。
优点:
1、设计考虑了库文件混淆的使用场景;
2、使用文档详尽,混淆选项配置文件的编写示例多;
3、除符号混淆外,还使用了两种高级的混淆手段:控制混淆(改写了for循环)和字符串加密(String数组初始化);
4、混淆选项粒度较细,支持本地方法的保护等;
5、支持水印技术,允许对需要混淆的代码添加有效日期;
6、支持j2me;
缺点:
1、商业软件(价格附后),对教育和非商业用途免费(网站链接是http://www.allatori.com/price.html)。
附:价格情况
SINGLE DEVELOPER LICENSE
1 license $290
2-5 licenses $260
6-10 licenses $230
11+ licenses $200
SITE LICENSE $3750
BUSINESS LICENSE $4850
ANNUAL SUPPORT UPDATE $45
四、Zelix KlassMaster(ZKM)
Zelix KlassMaster是一个来自Zelix Pty Ltd的商业混淆器。官方文档中关于它的混淆特性的介绍很少。它的保护功能非常强大,可以进行符号混淆和控制混淆,支持字符串的复杂加密保护,堆栈混乱,支持异常重构,支持增量混淆,支持J2ME。Zelix KlassMaster提供试用版本,可以到http://www.zelix.com下载。
五、DashO Pro
DashO Pro 是由Preemptive Solutions开发的商业化的混淆器. 免费的评估版可以到http://www.preemptive.com下载。DashO Pro代码保护能力强大易用,方便灵活(商业软件,非开源)。该Java混淆器是Sun的选择,对于企业级应用,作为其Java开发包的一部分,Sun微系统使用DashO Pro来混淆其加密库。DashO Pro能够对ID进行重新命名,使之成为毫无意义的字符;混淆元数据;改变控制流等,所有这些操作使得java代码被混淆,难于理解。产品特点包括:
领先的Java源码保护机制;
运用专利Overload-Inction技术对包/类/方法/域进行重命名;
高级的流程控制混淆机制;
字符串加密技术;
防止反编译器生成有用的输出;
水印软件;
提高Java源码效率;
不采用类/方法/域,全面移除常数存储库;
类/方法级别的优化,以提高JIT效果;
动态加载检测到的类;
全面高效的Java源码的拓展和部署;
支持所有的JDK版本 (JSE, J2EE, J2ME, etc)包括1.5;
自动堆栈跟踪转换;
在指定路径打包或者java jars;
支持任何打包类型的Java内容——程序、库、applets程序、小服务器程序、EJB等;支持基于J2ME CLDC的架构,包括MIDP和 iAppli;
支持CLDC预检验库中的类;
可以从指定路径、Zip压缩包或者jars中提取;
支持导出100%纯粹的Java,并提供验证;
命令行接口适合集成到构建环境内;
基于XML的配置文件,易于使用;
全面准确的PDF格式用户指南。
Ⅵ 在WebSphere7.0中安装Web应用时,出现下面的错误: 错误EAR 文件可能已损坏和/或不完整。确保应用程序处于
前段时间也遇到过这个问题,后来发现是当前项目选的jdk版本与当前编译项目的jdk版本不一致造成的。请检查项目所选的编译等级与rad中编译所选择的jdk版本是否一致。
Ⅶ EAR文件可能已损坏和/或不完整.WebSphere(R) Application Server 当前版本的兼容 Java(TM)Platform
看起来像是 unix 环境的WAS 和 Windows 环境的 WAS 版本不一样,检查下喽
Ⅷ Eclipse多项目引用和调试问题
完全可以跟踪进去的。
你可能同时在项目A的build path/libraries或者web-inf/lib中放了项目B的jar包,因此eclipse会去找这个jar包的源代码,而不是找项目B了。
如果完全用eclipse开发的话,不需要将B导出为jar包后放到A的build path/libraries或web-inf/lib中的。
而是应该在build path/projects中直接加入项目B,同时在Java EE Mole Dependencies中勾选项目B即可。
这种方式,在最后导出war/ear时,eclipse也会将项目B打包一起放入的。