java下载文件到本地指定目录?java根据文件路径下载文件
大家好,感谢邀请,今天来为大家分享一下java下载文件到本地指定目录的问题,以及和java根据文件路径下载文件的一些困惑,大家要是还不太明白的话,也没有关系,因为接下来将为大家分享,希望可以帮助到大家,解决大家的问题,下面就开始吧!
怎么用Java实现FTP上传
sun.net.ftp.FtpClient.,该类库主要提供了用于建立FTP连接的类。利用这些类的方法,编程人员可以远程登录到FTP服务器,列举该服务器上的目录,设置传输协议,以及传送文件。FtpClient类涵盖了几乎所有FTP的功能,FtpClient的实例变量保存了有关建立"代理"的各种信息。下面给出了这些实例变量:
public static boolean useFtpProxy
这个变量用于表明FTP传输过程中是否使用了一个代理,因此,它实际上是一个标记,此标记若为TRUE,表明使用了一个代理主机。
public static String ftpProxyHost
此变量只有在变量useFtpProxy为TRUE时才有效,用于保存代理主机名。
public static int ftpProxyPort此变量只有在变量useFtpProxy为TRUE时才有效,用于保存代理主机的端口地址。
FtpClient有三种不同形式的构造函数,如下所示:
1、public FtpClient(String hostname,int port)
此构造函数利用给出的主机名和端口号建立一条FTP连接。
2、public FtpClient(String hostname)
此构造函数利用给出的主机名建立一条FTP连接,使用默认端口号。
3、FtpClient()
此构造函数将创建一FtpClient类,但不建立FTP连接。这时,FTP连接可以用openServer方法建立。
一旦建立了类FtpClient,就可以用这个类的方法来打开与FTP服务器的连接。类ftpClient提供了如下两个可用于打开与FTP服务器之间的连接的方法。
public void openServer(String hostname)
这个方法用于建立一条与指定主机上的FTP服务器的连接,使用默认端口号。
public void openServer(String host,int port)
这个方法用于建立一条与指定主机、指定端口上的FTP服务器的连接。
打开连接之后,接下来的工作是注册到FTP服务器。这时需要利用下面的方法。
public void login(String username,String password)
此方法利用参数username和password登录到FTP服务器。使用过Intemet的用户应该知道,匿名FTP服务器的登录用户名为anonymous,密码一般用自己的电子邮件地址。
下面是FtpClient类所提供的一些控制命令。
public void cd(String remoteDirectory):该命令用于把远程系统上的目录切换到参数remoteDirectory所指定的目录。
public void cdUp():该命令用于把远程系统上的目录切换到上一级目录。
public String pwd():该命令可显示远程系统上的目录状态。
public void binary():该命令可把传输格式设置为二进制格式。
public void ascii():该命令可把传输协议设置为ASCII码格式。
public void rename(String string,String string1):该命令可对远程系统上的目录或者文件进行重命名操作。
除了上述方法外,类FtpClient还提供了可用于传递并检索目录清单和文件的若干方法。这些方法返回的是可供读或写的输入、输出流。下面是其中一些主要的方法。
public TelnetInputStream list()
返回与远程机器上当前目录相对应的输入流。
public TelnetInputStream get(String filename)
获取远程机器上的文件filename,借助TelnetInputStream把该文件传送到本地。
public TelnetOutputStream put(String filename)
以写方式打开一输出流,通过这一输出流把文件filename传送到远程计算机
package myUtil;
import java.io.DataInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;
import sun.net.TelnetInputStream;
import sun.net.TelnetOutputStream;
import sun.net.ftp.FtpClient;
/**
* ftp上传,下载
*
*@author why 2009-07-30
*
*/
public class FtpUtil{
private String ip="";
private String username="";
private String password="";
private int port=-1;
private String path="";
FtpClient ftpClient= null;
OutputStream os= null;
FileInputStream is= null;
public FtpUtil(String serverIP, String username, String password){
this.ip= serverIP;
this.username= username;
this.password= password;
}
public FtpUtil(String serverIP, int port, String username, String password){
this.ip= serverIP;
this.username= username;
this.password= password;
this.port= port;
}
/**
*连接ftp服务器
*
*@throws IOException
*/
public boolean connectServer(){
ftpClient= new FtpClient();
try{
if(this.port!=-1){
ftpClient.openServer(this.ip, this.port);
} else{
ftpClient.openServer(this.ip);
}
ftpClient.login(this.username, this.password);
if(this.path.length()!= 0){
ftpClient.cd(this.path);// path是ftp服务下主目录的子目录
}
ftpClient.binary();//用2进制上传、下载
System.out.println("已登录到\""+ ftpClient.pwd()+"\"目录");
return true;
} catch(IOException e){
e.printStackTrace();
return false;
}
}
/**
*断开与ftp服务器连接
*
*@throws IOException
*/
public boolean closeServer(){
try{
if(is!= null){
is.close();
}
if(os!= null){
os.close();
}
if(ftpClient!= null){
ftpClient.closeServer();
}
System.out.println("已从服务器断开");
return true;
} catch(IOException e){
e.printStackTrace();
return false;
}
}
/**
*检查文件夹在当前目录下是否存在
*
*@param dir
*@return
*/
private boolean isDirExist(String dir){
String pwd="";
try{
pwd= ftpClient.pwd();
ftpClient.cd(dir);
ftpClient.cd(pwd);
} catch(Exception e){
return false;
}
return true;
}
/**
*在当前目录下创建文件夹
*
*@param dir
*@return
*@throws Exception
*/
private boolean createDir(String dir){
try{
ftpClient.ascii();
StringTokenizer s= new StringTokenizer(dir,"/");// sign
s.countTokens();
String pathName= ftpClient.pwd();
while(s.hasMoreElements()){
pathName= pathName+"/"+(String) s.nextElement();
try{
ftpClient.sendServer("MKD"+ pathName+"\r\n");
} catch(Exception e){
e= null;
return false;
}
ftpClient.readServerResponse();
}
ftpClient.binary();
return true;
} catch(IOException e1){
e1.printStackTrace();
return false;
}
}
/**
* ftp上传如果服务器段已存在名为filename的文件夹,该文件夹中与要上传的文件夹中同名的文件将被替换
*
*@param filename
*要上传的文件(或文件夹)名
*@return
*@throws Exception
*/
public boolean upload(String filename){
String newname="";
if(filename.indexOf("/")>-1){
newname= filename.substring(filename.lastIndexOf("/")+ 1);
} else{
newname= filename;
}
return upload(filename, newname);
}
/**
* ftp上传如果服务器段已存在名为newName的文件夹,该文件夹中与要上传的文件夹中同名的文件将被替换
*
*@param fileName
*要上传的文件(或文件夹)名
*@param newName
*服务器段要生成的文件(或文件夹)名
*@return
*/
public boolean upload(String fileName, String newName){
try{
String savefilename= new String(fileName.getBytes("GBK"),
"GBK");
File file_in= new File(savefilename);//打开本地待长传的文件
if(!file_in.exists()){
throw new Exception("此文件或文件夹["+ file_in.getName()+"]有误或不存在!");
}
if(file_in.isDirectory()){
upload(file_in.getPath(), newName, ftpClient.pwd());
} else{
uploadFile(file_in.getPath(), newName);
}
if(is!= null){
is.close();
}
if(os!= null){
os.close();
}
return true;
} catch(Exception e){
e.printStackTrace();
System.err.println("Exception e in Ftp upload():"+ e.toString());
return false;
} finally{
try{
if(is!= null){
is.close();
}
if(os!= null){
os.close();
}
} catch(IOException e){
e.printStackTrace();
}
}
}
/**
*真正用于上传的方法
*
*@param fileName
*@param newName
*@param path
*@throws Exception
*/
private void upload(String fileName, String newName, String path)
throws Exception{
String savefilename= new String(fileName.getBytes("ISO-8859-1"),"GBK");
File file_in= new File(savefilename);//打开本地待长传的文件
if(!file_in.exists()){
throw new Exception("此文件或文件夹["+ file_in.getName()+"]有误或不存在!");
}
if(file_in.isDirectory()){
if(!isDirExist(newName)){
createDir(newName);
}
ftpClient.cd(newName);
File sourceFile[]= file_in.listFiles();
for(int i= 0; i< sourceFile.length; i++){
if(!sourceFile[i].exists()){
continue;
}
if(sourceFile[i].isDirectory()){
this.upload(sourceFile[i].getPath(), sourceFile[i]
.getName(), path+"/"+ newName);
} else{
this.uploadFile(sourceFile[i].getPath(), sourceFile[i]
.getName());
}
}
} else{
uploadFile(file_in.getPath(), newName);
}
ftpClient.cd(path);
}
/**
* upload上传文件
*
*@param filename
*要上传的文件名
*@param newname
*上传后的新文件名
*@return-1文件不存在>=0成功上传,返回文件的大小
*@throws Exception
*/
public long uploadFile(String filename, String newname) throws Exception{
long result= 0;
TelnetOutputStream os= null;
FileInputStream is= null;
try{
java.io.File file_in= new java.io.File(filename);
if(!file_in.exists())
return-1;
os= ftpClient.put(newname);
result= file_in.length();
is= new FileInputStream(file_in);
byte[] bytes= new byte[1024];
int c;
while((c= is.read(bytes))!=-1){
os.write(bytes, 0, c);
}
} finally{
if(is!= null){
is.close();
}
if(os!= null){
os.close();
}
}
return result;
}
/**
*从ftp下载文件到本地
*
*@param filename
*服务器上的文件名
*@param newfilename
*本地生成的文件名
*@return
*@throws Exception
*/
public long downloadFile(String filename, String newfilename){
long result= 0;
TelnetInputStream is= null;
FileOutputStream os= null;
try{
is= ftpClient.get(filename);
java.io.File outfile= new java.io.File(newfilename);
os= new FileOutputStream(outfile);
byte[] bytes= new byte[1024];
int c;
while((c= is.read(bytes))!=-1){
os.write(bytes, 0, c);
result= result+ c;
}
} catch(IOException e){
e.printStackTrace();
} finally{
try{
if(is!= null){
is.close();
}
if(os!= null){
os.close();
}
} catch(IOException e){
e.printStackTrace();
}
}
return result;
}
/**
*取得相对于当前连接目录的某个目录下所有文件列表
*
*@param path
*@return
*/
public List getFileList(String path){
List list= new ArrayList();
DataInputStream dis;
try{
dis= new DataInputStream(ftpClient.nameList(this.path+ path));
String filename="";
while((filename= dis.readLine())!= null){
list.add(filename);
}
} catch(IOException e){
e.printStackTrace();
}
return list;
}
public static void main(String[] args){
FtpUtil ftp= new FtpUtil("192.168.11.11","111","1111");
ftp.connectServer();
boolean result= ftp.upload("C:/Documents and Settings/ipanel/桌面/java/Hibernate_HQL.docx","amuse/audioTest/music/Hibernate_HQL.docx");
System.out.println(result?"上传成功!":"上传失败!");
ftp.closeServer();
/**
* FTP远程命令列表 USER PORT RETR ALLO DELE SITE XMKD CDUP FEAT PASS PASV STOR
* REST CWD STAT RMD XCUP OPTS ACCT TYPE APPE RNFR XCWD HELP XRMD STOU
* AUTH REIN STRU SMNT RNTO LIST NOOP PWD SIZE PBSZ QUIT MODE SYST ABOR
* NLST MKD XPWD MDTM PROT
*在服务器上执行命令,如果用sendServer来执行远程命令(不能执行本地FTP命令)的话,所有FTP命令都要加上\r\n
* ftpclient.sendServer("XMKD/test/bb\r\n");//执行服务器上的FTP命令
* ftpclient.readServerResponse一定要在sendServer后调用
* nameList("/test")获取指目录下的文件列表 XMKD建立目录,当目录存在的情况下再次创建目录时报错 XRMD删除目录
* DELE删除文件
*/
}
}
想要java软件安装包,有哪位朋友有吗
软件介绍
java se development kit 9 64位,简称为java9 64位,是由oracle公司官方推出的一款Java语言的软件开发工具包,面向Java开发人员,包括一个完整的JRE以及用于开发、调试和监视Java应用的工具,是整个Java的核心,其中包括了Java运行环境(Java Runtime EnvirnmeJava开发工具和Java基础类库源代码)。java se 9是Java Platform的新更新,此版本包括期待已久的新特性,如Java Platform模块化、性能提升、支持新标准以及许多其他改进。其中Java Platform模块化是java se development kit 9的最大特色,在引入了模块系统之后,JDK被重新组织成 94个模块。Java应用可以通过新增的jlink工具,创建出只包含所依赖的JDK模块的自定义运行时镜像,这样可以极大的减少Java 9运行时环境的大小,使得JDK可以在更小的设备中使用。
所需工具:点击下载java se development kit 9
java se development kit 9 64位新特性
1、Java平台级模块系统
Java 9的定义功能是一套全新的模块系统。当代码库越来越大,创建复杂,盘根错节的“意大利面条式代码”的几率呈指数级的增长。这时候就得面对两个基础的问题:很难真正地对代码进行封装,而系统并没有对不同部分(也就是 JAR文件)之间的依赖关系有个明确的概念。每一个公共类都可以被类路径之下任何其它的公共类所访问到,这样就会导致无意中使用了并不想被公开访问的 API。此外,类路径本身也存在问题:你怎么知晓所有需要的 JAR都已经有了,或者是不是会有重复的项呢?模块系统把这俩个问题都给解决了。
模块化的 JAR文件都包含一个额外的模块描述器。在这个模块描述器中,对其它模块的依赖是通过“requires”来表示的。另外,“exports”语句控制着哪些包是可以被其它模块访问到的。所有不被导出的包默认都封装在模块的里面。如下是一个模块描述器的示例,存在于“module-info.java”文件中:
请注意,两个模块都包含封装的包,因为它们没有被导出(使用橙色盾牌可视化)。没有人会偶然地使用来自这些包中的类。Java平台本身也使用自己的模块系统进行了模块化。通过封装 JDK的内部类,平台更安全,持续改进也更容易。
当启动一个模块化应用时, JVM会验证是否所有的模块都能使用,这基于 `requires`语句——比脆弱的类路径迈进了一大步。模块允许你更好地强制结构化封装你的应用并明确依赖。你可以在这个课程中学习更多关于 Java 9中模块工作的信息。
2. Linking
当你使用具有显式依赖关系的模块和模块化的 JDK时,新的可能性出现了。你的应用程序模块现在将声明其对其他应用程序模块的依赖以及对其所使用的 JDK模块的依赖。为什么不使用这些信息创建一个最小的运行时环境,其中只包含运行应用程序所需的那些模块呢?这可以通过 Java 9中的新的 jlink工具实现。你可以创建针对应用程序进行优化的最小运行时映像而不需要使用完全加载 JDK安装版本。
3. JShell:交互式 Java REPL
许多语言已经具有交互式编程环境,Java现在加入了这个俱乐部。您可以从控制台启动 jshell,并直接启动输入和执行 Java代码。 jshell的即时反馈使它成为探索 API和尝试语言特性的好工具。
测试一个 Java正则表达式是一个很好的说明 jshell如何使您的生活更轻松的例子。交互式 shell还可以提供良好的教学环境以及提高生产力,您可以在此了解更多信息。在教人们如何编写 Java的过程中,不再需要解释“public static void main(String [] args)”这句废话。
4.改进的 Javadoc
有时一些小事情可以带来很大的不同。你是否就像我一样在一直使用 Google来查找正确的 Javadoc页面呢?这不再需要了。Javadoc现在支持在 API文档中的进行搜索。另外,Javadoc的输出现在符合兼容 HTML5标准。此外,你会注意到,每个 Javadoc页面都包含有关 JDK模块类或接口来源的信息。
5.集合工厂方法
通常,您希望在代码中创建一个集合(例如,List或 Set),并直接用一些元素填充它。实例化集合,几个“add”调用,使得代码重复。 Java 9,添加了几种集合工厂方法:
除了更短和更好阅读之外,这些方法也可以避免您选择特定的集合实现。事实上,从工厂方法返回已放入数个元素的集合实现是高度优化的。这是可能的,因为它们是不可变的:在创建后,继续添加元素到这些集合会导致“UnsupportedOperationException”。
6.改进的 Stream API
长期以来,Stream API都是 Java标准库最好的改进之一。通过这套 API可以在集合上建立用于转换的申明管道。在 Java 9中它会变得更好。Stream接口中添加了 4个新的方法:
dropWhile, takeWhile, ofNullable。还有个 iterate方法的新重载方法,可以让你提供一个 Predicate(判断条件)来指定什么时候结束迭代:
第二个参数是一个 Lambda,它会在当前 IntStream中的元素到达 100的时候返回 true。因此这个简单的示例是向控制台打印 1到 99。
除了对 Stream本身的扩展,Optional和 Stream之间的结合也得到了改进。现在可以通过 Optional的新方法 `stram`将一个 Optional对象转换为一个(可能是空的) Stream对象:
在组合复杂的 Stream管道时,将 Optional转换为 Stream非常有用。
7.私有接口方法
Java9为我们带来了接口的默认方法。接口现在也可以包含行为,而不仅仅是方法签名。但是,如果在接口上有几个默认方法,代码几乎相同,会发生什么情况?通常,您将重构这些方法,调用一个可复用的私有方法。但默认方法不能是私有的。将复用代码创建为一个默认方法不是一个解决方案,因为该辅助方法会成为公共API的一部分。使用 Java 9,您可以向接口添加私有辅助方法来解决此问题:
如果您使用默认方法开发 API,那么私有接口方法可能有助于构建其实现。
8. HTTP/2
Java 9中有新的方式来处理 HTTP调用。这个迟到的特性用于代替老旧的
`HttpURLConnection` API,并提供对 WebSocket和 HTTP/2的支持。注意:新的
HttpClient API在 Java 9中以所谓的孵化器模块交付。也就是说,这套 API不能保证 100%完成。
9.多版本兼容 JAR
我们最后要来着重介绍的这个特性对于库的维护者而言是个特别好的消息。当一个新版本的 Java出现的时候,你的库用户要花费数年时间才会切换到这个新的版本。这就意味着库得去向后兼容你想要支持的最老的 Java版本(许多情况下就是 Java 6或者 7)。这实际上意味着未来的很长一段时间,你都不能在库中运用 Java 9所提供的新特性。
10、支持Unicode 8.0。JDK 8支持Unicode 6.2。
Unicode的6.3,7.0和8.0标准相结合引入10555个字符,29个脚本,和42块,所有这些在JDK 9支撑。
java9 64位安装教程:
1、软件下载解压完成后,点击jdk-9_windows-x64打开软件包,等待片刻后点击下一步开始安装软件。
2、选择安装组件和安装路径。
3、确定软件安装目录。
4、java9 64位安装完成。
更新日志
java se development kit 9是一个主要的功能版本,以下总结了Java SE 9和JDK 9(Oracle的Java SE 9的实现)中的功能和增强功能。
A、关键变化:
一、Java平台模块系统
介绍一种新的Java编程组件,这个模块是一个有名的,自描述的代码和数据集合。这个模块系统:
1、引入了一个新的可选阶段,即链接时间,该时间在编译时间和运行时间之间,在此期间可以将一组模块组装并优化为自定义运行时映像;看到jlink在工具Java平台,标准版工具参考。
2、将选项添加到工具javac,jlink以及java可以指定模块路径的位置,这些模块路径定位了模块的定义。
3、介绍模块化的JAR文件,它是一个JAR文件,module-info.class在其根目录中有一个文件。
4、介绍JMOD格式,除了可以包含本地代码和配置文件之外,它是与JAR类似的打包格式;看到这个jmod工具。
二、JEP 223:新的版本字符串计划
提供简化的版本字符串格式,有助于清楚地区分主要,次要,安全和修补程序更新版本。
B、新增功能
1、使用安装程序的用户界面启用或禁用Web部署
提供在安装程序的欢迎页面中启用或禁用Web部署的选项。要启用Web部署,请在“欢迎”页面中选择“自定义安装”,单击“安装”,然后选中“在浏览器中启用Java内容”复选框。
2、JEP 222:jshell:Java Shell(Read-Eval-Print Loop)
将Read-Eval-Print Loop(REPL)功能添加到Java平台。
该jshell工具提供了一个用于评估Java编程语言的声明,语句和表达式的交互式命令行界面。
它有助于对编码选项进行原型设计和探索,并立即得到结果和反馈。即时反馈与以表达式开始的能力相结合对教育非常有用,无论是学习Java语言,还是学习新的API或语言功能。
3、JEP 228:添加更多的诊断命令
定义其他诊断命令以提高诊断Hotspot和JDK问题的能力。
3、JEP 231:删除启动时JRE版本选择
删除了在启动时请求不是JRE版本的JRE版本的功能。
4、JEP 238:多版本JAR文件
扩展JAR文件格式,使多个Java特定版本的类文件能够共存于一个归档中。
5、JEP 240:删除JVM TI hprof代理
hprof从JDK中删除代理。该hprof代理程序被编写为JVM工具接口的演示代码,并不打算成为生产工具。
6、JEP 241:删除jhat工具
jhat从JDK中删除该工具。
7、JEP 245:验证JVM命令行标志参数
验证所有数字JVM命令行标志的参数以避免失败,如果发现它们是无效的,则会显示相应的错误消息。
如何将.class文件转换成.java文件
将WAR中的.class文件反编译成.java文件,反编译软件我用的是Java Decompiler",由 Pavel Kouznetsov开发,目前最新版本为0.2.5.它由 C++开发,并且官方可以下载 windows、linux和苹果Mac Os三个平台的可执行程序。
如何将现有的web程序导入到myeclipse环境中去
如果要将别人发布的war包,导入到自己的eclipse环境中进行再开发,最快的方法如下:
1、新建一个myeclipse的web project。
2、右键该工程,myeclipse/add struts capability,设置成struts开发环境。
3、将war包解压,全目录覆盖新工程的WebRoot(包括其中的web-inf/meta-inf目录),相应的scr目录(或者对应的包含java文件的目录)覆盖eclipse的src目录。myeclipse会自动将WEB-INF\lib下的jar包作为放到classpath中的。
4、refresh该工程,over。
JAVA语言是1995年5月由SUN公司发布的,由于其安全性高、代码优化、跨平台等特性,迅速取代了很多传统高级语言,占据了企业级网络应用开发等诸多领域的霸主地位。不过,JAVA最突出的跨平台优势使得它不能被编译成本。
JAVA语言是1995年5月由SUN公司发布的,由于其安全性高、代码优化、跨平台等特性,迅速取代了很多传统高级语言,占据了企业级网络应用开发等诸多领域的霸主地位。中国网管联盟www、bitsCN、com
不过,JAVA最突出的跨平台优势使得它不能被编译成本地代码,而要以中间代码的形式运行在虚拟机环境中,这使得JAVA的反编译要比别的高级语言容易实现,并且反编译的代码经过优化后几乎可以与源代码相媲美。
为了更好地保护知识产权,避免本公司的智力成果轻易被人窃取,开发者有必要对反编译工具深入了解,以便有针对性地采取保护措施。
目前,比较流行的JAVA反编译工具有近30种,其中有三款堪称精品:
一、应用广泛的JAD
在众多的JAVA反编译工具中,有几种非常著名的工具使用了相同的核心引擎——JAD,其中主要包括:Front End Plus、mDeJava、Decafe Pro、Cavaj Java Decompiler、DJ Java Decompiler、NMI’s Java Class Viewer和国产的JAVA源代码反编译专家。
JAD本身是一个命令行工具,没有图形界面,上述的这些工具大多是在JAD内核的基础之上加了一个图形界面而已。这么多种产品的共同选择,足可证明JAD在JAVA反编译领域中的尊贵地位。
笔者用来测试的JAD版本是1.5.8f。
JAD是使用Microsoft Visual C++开发的,运行速度非常快,可以处理很复杂的JAVA编译文件。众多的参数使JAD可以灵活应付多种加密手段,令反编译的代码更加优化和易读。由于JAD参数太多,没必要一一解释,其中有几个最常用的如下:
54com.cn
-d
-用于指定输出文件的目录
-s-输出文件扩展名(默认为:.jad),通常都会把输出文件扩展名直接指定为.java,以方便修改的重新编译。
-8-将Unicode字符转换为ANSI字符串,如果输出字符串是中文的话一定要加上这个参数才能正确显示。
最常用的反编译指令如下所示:
Jad–d c:\\javasource–s.java-8 javatest.class
这条指令将当前目录下的javatest.class反编译为javatest.java并保存在c:\\javasource目录里,其中的提示输出为中文,而不是Unicode代码。
二、源码开放的JODE
JODE是全球最大的开源项目网站Sourceforge.net的成员,不要以为源码开放就小瞧它,在所有的JAVA反编译器中,JODE的反编译效果是最好的,尤其是对付一些常见的加密手段,例如混淆技术等,更是出类拔粹。
JODE本身也是纯JAVA开发的,最近越来越多的JAVA反编译软件也选择JODE来做它们的核心引擎,例如JCavaj Java Decompiler、BTJ(Back To Java)、jEdit’s JavaInsight plugin等。
JODE是一个可运行的JAR文件,在windows环境下双击即可运行。
中国网管联盟www.bitscn.com
需要特别说明的是,JODE不是通过常规的Open->File的方式来加载JAVA编译后的类文件(*.class)或是类包(*.jar)的,而是通过在Options菜单中的Set Classpath来实现的,单独的类文件可以将它的上一级目录作为Classpath输入,然后再选择Reload Classpath即可。
如果你还想了解更多这方面的信息,记得收藏关注本站。