国产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暗號化クラスの実裝を紹介し、暗號化と復號化を?qū)g裝するためのphpカスタムRSAクラスの手法を分析します。必要な人は參照してください

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

openssl を通じて実裝された署名、署名検証、非対稱暗號化と復號化は、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 進數(shù)文字列/バイナリ文字列ストリーム

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

*

* 注意: ブロック サイズは 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 文字列秘密鍵ファイル (署名時と復號化時に渡されます)

*/

パブリック関數(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 を返す;

}

/**

* 署名を確認します

*

* @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 を返す;

}

/**

* 復號化

*

* @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 のみをサポートします

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

*

* @param int フィルモード

* @param 文字列の暗號化/復號化

* @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 進數(shù)」:

$data = bin2hex($data);

休憩;

ケース「ビン」:

デフォルト:

}

$data を返す;

}

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

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

ケース「base64」:

$data =base64_decode($data);

休憩;

ケース「16 進數(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->復號化($x);

var_dump($x, $y);

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

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

ホット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

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

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPで現(xiàn)在のセッションIDを取得する方法は? PHPで現(xiàn)在のセッションIDを取得する方法は? Jul 13, 2025 am 03:02 AM

PHPで現(xiàn)在のセッションIDを取得する方法は、session_id()関數(shù)を使用することですが、session_start()を呼び出して正常に取得する必要があります。 1。Session_start()を呼び出してセッションを開始します。 2。Session_Id()を使用してセッションIDを読み取り、ABC123DEF456GHI789に似た文字列を出力します。 3.返品が空の場合は、Session_start()が欠落しているかどうか、ユーザーが初めてアクセスするか、セッションが破壊されるかを確認します。 4.セッションIDは、ロギング、セキュリティ検証、およびクロスレクエスト通信に使用できますが、セキュリティに注意する必要があります。セッションが正しく有効になり、IDが正常に取得できることを確認してください。

PHPストリングからサブストリングを取得します PHPストリングからサブストリングを取得します Jul 13, 2025 am 02:59 AM

PHP文字列からサブストリングを抽出するには、Substr()関數(shù)を使用できます。これはSyntax substr(String $ string、int $ start、?int $ length = null)であり、長さが指定されていない場合は、端まで傍受されます。中國語などのマルチバイト文字を処理する場合、MB_Substr()関數(shù)を使用して、文字化けコードを避ける必要があります。特定のセパレーターに従って文字列を傍受する必要がある場合は、exploit()を使用するか、strpos()とsubstr()を組み合わせて、ファイル名拡張子またはドメイン名を抽出するなどの実裝できます。

PHPコードの単體テストをどのように実行しますか? PHPコードの単體テストをどのように実行しますか? Jul 13, 2025 am 02:54 AM

unittestinginphpinvolvevidevifignivision like like fike fikionsionsormethodstocatchsearlyandensureliablerefactoring.1)setupphpunitviacomposer、createatestdirectory、and configureautoloadandphpunit.xml.2)

文字列をPHPの配列に分割する方法 文字列をPHPの配列に分割する方法 Jul 13, 2025 am 02:59 AM

PHPでは、最も一般的な方法は、exploit()関數(shù)を使用して文字列を配列に分割することです。この関數(shù)は、指定された區(qū)切り文字を介して文字列を複數(shù)の部分に分割し、配列を返します。構(gòu)文はエクスプロイト(セパレーター、文字列、制限)であり、セパレーターはセパレーターであり、文字列は元の文字列であり、制限はセグメントの最大數(shù)を制御するオプションのパラメーターです。たとえば、$ str = "Apple、Banana、Orange"; $ arr = Explode( "、"、$ str);結(jié)果は["apple"、 "banaです

JavaScriptデータ型:プリミティブ対參照 JavaScriptデータ型:プリミティブ対參照 Jul 13, 2025 am 02:43 AM

JavaScriptデータ型は、プリミティブタイプと參照タイプに分割されます。プリミティブタイプには、文字列、數(shù)字、ブール、ヌル、未定義、シンボルが含まれます。値は不変であり、コピーは値を割り當てるときにコピーされるため、互いに影響を與えません。オブジェクト、配列、関數(shù)などの參照タイプはメモリアドレスを保存し、同じオブジェクトを指す変數(shù)は互いに影響します。 TypeofとInstanceOFを使用してタイプを決定できますが、TypeOfNullの歴史的な問題に注意してください。これらの2種類の違いを理解することは、より安定した信頼性の高いコードを書くのに役立ちます。

c c Jul 15, 2025 am 01:30 AM

STD :: Chronoは、現(xiàn)在の時間の取得、実行時間の測定、操作時點と期間の測定、分析時間のフォーマットなど、時間の処理にCで使用されます。 1。STD:: Chrono :: System_Clock :: now()を使用して、現(xiàn)在の時間を取得します。 2。STD:: CHRONO :: STEADY_CLOCKを使用して実行時間を測定して単調(diào)さを確保し、DurateR_CASTを通じてミリ秒、秒、その他のユニットに変換します。 3。時點(Time_Point)と期間(期間)は相互運用可能ですが、ユニットの互換性と時計エポック(エポック)に注意を払う必要があります

PHPの別のページにセッション変數(shù)を渡す方法は? PHPの別のページにセッション変數(shù)を渡す方法は? Jul 13, 2025 am 02:39 AM

PHPでは、セッション変數(shù)を別のページに渡すために、キーはセッションを正しく開始し、同じ$ _Sessionキー名を使用することです。 1.各ページにセッション変數(shù)を使用する前に、session_start()と呼ばれ、スクリプトの前面に配置する必要があります。 2。$ _Session ['username'] = 'Johndoe'などのセッション変數(shù)を設定します。 3。別のページでsession_start()を呼び出した後、同じキー名を介して変數(shù)にアクセスします。 4.各ページでsession_start()が呼び出されることを確認し、事前にコンテンツの出力を避け、サーバーのセッションストレージパスが書き込み可能であることを確認してください。 5.SESを使用します

PHPは環(huán)境変數(shù)をどのように処理しますか? PHPは環(huán)境変數(shù)をどのように処理しますか? Jul 14, 2025 am 03:01 AM

toaccessenvironmentvariablesinphp、usegetenv()または$ _envsuperglobal.1.getenv( 'var_name')retievessaspecificvariable.2。$ _ en v ['var_name'] AccessESSESESSVARIABLESIFVARIABLES_ORDERINPHP.INIINCLUDES "E" .SETVARIABLESVIACLIWITHVAR = ValuePhpscript.php、inapach

See all articles