1. ホーム
  2. java

[解決済み] java.io.IOException。DER長の短い読み取り

2022-02-26 20:38:46

質問

x509証明書の情報を読み取り、それを TableView .

しかし、これらの情報を以下のようなコードで表示しようとすると、問題が発生します。

@FXML
private void handleHDD() throws CertificateException, IOException{
    String userDir = System.getProperty("user.home");
    File folder = new File(userDir +"\\Desktop\\Certificate_Folder");
    File[] certificates = folder.listFiles();
    if (certificates!=null){

        String columnHeader[] = {"Nom","Version","N°série","Algorithme de signature","Emetteur","Valide à partir de","Valide jusqu'au","Objet","Clé publique"};

        int sizeColumns = 9;

        for (File file : certificates){
            if(file.isFile()){
            CertificateFactory cf = CertificateFactory.getInstance("X.509");
            InputStream input = new FileInputStream(file);

            X509Certificate cert = (X509Certificate) cf.generateCertificate(input);
            input.close();
            for (int j = 0; j < sizeColumns; j++) {
                data.add(new CertificateModel(file.getName().replace(".der", ""),cert.getVersion(),cert.getSerialNumber().toString(),cert.getSigAlgName(),cert.getIssuerDN().toString(),cert.getNotBefore(),cert.getNotAfter(),cert.getSubjectDN().toString(),cert.getPublicKey().toString()));
                TableColumn col = new TableColumn();
                col.setText(columnHeader[j]);
                col.setMinWidth(200);
                col.setCellValueFactory(new PropertyValueFactory<CertificateModel, String>(columnHeader[j]));
                table.getColumns().addAll(col);
            }               
            table.setItems(data);

            }


            }

        }
    }

実行しようとすると、以下のような例外が発生します。 java.security.cert.CertificateException


これは、完全な例外スタックです。

Exception in thread "JavaFX Application Thread" java.lang.RuntimeException: java.lang.reflect.InvocationTargetException
at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1774)
at javafx.fxml.FXMLLoader$ControllerMethodEventHandler.handle(FXMLLoader.java:1657)
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86)
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)
at javafx.event.Event.fireEvent(Event.java:198)
at javafx.scene.Scene$ClickGenerator.postProcess(Scene.java:3470)
at javafx.scene.Scene$ClickGenerator.access$8100(Scene.java:3398)
at javafx.scene.Scene$MouseHandler.process(Scene.java:3766)
at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485)
at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762)
at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494)
at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:381)
at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295)
at java.security.AccessController.doPrivileged(Native Method)
at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$354(GlassViewEventHandler.java:417)
at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389)
at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:416)
at com.sun.glass.ui.View.handleMouseEvent(View.java:555)
at com.sun.glass.ui.View.notifyMouse(View.java:937)
at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at sun.reflect.misc.Trampoline.invoke(MethodUtil.java:71)
    at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at sun.reflect.misc.MethodUtil.invoke(MethodUtil.java:275)
    at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1771)
    ... 33 more
Caused by: java.security.cert.CertificateException: Unable to initialize, java.io.IOException: Short read of DER length
    at sun.security.x509.X509CertImpl.<init>(X509CertImpl.java:198)
    at sun.security.provider.X509Factory.engineGenerateCertificate(X509Factory.java:102)
    at java.security.cert.CertificateFactory.generateCertificate(CertificateFactory.java:339)
    at cm.camgovca.view.CertificateOverviewController.handleHDD(CertificateOverviewController.java:98)
    ... 43 more
Caused by: java.io.IOException: Short read of DER length
    at sun.security.util.DerInputStream.getLength(DerInputStream.java:582)
    at sun.security.util.DerValue.<init>(DerValue.java:252)
    at sun.security.util.DerInputStream.getDerValue(DerInputStream.java:451)
    at sun.security.x509.X509CertImpl.parse(X509CertImpl.java:1784)
    at sun.security.x509.X509CertImpl.<init>(X509CertImpl.java:195)
    ... 46 more

CertificateOverview.javaの98行目は

X509Certificate cert = (X509Certificate) cf.generateCertificate(input);

そして、私の証明書はDERエンコード(.der)です。

解決方法を教えてください。

のドキュメントを見ると CertificateFactory#generateCertificate と書いてあります。

を投げます。CertificateException - 構文解析のエラー時にスローされます。

ですから、コメントにあるように、おそらくあなたの証明書ファイルが期待される形式でないのでしょう。

特に、ドキュメントの以下の行が参考になると思います。

<ブロッククオート

X.509証明書の証明書ファクトリーの場合、inStreamで提供される証明書はDERエンコードされていなければならず、バイナリまたは印刷可能な(Base64)エンコーディングで提供することができます。証明書がBase64エンコーディングで提供される場合、それは-----BEGIN CERTIFICATE-----で始まり、-----END CERTIFICATE-----で終わり、で囲まれなければならない。

もしあなたが例外スタックと詳細な例外メッセージを投稿すれば、私たちはおそらくもっと助けられるでしょう。