" />

GOOGLE Keyczar加密工具使用小贴士

系统 1605 0
<!-- Feedsky FEED发布代码开始 --> 欢迎点击此处订阅本Blog <!-- FEED自动发现标记开始 --> <link title="RSS 2.0" type="application/rss+xml" href="http://feed.feedsky.com/softwave" rel="alternate"> <!-- FEED自动发现标记结束 --> Blog 订阅

<!--Google 468*60横幅广告开始--><script type="text/javascript"><!-- google_ad_client = "pub-7343546549496470"; google_ad_width = 468; google_ad_height = 60; google_ad_format = "468x60_as"; google_ad_type = "image"; //2007-07-26: CSDN google_ad_channel = "6063905817"; google_color_border = "6699CC"; google_color_bg = "E6E6E6"; google_color_link = "FFFFFF"; google_color_text = "333333"; google_color_url = "AECCEB"; google_ui_features = "rc:6"; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script><!--Google 468*60横幅广告结束-->

keyczar 是這幾天 Google 放出來的 API ,其主要的功能為 加解密 與 數位簽署驗證. 它把一些實作的細節都隱藏起來,以及使用適當的預設值. 對於程式設計師的好處應該就是我們又可以把一些心力放在該注意的其它地方了!

查了一下 keyczar 是 BSD 授權,自己覺得以後有機會使用,所以花了一天的時間簡單寫了筆記跟嚐試去使用此 API . 目前實作仍卡關中! 囧rz

keyczar 我把玩至今的感覺(也許有錯! 請有興趣的人看官網比較準!), keyczar = console 介面 + JAVA API .

  • console 介面: 利用命令列來產生管理 keyset .
  • JAVA API : 程式設計師則用 API 來與 console 產生的檔案互動,做加密/解密/簽署/驗證 的功能.

目前我卡在 - 利用 console 產生出來的檔案格式似乎不標準,造成後續 API 無法正常運作,已經上討論區去問了! 希望不是我搞了個大笑話! Orz

以下為簡單概要筆記,建議不要全信,有問題看原本比較準! 之後問題解決也會將 測試程式碼片段 以及 解決方法 補上!

沒有 Keyzar 之前

  • 開發者使用不適當的方式來加解密.
  • 沒有辦法保護 Key Rotation.
  • 將 Key Roration 以 hard-code 的方式編寫.

實作版本

JAVA

  • Keyczar
    • Keyczar(KeyczarReader inReader)
      • KeyczarFileReader 從本地端讀取 KeySet .
      • 開發者可以實作自己的 KeyczarReader.
  • Keyczar(String inKeySetLocation)
  • Encrypter
    • 將資料加密.
    • 初始化需要傳入 crypting key set 的位置.
    • 初始化傳入的 keyset 一定要有一個 primary key.
    • 支援以UTF-8編碼的字串,位元組陣列 和 ByteBuffer .
  • Crypter
    • 將加密資料解密.
    • 初始化需要傳入 crypting key set 的位置.
    • 初始化傳入的 keyset 可以包含能解密的 key,namely symmetric key 或 private key.
    • 支援以WebSageBase64編碼的字串,位元組陣列 和 ByteBuffer .
  • Vertifier
    • 驗證數位簽署.
    • 初始化需要傳入任意 key set 的位置.
    • 支援以WebSageBase64編碼的字串,位元組陣列 和 ByteBuffer .
  • Signer
    • 替資料產生數位簽署.
    • 初始化傳入的 keyset 可以包含能簽署的 key,namely symmetric key 或 private key.
    • 初始化傳入的 keyset 一定要有一個 primary key.
    • 支援以UTF-8編碼的字串,位元組陣列 和 ByteBuffer .

Python

C++ coming soon

使用 KeyczrTool

建立 KeyczrTool

  • 使用 create 指令
    • location
    • purpose
      • crypt
      • sign
    • name
    • asymmetric
      • DSA
        • 只支援 sign
      • RSA
        • 支援 sign 跟 crypt

在 KeyczrTool 下建立 key

  • 使用 addkey 指令
    • location
      • primary
      • active(預設)
      • inactive
    • status
    • crypter
    • size

在 KeyczrTool 下產生 public key

  • 使用 pubkey 指令
    • location
    • destination

在 keyczrTool 下管理 key 的 status

  • promote
    • active key -> primary key
    • inactive key -> primary key
    • 一組 keyset 中只會有一個 primary key.
  • demote
    • primary key -> active key
    • active key -> inactive key
  • revoke
    • 只作用於 inactive key 上.

用 JAVA 實作遇的問題:

KeyczarTool 在哪裡?

keyczar05b-1.6.jar 解壓縮後在 org/keyczar 下.

怎麼執行 KeyczarTool ?

console 進入 keyczar 解壓目錄下.
執行 java org.keyczar.KeyczarTool (後面參數參考文件)

沒有 GsonBuilder .

至 http://code.google.com/p/google-gson/downloads/list 下載.
解壓縮後丟至 keyczar 相對應的位置下.

沒有 log4j .

至 http://logging.apache.org/log4j/1.2/download.html 下載.
解壓縮後丟至 keyczar 相對應的位置下.

資料來源

摘自:http://tangblack.blogspot.com/2008/08/keyczar.html

<!--新Google 468*60横幅广告开始--><script type="text/javascript"><!-- google_ad_client = "pub-7343546549496470"; /* 468x60, 创建于 08-8-6 */ google_ad_slot = "7368701459"; google_ad_width = 468; google_ad_height = 60; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script><!--新Google 468*60横幅广告结束-->

<!--新Google 468x15 横链接单元开始--><script type="text/javascript"><!-- google_ad_client = "pub-7343546549496470"; /* 468x15 横链接单元 */ google_ad_slot = "5785741422"; google_ad_width = 468; google_ad_height = 15; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script><!--新Google 468x15 横链接单元结束-->

<!-- Google Reader shared发布代码开始 --><script type="text/javascript" src="http://www.google.com/reader/ui/publisher.js"></script><script type="text/javascript" src="http://www.google.com/reader/public/javascript/user/00697638153916680411/state/com.google/broadcast?n=5&amp;callback=GRC_p(%7Bc%3A%22green%22%2Ct%3A%22%5Cu8FD9%5Cu4E9B%5Cu6587%5Cu7AE0%5Cu4E5F%5Cu503C%5Cu5F97%5Cu4E00%5Cu770B%22%2Cs%3A%22false%22%7D)%3Bnew%20GRC"></script><!-- Google Reader shared发布代码结束 -->

GOOGLE Keyczar加密工具使用小贴士


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论