久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

NoSuchAlgorithmException:算法 HmacSHA1 不可用

NoSuchAlgorithmException: Algorithm HmacSHA1 not available(NoSuchAlgorithmException:算法 HmacSHA1 不可用)
本文介紹了NoSuchAlgorithmException:算法 HmacSHA1 不可用的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

看java的下面一行:

Look at the following line of java:

Mac.getInstance("HmacSHA1");

如果我把它放在一個簡單的測試程序中,它在我的服務器上運行沒有問題.但是,如果我在容器中使用這條線,我會得到

If I put this in a simple test program, it runs without problems on my server. However, if I use this line in a container, I get

java.security.NoSuchAlgorithmException: Algorithm HmacSHA1 not available
  at javax.crypto.Mac.getInstance(DashoA13*..)

在這兩種情況下都使用相同的 JDK 安裝.

The same JDK installation is used in both cases.

在谷歌上搜索了一下之后,我通過做兩件事設法讓它工作:

After googling around a bit, I managed to get it to work by doing two things:

  1. $JAVA_HOME/jre/lib/ext中的sunjce_provider.jar復制到容器的lib目錄中.
  2. 將以下行添加到我的代碼中:

  1. Copying sunjce_provider.jar from $JAVA_HOME/jre/lib/ext to the lib directory of the container.
  2. Adding the following line to my code:

java.security.Security.addProvider(new com.sun.crypto.provider.SunJCE());

具體來說,這發生在我的 Apache James 郵件中,但我很漂亮確定這與 JVM 選項有關.這里是啟動腳本 它使用.

Specifically, this happens to me in an Apache James mailet, but I'm pretty sure this is has to do with JVM options. Here is the startup script that it uses.

雖然我最終得到了它的工作,但這個解決方案感覺太老套了,無法成為正確的解決方案.我將不勝感激對正在發生的事情的解釋,以及更適當"的解決方案.

Although I got it to work in the end, the solution feels too hacked to be the right one. I would appreciate an explanation of what is going on, as well as a more "proper" solution.

相關問題:使用Java加密導致NoSuchAlgorithmException.但是,在這種情況下,我很確定應該支持開箱即用的 HmacSHA1 算法.作為證據,這在測試程序中沒有問題.

Related question: Using Java crypto leads to NoSuchAlgorithmException. However, in this case I'm pretty sure the HmacSHA1 algorithm should be supported out of the box. As evidence, this works without problems in a test program.

推薦答案

啟動腳本將 java.ext.dirs 設置為其自己的目錄集(特定于應用程序),但省略了"normal" 擴展目錄 ($JAVA_HOME/jre/lib/ext/),它是 sunjce_provider.jar 所在的位置.這解釋了您的第一點(將 Jar 文件復制到 lib 目錄使其再次可見).這很容易復制.

The startup script sets the java.ext.dirs to its own set of directories (specific to the application) but omitting the "normal" extension directory ($JAVA_HOME/jre/lib/ext/) which is where sunjce_provider.jar resides. This explains your first point (copying the Jar file to the lib directory makes it visible again). This is easily reproduced.

至于第二點,我認為這是由于啟動腳本使用 -Djava.security.policy 選項設置的策略文件所致.某些提供程序是否可用取決于策略文件.默認策略文件使 SunJCE 提供程序可用,但由于啟動腳本要求使用非默認的自定義策略文件,因此一切正常.我建議你看看那個策略文件.

As for the second point, I think this is due the policy file that the startup script sets with the -Djava.security.policy option. Whether some providers are available or not depends on policy files. The default policy file makes the SunJCE provider available, but since the startup scripts mandates a non-default, custom policy file, then anything goes. I suggest you take a look at that policy file.

例如,在我的系統上(Ubuntu Linux,Ubuntu 打包的 Sun JVM 1.6.0_20),默認策略文件在 /etc/java-6-sun/security/java.security 并包含(除其他外)以下幾行:

For instance, on my system (Ubuntu Linux, with Sun JVM 1.6.0_20 as packaged by Ubuntu), the default policy file is in /etc/java-6-sun/security/java.security and contains (among others) the following lines:

security.provider.1=sun.security.provider.Sun
security.provider.2=sun.security.rsa.SunRsaSign
security.provider.3=com.sun.net.ssl.internal.ssl.Provider
security.provider.4=com.sun.crypto.provider.SunJCE
security.provider.5=sun.security.jgss.SunProvider
security.provider.6=com.sun.security.sasl.Provider
security.provider.7=org.jcp.xml.dsig.internal.dom.XMLDSigRI
security.provider.8=sun.security.smartcardio.SunPCSC

它定義了默認情況下應該可用的提供程序.根據您的癥狀,我認為自定義策略文件使 SunJCE 不可用,除非明確注冊(這是可以理解的,因為啟動腳本還刪除了對包含 SunJCE 的 Jar 文件的訪問......).

which define what providers should be available by default. From your symptoms, I think that the custom policy file made SunJCE unavailable unless explicitly registered (which is understandable since the startup script also removed the access to the Jar file containing SunJCE...).

這篇關于NoSuchAlgorithmException:算法 HmacSHA1 不可用的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Java Remove Duplicates from an Array?(Java從數組中刪除重復項?)
How to fix Invocation failed Unexpected Response from Server: Unauthorized in Android studio(如何修復調用失敗來自服務器的意外響應:在 Android 工作室中未經授權)
AES encryption, got extra trash characters in decrypted file(AES 加密,解密文件中有多余的垃圾字符)
AES Error: Given final block not properly padded(AES 錯誤:給定的最終塊未正確填充)
Detecting incorrect key using AES/GCM in JAVA(在 JAVA 中使用 AES/GCM 檢測不正確的密鑰)
AES-256-CBC in Java(Java 中的 AES-256-CBC)
主站蜘蛛池模板: 做a视频| 中文在线一区 | 午夜午夜精品一区二区三区文 | 日本免费黄色 | 亚洲3级 | 国产资源视频 | 久久精品一级 | 欧美日韩久久精品 | 综合色久 | 亚洲欧美综合精品另类天天更新 | 日本精品一区二区三区视频 | 成人高清在线 | 亚洲 欧美 在线 一区 | 九九伊人sl水蜜桃色推荐 | 国产婷婷精品av在线 | 日韩在线一区二区 | 亚洲最新网址 | 国产精品99久久久久久动医院 | 久久久久国产精品一区二区 | 亚洲视频在线观看 | 国产一二三视频在线观看 | av天天澡天天爽天天av | 亚洲精品免费在线观看 | 玖玖国产 | 国产成人一区二区三区 | 91大神xh98xh系列全部 | 亚洲日韩中文字幕一区 | 国产综合久久久久久鬼色 | 国产成人高清 | 色婷婷精品久久二区二区蜜臂av | 一级黄色影片在线观看 | 亚洲综合久久久 | 亚洲影音 | 中文字幕人成乱码在线观看 | 欧美一级在线视频 | 国产精品一码二码三码在线 | 在线国产一区 | 日韩高清中文字幕 | 中文字幕在线一区二区三区 | 涩涩鲁亚洲精品一区二区 | 一区二区国产精品 |