Шаги для добавления Apache Commons Code c в oracle базу данных - PullRequest
0 голосов
/ 05 февраля 2020

У меня есть библиотека общих кодеков Apache, и мне нужно вызвать ее в базе данных Oracle 11, чтобы я мог создать источник java, который будет использовать классы внутри него, как показано ниже.

Какие шаги нужно сделать, чтобы эта библиотека была включена в базу данных?

Java file needs to be included in Oracle DB

** Код должен быть достигнут, но символ не найден

CREATE OR REPLACE JAVA SOURCE NAMED "org_apache_Base64" AS
import java.lang.*;
import java.sql.*;
import oracle.sql.*;
import java.io.*;
import javax.xml.bind.DatatypeConverter;
import org.apache.commons.codec.binary.Base64; 

public class org_apache_Base64
{
  public static void ExportBlob(String CONTFILE, BLOB CONTBLOB) throws Exception
  {
  try
  {
    File file = new File("/u01/oracle/jam_export/contract1");
    FileOutputStream fos = new FileOutputStream(file);  
    byte[] encodedBytes = Base64.getEncoder().encode("Test".getBytes());
    System.out.println("encodedBytes " + new String(encodedBytes));
    byte[] decodedBytes = Base64.getDecoder().decode(encodedBytes);
    System.out.println("decodedBytes " + new String(decodedBytes)); 
    System.out.println("PDF File Saved");
    fos.write(decoded); 
    fos.flush();
    fos.close(); 
    }
    catch  (Exception e) 
    {
     System.out.println(e); 
    }
  } };

1 Ответ

0 голосов
/ 05 февраля 2020

Найдите jar файлы , содержащие эти зависимости (которые, вероятно, можно загрузить из Apache Commons Code c), а затем используйте утилиту loadjava чтобы сохранить их в базе данных, чтобы Oracle мог найти их в своем пути к классам.

loadjava -user USERNAME/PASSWORD@SID name_of_jar_file.jar

Если вы хотите включить исходные файлы, вы также можете сделать это с помощью loadjava, но я не рекомендовал бы ее для внешней библиотеки, поскольку вам нужно было бы загрузить ALL зависимости для файла Base64.java, а это могут быть сотни (или тысячи) других исходных файлов; проще просто найти JAR, в котором они упакованы, и загрузить этот ресурс (или скомпилировать исходный код и упаковать его JAR самостоятельно).

...