ホームページ > バックエンド開発 > PHPチュートリアル > NodeJS md5 で暗号化された中国語と PHP の間で結果が一貫しない場合の解決策

NodeJS md5 で暗号化された中国語と PHP の間で結果が一貫しない場合の解決策

WBOY
リリース: 2016-07-29 09:01:30
オリジナル
1441 人が閲覧しました

プロジェクトのニーズにより、インターフェース呼び出しを行うには、node.JS と php が必要です。中国語の md5 暗号化を使用した node.JS と、中国語の md5 暗号化を使用した php の結果が異なることがわかりました。

PHP

<code><span><span><?php</span><span>$str</span> = <span>'程序员'</span>;
<span>echo</span><span>$str</span>.<span>' md5:'</span>.md5(<span>$str</span>);
<span>?></span></span></code>
ログイン後にコピー

出力:
プログラマー md5:72d9adf4944f23e5efde37f6364c126f

node.JS

<code><span>var</span> crypto = <span>require</span>(<span>'crypto'</span>);

<span>var</span> md5 = <span><span>function</span><span>(str)</span>{</span><span>var</span> crypto_md5 = crypto.createHash(<span>'md5'</span>);
    <span>return</span> crypto_md5.digest(<span>'hex'</span>);
}

<span>var</span> str = <span>'程序员'</span>;
<span>var</span> result = str + <span>' md5:'</span> + md5(str);

console.log(result);</code>
ログイン後にコピー

出力:
プログラマー md5:d41d8cd98f00b204e9800998ecf8427e


情報を確認したところ、node.JS にコーディングを追加することで問題を解決できることがわかりました。

解決策は次のとおりです:

<code><span>var</span> crypto = <span>require</span>(<span>'crypto'</span>);

<span>var</span> md5 = <span><span>function</span><span>(str)</span>{</span><span>var</span> crypto_md5 = crypto.createHash(<span>'md5'</span>);
    crypto_md5.update(str, <span>'utf8'</span>); <span>// 加入编码</span><span>return</span> crypto_md5.digest(<span>'hex'</span>);
}

<span>var</span> str = <span>'程序员'</span>;
<span>var</span> result = str + <span>' md5:'</span> + md5(str);

console.log(result);</code>
ログイン後にコピー

出力:
プログラマ md5:72d9adf4944f23e5efde37f6364c126f

').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

上記は、nodeJS md5 で暗号化された中国語と PHP の結果の間の不一致に対する解決策を、関連する内容も含めて紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート