Java は、アプリケーションの開発に広く使用されているプログラミング言語です。 Java 11 の導入により、新しいセキュリティ オプションが導入されました。ただし、これらの新しいオプションによっていくつかの問題が発生する可能性もあります。この記事では、Java11 の新しいセキュリティ オプション エラーと、それらに対処して回避する方法について説明します。
新しいセキュリティ オプション
Java11 の新しいセキュリティ オプションには、主に次の 3 つの側面が含まれます:
- アプリケーション クラス ローダー
Java11新しいアプリケーション クラス ローダーが導入され、アプリケーション クラス ローダーの動作を制御するためのいくつかの新しいオプションが導入されています。これらのオプションには主に次のものが含まれます。
- Xshare:off オプションは、共有クラス キャッシュ機能をオフにするために使用されます。
- --class-path オプションは、アプリケーションがロードする必要があるクラスパスを指定するために使用されます。
- --module-path オプションは、アプリケーションがロードする必要があるモジュール パスを指定するために使用されます。
- デフォルトのアルゴリズムを無効にする
SHA-1 や MD5 などの一部の安全でない暗号化アルゴリズムは、Java11 ではデフォルトで無効になっています。これらのアルゴリズムを有効にするには、特別なオプションが必要です。これらのオプションは次のとおりです。
- --add-exports java.base/jdk.internal.crypto=ALL-UNNAMED オプションは、名前のないモジュールに暗号化機能を公開します。
- --add-opens java.base/java.security=ALL-UNNAMED オプションは、名前のないモジュールに対して Java セキュリティ ディレクトリを開くために使用されます。
- コンパイラの制限
Java11 では、コンパイラの新しい制限もいくつか導入されています。これらの制限は主に次の状況に適用されます。
- sun.misc パッケージ内のクラスへのアクセスは禁止されています。
- 特定の Java SE API の使用は禁止されています。
- 未公開の API の使用は禁止されています。
Java11 の新しいセキュリティ オプション エラー
Java11 にアップグレードすると、アプリケーション開発者は次のエラーに遭遇する可能性があります:
- java.lang.IllegalAccessException 例外
リフレクションを通じて sun.misc.Unsafe クラスにアクセスすると、java.lang.IllegalAccessException 例外が発生することがあります。これは、Java11 では sun.misc パッケージ内のクラスへのアクセスが許可されなくなったためです。
解決策: Unsafe クラスを安全なメソッドに置き換えます。たとえば、java.nio.Bits または java.lang.invoke.VarHandle を使用します。
- java.lang.NoClassDefFoundError 例外
java.lang.NoClassDefFoundError 例外は、アプリケーションがアプリケーション クラス ローダーを使用してクラスをロードするときに発生することがあります。これは通常、共有クラスのキャッシュをオフにする -Xshare:off オプションを有効にすることによって発生します。
回避策: 次のコマンド ライン オプションを使用して、共有クラス キャッシュを有効にします:
java -Xshare:auto -jar app.jar
- コンパイル エラー
アプリケーションが Java SE API または文書化されていない API を使用しようとすると、コンパイル エラーが発生する可能性があります。
解決策: Java 標準ライブラリの代替 API を使用するか、自分で機能を実装します。同時に、未承認の API の使用を避けてください。
Java11 の新しいセキュリティ オプションのエラーを回避する
上記の解決策に加えて、Java11 の新しいセキュリティ オプションのエラーを回避するために次の方法があります。
- アプリケーション
Java 11 の新しいセキュリティ オプションに適応するために、可能な限りアプリケーションをアップグレードしてください。アプリケーションが古い API を使用している場合、アプリケーションではさらに多くの問題が発生します。
- 新しいセキュリティ オプションを理解する
Java11 の新しいセキュリティ オプションを理解し、それらを正しく使用する方法を学びます。
- 新しいオプションを使用する
Java 11 の新しいオプションを使用して、アプリケーションとクラス ローダーの動作を制御します。
- アプリケーションのテスト
アプリケーションをテストして、新しい Java11 環境で実行され、新しいセキュリティ オプションが正しく処理されることを確認します。
結論
Java11 の新しいセキュリティ オプションにより、Java アプリケーションの安全性が高まります。ただし、これらのオプションによっていくつかの問題が発生する可能性もあります。これらのオプションを正しく理解して使用し、アプリケーションをテストすることは、これらの問題を回避するのに役立ちます。問題が発生した場合は、アプリケーションをスムーズに実行できるように、タイムリーに問題を解決するための措置を講じる必要があります。
以上がJava エラー: Java11 新しいセキュリティ オプション エラー、対処方法と回避方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

javaispopularforsoss-platformdesktopapplicationsduetoits "writeonce、runaynay" philosophy.1)itusesbytecodatiTatrunnanyjvm-adipplatform.2)ライブラリリケンディンガンドジャヴァフククレアティック - ルルクリス

Javaでプラットフォーム固有のコードを作成する理由には、特定のオペレーティングシステム機能へのアクセス、特定のハードウェアとの対話、パフォーマンスの最適化が含まれます。 1)JNAまたはJNIを使用して、Windowsレジストリにアクセスします。 2)JNIを介してLinux固有のハードウェアドライバーと対話します。 3)金属を使用して、JNIを介してMacOSのゲームパフォーマンスを最適化します。それにもかかわらず、プラットフォーム固有のコードを書くことは、コードの移植性に影響を与え、複雑さを高め、パフォーマンスのオーバーヘッドとセキュリティのリスクをもたらす可能性があります。

Javaは、クラウドネイティブアプリケーション、マルチプラットフォームの展開、および言語間の相互運用性を通じて、プラットフォームの独立性をさらに強化します。 1)クラウドネイティブアプリケーションは、GraalvmとQuarkusを使用してスタートアップ速度を向上させます。 2)Javaは、埋め込みデバイス、モバイルデバイス、量子コンピューターに拡張されます。 3)Graalvmを通じて、JavaはPythonやJavaScriptなどの言語とシームレスに統合して、言語間の相互運用性を高めます。

Javaの強力なタイプ化されたシステムは、タイプの安全性、統一タイプの変換、多型を通じてプラットフォームの独立性を保証します。 1)タイプの安全性は、コンパイル時間でタイプチェックを実行して、ランタイムエラーを回避します。 2)統一された型変換ルールは、すべてのプラットフォームで一貫しています。 3)多型とインターフェイスメカニズムにより、コードはさまざまなプラットフォームで一貫して動作します。

JNIはJavaのプラットフォームの独立を破壊します。 1)JNIは特定のプラットフォームにローカルライブラリを必要とします。2)ローカルコードをターゲットプラットフォームにコンパイルおよびリンクする必要があります。3)異なるバージョンのオペレーティングシステムまたはJVMは、異なるローカルライブラリバージョンを必要とする場合があります。

新しいテクノロジーは、両方の脅威をもたらし、Javaのプラットフォームの独立性を高めます。 1)Dockerなどのクラウドコンピューティングとコンテナ化テクノロジーは、Javaのプラットフォームの独立性を強化しますが、さまざまなクラウド環境に適応するために最適化する必要があります。 2)WebAssemblyは、Graalvmを介してJavaコードをコンパイルし、プラットフォームの独立性を拡張しますが、パフォーマンスのために他の言語と競合する必要があります。

JVMの実装が異なると、プラットフォームの独立性が得られますが、パフォーマンスはわずかに異なります。 1。OracleHotspotとOpenJDKJVMは、プラットフォームの独立性で同様に機能しますが、OpenJDKは追加の構成が必要になる場合があります。 2。IBMJ9JVMは、特定のオペレーティングシステムで最適化を実行します。 3. Graalvmは複数の言語をサポートし、追加の構成が必要です。 4。AzulzingJVMには、特定のプラットフォーム調整が必要です。

プラットフォームの独立性により、開発コストが削減され、複数のオペレーティングシステムで同じコードセットを実行することで開発時間を短縮します。具体的には、次のように表示されます。1。開発時間を短縮すると、1セットのコードのみが必要です。 2。メンテナンスコストを削減し、テストプロセスを統合します。 3.展開プロセスを簡素化するための迅速な反復とチームコラボレーション。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ホットトピック









