php xxtea加密,php - esp32和php XXTEA字符串加密 - SO中文参考 - www.soinside.com
輸入具有不同的數(shù)據(jù)類(lèi)型可能會(huì)導(dǎo)致此問(wèn)題,因?yàn)楫?dāng)前沒(méi)有任何類(lèi)型或范圍檢查的XXTEA實(shí)現(xiàn)。
或者它可能是由于所涉及的兩臺(tái)計(jì)算機(jī)的不同端序行為,因?yàn)槎M(jìn)制文件通常存儲(chǔ)為由字節(jié)構(gòu)造的字?jǐn)?shù)組。
或者可能是由于缺少正式加密特定字符串和密鑰的官方或標(biāo)準(zhǔn)參考示例。在沒(méi)有參考示例(使用二進(jìn)制加密結(jié)果的十六進(jìn)制或base64轉(zhuǎn)換)的情況下,無(wú)法判斷加密的實(shí)現(xiàn)是否正確,即使其結(jié)果使用相應(yīng)的解密實(shí)現(xiàn)正確解密。
添加:
我想我在已發(fā)布的XXTEA代碼中發(fā)現(xiàn)了一個(gè)兼容性問(wèn)題。在這里討論它可能值得花些時(shí)間。
具體地說(shuō),問(wèn)題在于不同的實(shí)現(xiàn)為加密相同的明文和密鑰創(chuàng)建了不同的結(jié)果。
討論:
這個(gè)問(wèn)題是由于將明文的長(zhǎng)度作為long數(shù)組的最后一個(gè)元素而增加的。雖然這解決了長(zhǎng)度不是4的倍數(shù)的明文問(wèn)題,但它生成的加密值與JavaScript實(shí)現(xiàn)生成的加密值不同。
如果你插入“$ w = false;”在long2str和str2long函數(shù)的開(kāi)頭,PHP實(shí)現(xiàn)的加密值與JavaScript實(shí)現(xiàn)相同,但解密后的值最后有垃圾。
以下是此更改的一些測(cè)試用例結(jié)果:
PHP:
text: >This is an example. !@#$%^&*(){}[]:;<
Base64: PlRoaXMgaXMgYW4gZXhhbXBsZS4gIUAjJCVeJiooKXt9W106Ozw=
key: 8GmZWww5T97jb39W
encrypt: sIubYrII6jVXvMikX1oQivyOXC07bV1CoC81ZswcCV4tkg5CnrTtqQ==
decrypt: >This is an example. !@#$%^&*(){}[]:;
注意:“解密”行末尾有兩個(gè)UTF-8問(wèn)號(hào)字符。
JavaScript的:
text: >This is an example. !@#$%^&*(){}[]:;<
Base64: PlRoaXMgaXMgYW4gZXhhbXBsZS4gIUAjJCVeJiooKXt9W106Ozw=
key: 8GmZWww5T97jb39W
encrypt: sIubYrII6jVXvMikX1oQivyOXC07bV1CoC81ZswcCV4tkg5CnrTtqQ==
decrypt: >This is an example. !@#$%^&*(){}[]:;<
JavaScript實(shí)現(xiàn)中沒(méi)有垃圾的原因即使它沒(méi)有保存明文的長(zhǎng)度,也會(huì)在注釋中給出:“注意運(yùn)行字符串的結(jié)尾會(huì)生成空值,因?yàn)榘次贿\(yùn)算符將NaN視為0”。換句話說(shuō),生成的字符串用從未見(jiàn)過(guò)的NUL填充,即使JavaScript(如PHP)可以在字符串中包含NUL,因?yàn)樗謩e存儲(chǔ)長(zhǎng)度。
我對(duì)哪種方法最好是沒(méi)有意見(jiàn),但應(yīng)該為所有實(shí)現(xiàn)選擇一種方法。
應(yīng)該有加密結(jié)果標(biāo)準(zhǔn)的原因(無(wú)論二進(jìn)制文件是轉(zhuǎn)換為十六進(jìn)制還是轉(zhuǎn)換為base64以便安全傳輸),人們可能希望使用PHP進(jìn)行編碼,而使用JavaScript進(jìn)行解碼,具體取決于在兩個(gè)地方使用哪種語(yǔ)言是很自然的。畢竟,加密最常用于在兩個(gè)位置之間進(jìn)行通信,并且目標(biāo)位置使用的語(yǔ)言甚至可能都不知道。
總結(jié)
以上是生活随笔為你收集整理的php xxtea加密,php - esp32和php XXTEA字符串加密 - SO中文参考 - www.soinside.com的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linkbox php,win10 do
- 下一篇: java swing列表数据加监听,【J