찾다
데이터 베이스MySQL 튜토리얼如何在Oracle中使用Java存储过程 (详解)

其实,这篇短文,我早就应该写了。因为,java存储过程今后在各大数据库厂商中越来越流行,功能也越来越强大。这里以Oracle为例,介绍一下java存储过程的具体用法。 iihero on csdn) 一、如何创建java存储过程? 通常有三种方法来创建java存储过程。 1. 使用o

其实,这篇短文,我早就应该写了。因为,java存储过程今后在各大数据库厂商中越来越流行,功能也越来越强大。这里以Oracle为例,介绍一下java存储过程的具体用法。
iihero  on csdn)

一、如何创建java存储过程?
通常有三种方法来创建java存储过程。

1. 使用oracle的sql语句来创建:

e.g. 使用create or replace and compile java source named "" as
       后边跟上java源程序。要求类的方法必须是public static的,才能用于存储过程。

如何在Oracle中使用Java存储过程 (详解)SQL> create or replace and compile java source named "javademo1"
如何在Oracle中使用Java存储过程 (详解)  
2  as
如何在Oracle中使用Java存储过程 (详解)  
3  import java.sql.*;
如何在Oracle中使用Java存储过程 (详解)  
4  public class JavaDemo1
如何在Oracle中使用Java存储过程 (详解)  
5  {
如何在Oracle中使用Java存储过程 (详解)  
6  public static void main(String[] argv)
如何在Oracle中使用Java存储过程 (详解)  
7  {
如何在Oracle中使用Java存储过程 (详解)  
8  System.out.println("hello, java demo1");
如何在Oracle中使用Java存储过程 (详解)  
9  }
如何在Oracle中使用Java存储过程 (详解) 
10  }
如何在Oracle中使用Java存储过程 (详解) 
11  /
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)Java 已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> show errors java source "javademo1"
如何在Oracle中使用Java存储过程 (详解)没有错误。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> create or replace procedure javademo1
如何在Oracle中使用Java存储过程 (详解)  
2  as
如何在Oracle中使用Java存储过程 (详解)  
3  language java name 'JavaDemo1.main(java.lang.String[])';
如何在Oracle中使用Java存储过程 (详解)  
4  /
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)过程已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> set serveroutput on
如何在Oracle中使用Java存储过程 (详解)SQL
> call javademo1();
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> call dbms_java.set_output(5000);
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> call javademo1();
如何在Oracle中使用Java存储过程 (详解)hello, java demo1
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> call javademo1();
如何在Oracle中使用Java存储过程 (详解)hello, java demo1
如何在Oracle中使用Java存储过程 (详解)调用完成。

2. 使用外部class文件来装载创建
e.g. 这里既然用到了外部文件,必然要将class文件放到oracle Server的某一目录下边。

如何在Oracle中使用Java存储过程 (详解)public class OracleJavaProc
如何在Oracle中使用Java存储过程 (详解){
如何在Oracle中使用Java存储过程 (详解)    
public static void main(String[] argv)
如何在Oracle中使用Java存储过程 (详解)    {
如何在Oracle中使用Java存储过程 (详解)        System.out.println("It
's a Java Oracle procedure.");
如何在Oracle中使用Java存储过程 (详解)    }
如何在Oracle中使用Java存储过程 (详解)}
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> grant create any directory to scott;
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)授权成功。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> conn scott/tiger@iihero.oracledb
如何在Oracle中使用Java存储过程 (详解)已连接。
如何在Oracle中使用Java存储过程 (详解)SQL> create or   replace   directory   test_dir   as  
'd:/oracle';
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)目录已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> create or replace java class using bfile(test_dir, 
'OracleJavaProc.CLASS')
如何在Oracle中使用Java存储过程 (详解)  2  /
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)Java 已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> create or replace procedure testjavaproc as language java name 
'OracleJavaProc.main(java.lang.String[])';
如何在Oracle中使用Java存储过程 (详解)  2  /
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)过程已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> call testjavaproc();
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> execute testjavaproc;
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)PL/SQL 过程已成功完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> set serveroutput on size 5000
如何在Oracle中使用Java存储过程 (详解)SQL> call dbms_java.set_output(5000);
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL> execute testjavaproc;
如何在Oracle中使用Java存储过程 (详解)It
's a Java Oracle procedure.

3. 我推荐的一种方法,直接使用loadjava命令远程装载并创建。
    先创建一个类, e.g.

如何在Oracle中使用Java存储过程 (详解)import java.sql.*;
如何在Oracle中使用Java存储过程 (详解)
import oracle.jdbc.*;
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)
public class OracleJavaProc ...{
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)   
//Add a salgrade to the database.
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)
   public static void addSalGrade(int grade, int losal, int hisal) ...{
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)      System.out.println(
"Creating new salgrade for EMPLOYEE...");
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)      
try ...{
如何在Oracle中使用Java存储过程 (详解)         Connection conn 
=
如何在Oracle中使用Java存储过程 (详解)            DriverManager.getConnection(
"jdbc:default:connection:");
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)         String sql 
=
如何在Oracle中使用Java存储过程 (详解)            
"INSERT INTO salgrade " +
如何在Oracle中使用Java存储过程 (详解)            
"(GRADE,LOSAL,HISAL) " +
如何在Oracle中使用Java存储过程 (详解)            
"VALUES(?,?,?)";
如何在Oracle中使用Java存储过程 (详解)         PreparedStatement pstmt 
= conn.prepareStatement(sql);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
1,grade);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
2,losal);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
3,hisal);
如何在Oracle中使用Java存储过程 (详解)         pstmt.executeUpdate();
如何在Oracle中使用Java存储过程 (详解)         pstmt.close();
如何在Oracle中使用Java存储过程 (详解)         }

如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)      
catch(SQLException e) ...{
如何在Oracle中使用Java存储过程 (详解)         System.err.println(
"ERROR! Adding Salgrade: " 
如何在Oracle中使用Java存储过程 (详解)           
+ e.getMessage());
如何在Oracle中使用Java存储过程 (详解)         }

如何在Oracle中使用Java存储过程 (详解)   }

如何在Oracle中使用Java存储过程 (详解)}

使用loadjava命令将其装载到服务器端并编译:

D:eclipse3.1workspacedbtest>loadjava -u scott/tiger@iihero.oracledb -v -resolve Or
acleJavaProc
.java
arguments: '-u' 'scott
/tiger@iihero.oracledb '-v' '-resolve' 'OracleJavaProc.java'
creating : source OracleJavaProc
loading  : source OracleJavaProc
resolving: source OracleJavaProc

查询一下状态:

如何在Oracle中使用Java存储过程 (详解)连接到:
如何在Oracle中使用Java存储过程 (详解)Oracle9i Enterprise Edition Release 
9.2.0.1.0 - Production
如何在Oracle中使用Java存储过程 (详解)
With the Partitioning, OLAP and Oracle Data Mining options
如何在Oracle中使用Java存储过程 (详解)JServer Release 
9.2.0.1.0 - Production
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> SELECT object_name, object_type, status FROM user_objects WHERE object_type LIKE 'JAVA%';
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)
OBJECT_NAME
如何在Oracle中使用Java存储过程 (详解)
--------------------------------------------------------------------------------
如何在Oracle中使用Java存储过程 (详解)

如何在Oracle中使用Java存储过程 (详解)OBJECT_TYPE                          STATUS
如何在Oracle中使用Java存储过程 (详解)
------------------------------------ --------------
如何在Oracle中使用Java存储过程 (详解)
OracleJavaProc
如何在Oracle中使用Java存储过程 (详解)JAVA CLASS                           VALID
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)OracleJavaProc
如何在Oracle中使用Java存储过程 (详解)JAVA SOURCE                          VALID

测试一下存储过程:

如何在Oracle中使用Java存储过程 (详解)SQL> create or replace procedure add_salgrade(id number, losal number, hisal num
如何在Oracle中使用Java存储过程 (详解)ber) 
as language java name 'OracleJavaProc.addSalGrade(int, int, int)';
如何在Oracle中使用Java存储过程 (详解)  
2  /
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)过程已创建。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> set serveroutput on size 2000
如何在Oracle中使用Java存储过程 (详解)SQL
> call dbms_java.set_output(2000);
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)调用完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> execute add_salgrade(61000015000);
如何在Oracle中使用Java存储过程 (详解)Creating new salgrade 
for EMPLOYEE...
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)PL
/SQL 过程已成功完成。
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)SQL
> select * from salgrade where grade=6;
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)     GRADE      LOSAL      HISAL
如何在Oracle中使用Java存储过程 (详解)
---------- ---------- ----------
如何在Oracle中使用Java存储过程 (详解)
         6      10000      15000

 

二、如何更新你已经编写的java存储过程?  

假如要往类OracleJavaProc里添加一个存储过程方法,如何开发?
正确的步骤应该是先dropjava, 改程序,再loadjava。

e.g.修改OracleJavaProc类内容如下:

如何在Oracle中使用Java存储过程 (详解)import java.sql.*;
如何在Oracle中使用Java存储过程 (详解)
import oracle.jdbc.*
;
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)
public class OracleJavaProc ...
{
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)   
// Add a salgrade to the database.

如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)
   public static void addSalGrade(int grade, int losal, int hisal) ...{
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)      System.out.println(
"Creating new salgrade for EMPLOYEE..."
);
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)      
try ...
{
如何在Oracle中使用Java存储过程 (详解)         Connection conn 
=

如何在Oracle中使用Java存储过程 (详解)            DriverManager.getConnection(
"jdbc:default:connection:");
如何在Oracle中使用Java存储过程 (详解)
如何在Oracle中使用Java存储过程 (详解)         String sql 
=

如何在Oracle中使用Java存储过程 (详解)            
"INSERT INTO salgrade " +
如何在Oracle中使用Java存储过程 (详解)            
"(GRADE,LOSAL,HISAL) " +
如何在Oracle中使用Java存储过程 (详解)            
"VALUES(?,?,?)";
如何在Oracle中使用Java存储过程 (详解)         PreparedStatement pstmt 
=
 conn.prepareStatement(sql);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
1
,grade);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
2
,losal);
如何在Oracle中使用Java存储过程 (详解)         pstmt.setInt(
3
,hisal);
如何在Oracle中使用Java存储过程 (详解)         pstmt.executeUpdate();
如何在Oracle中使用Java存储过程 (详解)         pstmt.close();
如何在Oracle中使用Java存储过程 (详解)         }

如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)      
catch(SQLException e) ...{
如何在Oracle中使用Java存储过程 (详解)         System.err.println(
"ERROR! Adding Salgrade: "
 
如何在Oracle中使用Java存储过程 (详解)           
+
 e.getMessage());
如何在Oracle中使用Java存储过程 (详解)         }

如何在Oracle中使用Java存储过程 (详解)   }

如何在Oracle中使用Java存储过程 (详解)   
如何在Oracle中使用Java存储过程 (详解)   
public static int getHiSal(int grade)
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)   
...
{
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)    
try ...
{
如何在Oracle中使用Java存储过程 (详解)        Connection conn 
=

如何在Oracle中使用Java存储过程 (详解)          DriverManager.getConnection(
"jdbc:default:connection:");
如何在Oracle中使用Java存储过程 (详解)        String sql 
= "SELECT hisal FROM salgrade WHERE grade = ?"
;
如何在Oracle中使用Java存储过程 (详解)        PreparedStatement pstmt 
=
 conn.prepareStatement(sql);pstmt.setInt(1, grade);
如何在Oracle中使用Java存储过程 (详解)        ResultSet rset 
=
 pstmt.executeQuery();
如何在Oracle中使用Java存储过程 (详解)        
int res = 0
;
如何在Oracle中使用Java存储过程 (详解)        
if
 (rset.next())
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)        
...
{
如何在Oracle中使用Java存储过程 (详解)            res 
= rset.getInt(1
);
如何在Oracle中使用Java存储过程 (详解)        }

如何在Oracle中使用Java存储过程 (详解)        rset.close();
如何在Oracle中使用Java存储过程 (详解)        
return res;

       }
如何在Oracle中使用Java存储过程 (详解)    
catch
 (SQLException e) 
如何在Oracle中使用Java存储过程 (详解)如何在Oracle中使用Java存储过程 (详解)    
...
{
如何在Oracle中使用Java存储过程 (详解)        System.err.println(
"ERROR! Querying Salgrade: "
 
如何在Oracle中使用Java存储过程 (详解)           
+
 e.getMessage());
          return -1;
如何在Oracle中使用Java存储过程 (详解)    }
    
如何在Oracle中使用Java存储过程 (详解)   }

如何在Oracle中使用Java存储过程 (详解)      
如何在Oracle中使用Java存储过程 (详解)}

如何更新呢?

D:eclipse3.1workspacedbtest>dropjava -u scott -v OracleJavaProc

D:
/
tiger@iihero.oracledbeclipse3.1workspacedbtest>loadjava -u scott -v -resolve Or
acleJavaProc
/
tiger@iihero.oracledb.java
arguments: '-u' 'scott
/tiger@iihero.oracledb' '-v' '-resolve' 'OracleJavaProc.
java'
creating : source OracleJavaProc
loading  : source OracleJavaProc
resolving: source OracleJavaProc

后边的应用示例:

SQL> create or replace function query_hisal(grade numberreturn number as langu
age java name 
'OracleJavaProc.getHiSal(int) return int'
;
  
2  /


函数已创建。

SQL
> set serveroutput on size 2000
SQL
> call dbms_java.set_output(2000);

调用完成。
SQL
> select query_hisal(5from
 dual;

QUERY_HISAL(
5
)
--------------

          9999

全文完!

用法个人见解:不要手动drop java source, 不要手动drop procedure。



성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL은 데이터 복제를 어떻게 처리합니까?MySQL은 데이터 복제를 어떻게 처리합니까?Apr 28, 2025 am 12:25 AM

MySQL은 비동기식, 반 동시성 및 그룹 복제의 세 가지 모드를 통해 데이터 복제를 처리합니다. 1) 비동기 복제 성능은 높지만 데이터가 손실 될 수 있습니다. 2) 반 동기화 복제는 데이터 보안을 향상 시키지만 대기 시간을 증가시킵니다. 3) 그룹 복제는 고 가용성 요구 사항에 적합한 다중 마스터 복제 및 장애 조치를 지원합니다.

설명 명세서를 사용하여 쿼리 성능을 분석 할 수있는 방법은 무엇입니까?설명 명세서를 사용하여 쿼리 성능을 분석 할 수있는 방법은 무엇입니까?Apr 28, 2025 am 12:24 AM

설명 설명은 SQL 쿼리 성능을 분석하고 개선하는 데 사용될 수 있습니다. 1. 쿼리 계획을 보려면 설명 명세서를 실행하십시오. 2. 출력 결과를 분석하고 액세스 유형, 인덱스 사용량 및 조인 순서에주의를 기울이십시오. 3. 분석 결과를 기반으로 인덱스 생성 또는 조정, 조인 작업을 최적화하며 전체 테이블 스캔을 피하여 쿼리 효율성을 향상시킵니다.

MySQL 데이터베이스를 어떻게 백업하고 복원합니까?MySQL 데이터베이스를 어떻게 백업하고 복원합니까?Apr 28, 2025 am 12:23 AM

논리 백업에 mysqldump를 사용하고 핫 백업을 위해 mysqlenterprisebackup을 사용하는 것은 mySQL 데이터베이스를 백업하는 효과적인 방법입니다. 1. MySQLDUMP를 사용하여 데이터베이스를 백업합니다 : MySQLDUMP-UROOT-PMYDATABASE> MYDATABASE_BACKUP.SQL. 2. Hot Backup : MySQLBackup- 사용자 = root-password = password-- backup-dir =/path/to/backupbackup에 mysqlenterprisebackup을 사용하십시오. 회복 할 때 해당 수명을 사용하십시오

MySQL에서 느린 쿼리의 일반적인 원인은 무엇입니까?MySQL에서 느린 쿼리의 일반적인 원인은 무엇입니까?Apr 28, 2025 am 12:18 AM

느린 MySQL 쿼리의 주된 이유는 인덱스의 누락 또는 부적절한 사용, 쿼리 복잡성, 과도한 데이터 볼륨 및 불충분 한 하드웨어 리소스가 포함됩니다. 최적화 제안에는 다음이 포함됩니다. 1. 적절한 인덱스 생성; 2. 쿼리 문을 최적화합니다. 3. 테이블 파티셔닝 기술 사용; 4. 적절하게 하드웨어를 업그레이드합니다.

MySQL의 견해는 무엇입니까?MySQL의 견해는 무엇입니까?Apr 28, 2025 am 12:04 AM

MySQL View는 SQL 쿼리 결과를 기반으로 한 가상 테이블이며 데이터를 저장하지 않습니다. 1) 뷰는 복잡한 쿼리를 단순화하고 2) 데이터 보안을 향상시키고 3) 데이터 일관성을 유지합니다. 뷰는 테이블처럼 사용할 수있는 데이터베이스에 저장된 쿼리이지만 데이터는 동적으로 생성됩니다.

MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit, 자동 점유, 문자열 comparison, 하위 쿼리 및 퍼포먼스 앤 알리 분석 .1) mysqluse Slimit, whilesqlSerVerusestOpandoracleSrownum.2) MySql'Sauto_incrementContrastSwithPostgresql'serialandoracle '

MySQL 파티셔닝이란 무엇입니까?MySQL 파티셔닝이란 무엇입니까?Apr 27, 2025 am 12:23 AM

MySQL 파티셔닝은 성능을 향상시키고 유지 보수를 단순화합니다. 1) 큰 테이블을 특정 기준 (예 : 날짜 범위)으로 작은 조각으로 나누고, 2) 데이터를 독립적 인 파일로 물리적으로 나눌 수 있습니다.

MySQL에서 어떻게 권한을 부여하고 취소합니까?MySQL에서 어떻게 권한을 부여하고 취소합니까?Apr 27, 2025 am 12:21 AM

MySQL에서 권한을 부여하고 취소하는 방법은 무엇입니까? 1. 보조금 명세서를 사용하여 grantallprivilegesondatabase_name.to'username'@'host '와 같은 부여 권한; 2. Revoke 문을 사용하여 Revokeallprivilegesondatabase_name.from'username'@'host '와 같은 권한을 취소하여 허가 변경의 적시에 의사 소통을 보장하십시오.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는