国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
phpで実裝されたRSA暗號化クラスの例
ホームページ バックエンド開発 PHPチュートリアル PHP は RSA 暗號化クラスを?qū)g裝します。 example_PHP チュートリアル

PHP は RSA 暗號化クラスを?qū)g裝します。 example_PHP チュートリアル

Jul 13, 2016 am 10:00 AM
php rsa 主要 暗號化 事例分析 成し遂げる 記事 親切

phpで実裝されたRSA暗號化クラスの例

この記事では主にphpでのRSA暗號化クラスの実裝を紹介し、暗號化と復(fù)號化を?qū)g裝するためのphpカスタムRSAクラスの手法を分析します。必要な人は參照してください

この記事の例では、PHP での RSA 暗號化クラスの実裝について説明します。皆さんの參考に共有してください。具體的な分析は次のとおりです:

openssl を通じて実裝された署名、署名検証、非対稱暗號化と復(fù)號化は、x.509 証明書 (crt や pem など) ファイルで使用する必要があります。
諸事情によりこのクラスはあまり完成度が高くありませんが、様々なテストは大歓迎です!

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

/**

* RSA アルゴリズム クラス

* 署名と暗號文のエンコーディング: Base64 文字列/16 進(jìn)數(shù)文字列/バイナリ文字列ストリーム

*パディング方式:PKCS1Padding(暗號化?復(fù)號化)/NOPadding(復(fù)號化)

*

* 注意: ブロック サイズは RSA キーのサイズと同じです!

* 鍵の長さが 1024 ビットの場合、暗號化時のデータは 128 バイト未満でなければならず、PKCS1Padding 自體の情報の 11 バイトを加えて、平文は 117 バイト未満でなければなりません

*

* @著者: linvo

* @バージョン: 1.0.0

* @日付: 2013/1/23

*/

クラス RSA{

private $pubKey = null;

プライベート $priKey = null;

/**

* カスタムエラー処理

*/

プライベート関數(shù) _error($msg){

die('RSA エラー:' . $msg); //TODO

}

/**

* コンストラクター

*

* @param 文字列公開キー ファイル (署名の検証と暗號化中に渡される)

* @param 文字列秘密鍵ファイル (署名時と復(fù)號化時に渡されます)

*/

パブリック関數(shù) __construct($public_key_file = '', $private_key_file = ''){

if ($public_key_file){

$this->_getPublicKey($public_key_file);

}

if ($private_key_file){

$this->_getPrivateKey($private_key_file);

}

}

/**

* 署名を生成します

*

* @param文字列署名素材

* @param 文字列署名エンコーディング (base64/hex/bin)

* @署名値を返す

*/

パブリック関數(shù)sign($data, $code = 'base64'){

$ret = false;

if (openssl_sign($data, $ret, $this->priKey)){

$ret = $this->_encode($ret, $code);

}

$ret を返す;

}

/**

* 署名を確認(rèn)します

*

* @param文字列署名素材

* @param 文字列署名値

* @param 文字列署名エンコーディング (base64/hex/bin)

* @return bool

*/

パブリック関數(shù) verify($data, $sign, $code = 'base64'){

$ret = false;

$sign = $this->_decode($sign, $code);

if ($sign !== false) {

switch (openssl_verify($data, $sign, $this->pubKey)){

ケース 1: $ret = true;休憩;

ケース0:

ケース-1:

デフォルト: $ret = false;

}

}

$ret を返す;

}

/**

* 暗號化

*

* @param 文字列プレーンテキスト

* @param 文字列暗號文エンコーディング (base64/hex/bin)

* @param int 埋め込みメソッド (php にバグがあるようで、現(xiàn)在は OPENSSL_PKCS1_PADDING のみをサポートしています)

* @return string ciphertext

*/

パブリック関數(shù) encrypt($data, $code = 'base64', $padding = OPENSSL_PKCS1_PADDING){

$ret = false;

if (!$this->_checkPadding($padding, 'en')) $this->_error('パディングエラー');

if (openssl_public_encrypt($data, $result, $this->pubKey, $padding)){

$ret = $this->_encode($result, $code);

}

$ret を返す;

}

/**

* 復(fù)號化

*

* @param 文字列暗號文

* @param 文字列暗號文エンコーディング (base64/hex/bin)

* @param int パディングメソッド (OPENSSL_PKCS1_PADDING / OPENSSL_NO_PADDING)

* @param bool 平文を反転するかどうか (Microsoft CryptoAPI で生成された RSA 暗號文を渡すときに、ブロック內(nèi)のバイトを元に戻します)

* @return string プレーンテキスト

*/

パブリック関數(shù) decrypt($data, $code = 'base64', $padding = OPENSSL_PKCS1_PADDING, $rev = false){

$ret = false;

$data = $this->_decode($data, $code);

if (!$this->_checkPadding($padding, 'de')) $this->_error('パディングエラー');

if ($data !== false){

if (openssl_private_decrypt($data, $result, $this->priKey, $padding)){

$ret = $rev ? rtrim(strrev($result), " ") : ''.$result;

}

}

$ret を返す;

}

// 私のある方法

/**

* パディングタイプを検出します

* 暗號化は PKCS1_PADDING のみをサポートします

* 復(fù)號化は PKCS1_PADDING および NO_PADDING をサポートします

*

* @param int フィルモード

* @param 文字列の暗號化/復(fù)號化

* @return bool

*/

プライベート関數(shù) _checkPadding($padding, $type){

if ($type == 'en'){

スイッチ ($padding){

ケースOPENSSL_PKCS1_PADDING:

$ret = true;

休憩;

デフォルト:

$ret = false;

}

} 他 {

スイッチ ($padding){

ケースOPENSSL_PKCS1_PADDING:

ケースOPENSSL_NO_PADDING:

$ret = true;

休憩;

デフォルト:

$ret = false;

}

}

$ret を返す;

}

プライベート関數(shù) _encode($data, $code){

スイッチ (strto lower($code)){

ケース「base64」:

$data =base64_encode(''.$data);

休憩;

ケース「16 進(jìn)數(shù)」:

$data = bin2hex($data);

休憩;

ケース「ビン」:

デフォルト:

}

$data を返す;

}

プライベート関數(shù) _decode($data, $code){

スイッチ (strto lower($code)){

ケース「base64」:

$data =base64_decode($data);

休憩;

ケース「16 進(jìn)數(shù)」:

$data = $this->_hex2bin($data);

休憩;

ケース「ビン」:

デフォルト:

}

$data を返す;

}

プライベート関數(shù) _getPublicKey($file){

$key_content = $this->_readFile($file);

if ($key_content){

$this->pubKey = openssl_get_publickey($key_content);

}

}

プライベート関數(shù) _getPrivateKey($file){

$key_content = $this->_readFile($file);

if ($key_content){

$this->priKey = openssl_get_privatekey($key_content);

}

}

プライベート関數(shù)_readFile($file){

$ret = false;

if (!file_exists($file)){

$this->_error("ファイル {$file} が存在しません");

} 他 {

$ret = file_get_contents($file);

}

$ret を返す;

}

プライベート関數(shù) _hex2bin($hex = false){

$ret = $hex !== false && preg_match('/^[0-9a-fA-F]+$/i', $hex) ?パック("H*", $hex) : false;

$ret を返す;

}

}

測試デモ:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

header('Content-Type:text/html;Charset=utf-8;');

「rsa.php」をインクルードします;

エコー '

';

$a = isset($_GET['a']) ? $_GET['a'] : '測試123';

////////////////////////////////////

$pubfile = 'E:sslcertpwd.crt';

$prifile = 'E:sslcertpwd.pem';

$m = 新しい RSA($pubfile, $prifile);

$x = $m->sign($a);

$y = $m->verify($a, $x);

var_dump($x, $y);

$x = $m->暗號化($a);

$y = $m->復(fù)號化($x);

var_dump($x, $y);

この記事で説明した內(nèi)容が皆様の PHP プログラミング設(shè)計に役立つことを願っています。

www.bkjia.comtru??ehttp://www.bkjia.com/PHPjc/974522.html技術(shù)記事この記事では、主に PHP での RSA 暗號化クラスの実裝を紹介します。この例では、暗號化と復(fù)號化を?qū)g裝するための PHP のカスタム RSA クラスの手法を分析します。
このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

最新のPHP開発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? 最新のPHP開発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? Jun 23, 2025 am 12:56 AM

postaycurrentwithpdevellyments andbest practices、follow keynewsourceslikephp.netandphpweekly、egagewithcommunitiessonforums andconferences、keeptooling and gradivallyadoptnewfeatures、andreadorcontributeTopensourceprijeprijeprijeptrijeprijeprests.

PHPとは何ですか、そしてなぜそれがWeb開発に使用されるのですか? PHPとは何ですか、そしてなぜそれがWeb開発に使用されるのですか? Jun 23, 2025 am 12:55 AM

PhpBecamepopularforwebdevelopmentduetoitseaseaseaseaseasease、SeamlessintegrationWithhtml、widespreadhostingsupport、andalargeecosystemincludingframeworkelavelandcmsplatformslikewordspresspressinsinsionsisionsisionsisionsisionsionsionsisionsionsionsisionsisions

PHPタイムゾーンを設(shè)定する方法は? PHPタイムゾーンを設(shè)定する方法は? Jun 25, 2025 am 01:00 AM

tosettherighttimezoneInphp、usedate_default_timezone_set()functionthestthestofyourscriptwithavalididentifiersiersuchas'america/new_york'.1.usedate_default_timezone_set()beforeanydate/timefunctions.2.2.Altertentally、confuturethephp.inifilebyset.

PHP(serialize()、unserialize())のデータシリアル化とは何ですか? PHP(serialize()、unserialize())のデータシリアル化とは何ですか? Jun 22, 2025 am 01:03 AM

thephpfunctionSerialize()andunserialize()areusedtoconvertcomplexdatastructostorestorestorustorasandabackagain.1.serialize()c onvertsdatalikecarraysorobjectsraystringcontainingtainingtainingepeandStructureinformation.2。

HTMLファイルにPHPコードを埋め込むにはどうすればよいですか? HTMLファイルにPHPコードを埋め込むにはどうすればよいですか? Jun 22, 2025 am 01:00 AM

PHPコードをHTMLファイルに埋め込むことができますが、ファイルに.phpの拡張機(jī)能があることを確認(rèn)して、サーバーが正しく解析できるようにします。標(biāo)準(zhǔn)タグを使用してPHPコードをラップし、HTMLのどこにでも動的コンテンツを挿入します。さらに、同じファイルでPHPとHTMLを複數(shù)回切り替えて、條件付きレンダリングなどの動的関數(shù)を?qū)g現(xiàn)できます。短いラベル、引用マークエラー、または省略されたエンドラベルによって引き起こされる問題を回避するために、サーバーの構(gòu)成と構(gòu)文の正確性に注意してください。

クリーンで保守可能なPHPコードを書くためのベストプラクティスは何ですか? クリーンで保守可能なPHPコードを書くためのベストプラクティスは何ですか? Jun 24, 2025 am 12:53 AM

清潔で維持しやすいPHPコードを書くための鍵は、標(biāo)準(zhǔn)、合理的な構(gòu)造に従って、コメント、テスト能力を適切に利用する明確な命名にあります。 1。$ userDataやcalculatetotalprice()などの明確な変數(shù)、関數(shù)、クラス名を使用します。 2。PSR-12標(biāo)準(zhǔn)統(tǒng)一コードスタイルに従ってください。 3.責(zé)任に従ってコード構(gòu)造を分割し、MVCまたはLaravelスタイルのカタログを使用して整理します。 4.麺スタイルのコードを避け、単一の責(zé)任でロジックを小さな関數(shù)に分割します。 5.キーポイントにコメントを追加し、インターフェイスドキュメントを書き込み、パラメーター、返品値、例外を明確にします。 6.テスト可能性を改善し、依存関係を採用し、グローバルな狀態(tài)と靜的な方法を減らします。これらのプラクティスは、コードの品質(zhì)、コラボレーション効率、メンテナンス後の容易さを改善します。

Bian Binance Exchange公式ウェブサイトログインポータル Bian Binance Exchange公式ウェブサイトログインポータル Jun 24, 2025 pm 06:15 PM

Binanceは、優(yōu)れたセキュリティ、豊富な取引品種、スムーズなユーザーエクスペリエンスを備えた世界をリードする暗號通貨取引プラットフォームです。資産のセキュリティを確保するために多層セキュリティアーキテクチャを採用し、スポット、レバレッジ、契約などのさまざまなトランザクションタイプを提供し、効率的な取引を確保するための高い流動性を備えています。ログイン手順には次のものが含まれます。1。公式Webサイトにアクセスして、URLを確認(rèn)します。 2。右上隅の[ログイン]ボタンをクリックします。 3.電子メール/攜帯電話番號とパスワードを入力します。 4. 2要素検証、SMS、または電子メール検証コードなどの完全なセキュリティ検証。 5.クリックしてログインして操作を完了します。また、このプラットフォームは、Binance Reath、NFT Market、Academy、その他の特別な機(jī)能を提供し、フィッシングWebサイトに注意し、2FAを有効にし、取引リスクを理解し、詐欺に注意し、そのことを確実にすることをユーザーに思い出させます。

See all articles