oracle 存储过程执行java进行密码加密成LDAP方式2

步骤

1.先写 java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import sun.misc.BASE64Encoder;


public class PwdToLdap {

public static String ldapSHA(String pwd) {
byte[] md = hexStringTobyteArray(pwd);
return "{SHA}" + (new BASE64Encoder()).encode(md);
}

public static byte[] hexStringTobyteArray(String str) {
if(str == null || str.trim().equals("")) {
return new byte[0];
}


byte[] bytes = new byte[str.length() / 2];
for(int i = 0; i < str.length() / 2; i++) {
String subStr = str.substring(i * 2, i * 2 + 2);
bytes[i] = (byte) Integer.parseInt(subStr, 16);
}
return bytes;
}


}
2.把相关包拷贝到当前目录下(rt.jar)
3.查询 oracle 的 jdk 版本
1
2
3
4
5
6
CREATE OR REPLACE FUNCTION get_java_property (prop IN VARCHAR2)
RETURN VARCHAR2 IS LANGUAGE JAVA
name 'java.lang.System.getProperty(java.lang.String) return java.lang.String';


SELECT get_java_property('java.version') FROM dual;
4.loadjava 导入到 oracle 中
1
F:\bufx>loadjava -r -f -u sys/123456@192.168.2.110:1521/orcl -v PwdToLdap.java
5.sql 查询是否存在 Java
1
SELECT * FROM USER_OBJECTS WHERE OBJECT_TYPE ='JAVA CLASS'order by created desc;
6.写存储过程
1
CREATE OR REPLACE FUNCTION PwdToLdap(str in varchar2)  RETURN VARCHAR2 AS LANGUAGE JAVA NAME 'PwdToLdap.ldapSHA (java.lang.String) return java.lang.String';
7.执行存储过程(两种方法)
7.1 直接查询
1
SELECT PwdToLdap('18dacbf7db89381473a754b4d76b0c3f03749ecc') FROM dual;
7.2 sqlplus 执行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SQL> VARIABLE myString VARCHAR2(20);
SQL> CALL PwdToLdap('18dacbf7db89381473a754b4d76b0c3f03749ecc') INTO :myString;
Method called
myString
---------
{SHA}GNrL99uJOBRzp1S012sMPwN0nsw=


SQL> PRINT myString;
myString
---------
{SHA}GNrL99uJOBRzp1S012sMPwN0nsw=


SQL>
9.删除 java 类
1
dropjava -u sys/123456@192.168.2.110:1521/orcl -v -resolve PwdToLdap.class

oracle 存储过程执行java进行密码加密成LDAP方式2

https://blog.buubiu.com/oracle-存储过程执行java进行密码加密成LDAP方式2/

作者

buubiu

发布于

2019-10-18

更新于

2024-01-25

许可协议