在騰訊微博API OAuth認證介紹中,我們可以看到關于請求簽名的介紹( http://open.t.qq.com/resource.php?i=1,2#tag0 ):所有TOKEN請求和受保護的資源請求必須被簽名,微博開放平臺會根據(jù)簽名來判斷請求的合法性。簽名算法使用Signature Base String和密鑰(Secret)生成簽名,參數(shù)oauth_signature用于指定簽名。這幾句話對oauth_signature產(chǎn)生過程介紹的比較簡單,通過閱讀其它的資料,我們可知在oauth_signature生成值的過程中我們需要進行URL編碼,使用HMAC-SHA1加密算法進行簽名,最后進行Base64編碼:
上圖顯示我們需要URL編碼方法。有過Java網(wǎng)絡編程或者Web開發(fā)的朋友應該對中文亂碼問題不會很陌生,有一種解決方法是對中文進行編碼,也就是調用URLEncoder.encode(s, enc),在這里我們是否也可以使用這個方法呢?通過閱讀Oauth提供的幫助文檔( http://tools.ietf.org/html/draft-hammer-oauth-10#section-3.6 )我們可以得知OAuth中需要的Encode()方法與URLEncoder.encode(s, enc)存在差異:OAuth中需要把“+”和“*”這兩個字符也使用“%XX”表示,而“~”不需要使用“%XX”表示,修改后的Encode()方法如下:
Encode()方法編寫完畢后,我們需要編寫“HmacSHA1”簽名算法,由于我對算法沒有任何知識,所以不知道怎么寫這個算法,這個使用我們就需要借助百度或者谷歌進行搜索,當然我們還可以參考OAuth官網(wǎng)給我們提供的參開代碼,尋找過程比較繁瑣,這個在視頻中給大家演示。HmacSHA1簽名算法如下:
當我們的參數(shù)進行HmacSHA1簽名后,最后我們還需進行Base64的編碼。這個我也不知道怎么寫,只能百度,代碼如下:
至此在oauth_signature值生成過程中需要的幾個方法我們已經(jīng)編寫完畢。下面我們在編寫一個輔助方法:
1.oauth_timestamp:時間戳, 其值是距1970 00:00:00 GMT的秒數(shù),必須是大于0的整數(shù)。
這個我們可以直接使用JDK給我們提供的類方法即可:
2.oauth_nonce:單次值,隨機生成的32位字符串,防止重放攻擊(每次請求必須不同)。
需要產(chǎn)生32位字符串,這個過程也比較簡單,我們Random幾次。對MD5加密了解的朋友應該知道MD5加密后是32位的,因此我們可以嘗試使用MD5進行加密,最后代碼如下:
這個方法有個參數(shù)判斷是否為32位,為什么要這么寫等我們調用這個方法的時候在給大家解釋。
本節(jié)課程下載地址: http://u.115.com/file/clizvrhw
本節(jié)文檔下載地址: http://download.csdn.net/source/3405209 <!-- .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; } -->
<!-- .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; } --><!-- .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; } --><!-- .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; } -->
更多文章、技術交流、商務合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
