- vừa được xem lúc

JAVA Chỉnh sửa *.JAR file mà không cần sourcecode

0 0 133

Người đăng: ledangtuanbk

Theo Viblo Asia

1. Yêu cầu bài toán

Bạn có 1 file *.jar dùng để chạy một số công việc hiện tại. Nhưng nó có 1 lỗi nhỏ, bạn muốn chỉnh sửa nó nhưng không có source-code.

2. Các giải pháp

Có 2 giải pháp

  1. Decompile *.jar -> chỉnh sửa -> build lại
  2. Giải nén Java classes -> Modify Java Bytecode -> Đóng gói lại

Phương pháp (1) có khá nhiều ưu điểm nếu bạn quen thuộc với Java, tuy nhiên nó cũng sẽ có những nhược điểm

  1. File jar phụ thuộc vào nhiều thư viện, bạn phải tìm hiểu để import đúng các thư viện đó.
  2. Quá trình decompile sẽ không chính xác 100%, bạn phải có kinh nghiệm để fix rất nhiều lỗi mới có thể compile được. Tùy thuộc vào mực độ phức tạp của project nó sẽ sinh ra số lỗi khác nhau. Mất khá nhiều thời gian để fix nó.

Trong bài hôm nay, mình chủ yếu tập trung vào phương pháp (2): Nhanh hơn, ít lỗi hơn và nó đơn giản thực hiện. Nó sẽ hữu ích cho developer vá những lỗi nhỏ. Có 1 số case hữu ích:

  1. Loại bỏ các giới hạn của phần mềm (bản quyền, chữ ký ...)
  2. Sử các lỗi liên quan security mà không cần source code
  3. Thêm một số đoạn code nhỏ.

3. Cách thực hiện

Trong bài toán này mình đã build 1 file jar Test.jar Khi chạy thì nó hiển thị như sau: Có 2 lỗi ở đây

  1. valuee -> value
  2. 3.15->3.14
java -jar Test.jar
The valuee of pi: 3.15

Để sửa file này chúng ta làm các bước sau(máy đã cài sẵn java jdk của mình là bản 1.8) :

  1. Giải nén file *.jar
  2. Sửa file .class bằng Java Bytecode Editor
  3. Đóng gói lại file *.jar
  4. Chạy lại và test

3.1 Giải nén file *.jar

Mình thao tác trên linux, các môi trường khác làm tương tự (hiểu ý tưởng của nó là được)

// Tạo 1 folder để thực hiện mkdir test // copy file Test.jar mình gửi link ở trên vào thư mục vừa tạo cp Test.jar test
// di chuyển vào thư mục đó
cd test
// giải nén jar -xf Test.jar // xóa file Test.jar đi rm Test.jar
// Kiểm tra các file trong thư mục tree .

Quan sát ta thấy có 1 file *.class -> Test.class

.
├── com
│ └── ldt
│ └── test
│ └── Test.class
└── META-INF ├── MANIFEST.MF └── maven └── org.example └── TestJar ├── pom.properties └── pom.xml 

Thử đọc file này thấy lỗi tung tóe

cat com/ldt/test/Test.class

Chúng ta phải sử dụng tool chuyển dụng để đọc bytecode file -> bước 2

3.2. Sửa file .class bằng Java Bytecode Editor

Tải về và run từ link Java bytecode editor 0.1.1

Sau khi tải về thì có các file như sau:

drwxrwxr-x 4 ldt ldt 4096 Mar 13 2011 ./
drwxr-xr-x 27 ldt ldt 4096 May 9 19:21 ../
drwxrwxr-x 4 ldt ldt 4096 Mar 13 2011 bin/
-rw-rw-r-- 1 ldt ldt 18007 Jul 6 2004 COPYING.TXT
-rw-rw-r-- 1 ldt ldt 53 Sep 29 2006 jbe.bat
-rw-rw-r-- 1 ldt ldt 53 Sep 29 2006 jbe.sh
drwxrwxr-x 4 ldt ldt 4096 Mar 13 2011 src/
-rw-rw-r-- 1 ldt ldt 26 Mar 13 2011 version.txt

Windows chạy jbe.bat Linux: jbe.sh

Lưu ý: Mình thao tác trên linux (Ubuntu) ban đầu nó chưa cấp quyề chạy file jbe.sh Mình cấp quyền cho nó

chmod a+x jbe.sh

Sau đó chạy thì bị lỗi, mình không rõ ở chỗ nào, có lẽ do lúc tạo file này có vấn đề. mình tạo 1 file run.sh để run với nội dung giống hệt file này. **Bạn nào biết lỗi ở đâu thì chỉ giúp mình **

_@.com:~/Downloads/jbe$ ./jbe.sh ./jbe.sh: line 1: cd: $'bin\r': No such file or directory
Error: Could not find or load main class ee.ioc.cs.jbe.browser.BrowserApplication
Caused by: java.lang.ClassNotFoundException: ee.ioc.cs.jbe.browser.BrowserApplication
nano run.sh
chmod a+x run.sh

Đây là nội dung file run.sh giống với file cũ jbe.sh

cd bin
java ee.ioc.cs.jbe.browser.BrowserApplication

Bật tool JBE rồi mở file

Methods -> main -> Code -> Chọn tab Code Editor

Nếu bạn có kiến thức về Java ByteCode thì sẽ hiểu không thì bắt buộc phải đoán. Như mình quan sát thấy : có biến 3.15 (line 1) và valuee ở line 7

Sửa và lưu lại click button (Save method) đến bước tiếp theo

3.3. Đóng gói lại file *.jar

jar -cvmf META-INF/MANIFEST.MF TestNew.jar ./*

Mình đóng gói lại file TestNew.jar Lưu ý: Phải chỉ đường dẫn chính xác đến file MANIFEST.MF, ban đầu mình không chỉ và bị lỗi (no main class found)

Sau khi chạy xong ta có file TestNew.jar, chuyển sang bước 4 để kiểm thử lại

3.4. Chạy lại và test

_@.com:~/temp/git/TestJar/target/test$ java -jar TestNew.jar The value of pi: 3.14

Đúng như ta mong muốn

4. Kết luận:

  1. Mỗi phương pháp sẽ có những ưu và nhược điểm riêng, tùy theo từng yêu cầu để lựa chọn phương thức cho phù hợp
  2. Để sử dụng phương pháp sửa java bytecode: Cần có những kiến thức và java bytecode, hiểu cấu trúc file, biết sửa file class nào, sửa chỗ nào... Trong ví dụ trên, nó rất đơn giản và dễ tìm, với file phức tạp thì cần nhiều thời gian hơn. Trong bài * tiếp theo mình sẽ hướng dẫn tìm hiểu về bytecode, cấu trúc trong đó.
  3. Chúng ta cũng có thể dùng tool Java Decomplier để hiểu cấu trúc file và project, từ đó dễ dàng đoán được đoạn code mình cẩn sửa ở file nào. Do project nhỏ nên nhìn rất rõ file và nội dung file .java

Tài liệu tham khảo

Bình luận

Bài viết tương tự

- vừa được xem lúc

Tổng hợp các bài hướng dẫn về Design Pattern - 23 mẫu cơ bản của GoF

Link bài viết gốc: https://gpcoder.com/4164-gioi-thieu-design-patterns/. Design Patterns là gì. Design Patterns không phải là ngôn ngữ cụ thể nào cả.

0 0 302

- vừa được xem lúc

Học Spring Boot bắt đầu từ đâu?

1. Giới thiệu Spring Boot. 1.1.

0 0 277

- vừa được xem lúc

Cần chuẩn bị gì để bắt đầu học Java

Cần chuẩn bị những gì để bắt đầu lập trình Java. 1.1. Cài JDK hay JRE.

0 0 50

- vừa được xem lúc

Sử dụng ModelMapper trong Spring Boot

Bài hôm nay sẽ là cách sử dụng thư viện ModelMapper để mapping qua lại giữa các object trong Spring nhé. Trang chủ của ModelMapper đây http://modelmapper.org/, đọc rất dễ hiểu dành cho các bạn muốn tìm hiểu sâu hơn. 1.

0 0 194

- vừa được xem lúc

[Java] 1 vài tip nhỏ khi sử dụng String hoặc Collection part 1

. Hello các bạn, hôm nay mình sẽ chia sẻ về mẹo check String null hay full space một cách tiện lợi. Mình sẽ sử dụng thư viện Lớp StringUtils download file jar để import vào thư viện tại (link).

0 0 71

- vừa được xem lúc

Deep Learning với Java - Tại sao không?

Muốn tìm hiểu về Machine Learning / Deep Learning nhưng với background là Java thì sẽ như thế nào và bắt đầu từ đâu? Để tìm được câu trả lời, hãy đọc bài viết này - có thể kỹ năng Java vốn có sẽ giúp bạn có những chuyến phiêu lưu thú vị. DJL là tên viết tắt của Deep Java Library - một thư viện mã ng

0 0 139