UNPKG

api-console-assets

Version:

This repo only exists to publish api console components to npm

295 lines 253 kB
<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"> <style> .KEYW {color: #933;} .COMM {color: #bbb; font-style: italic;} .NUMB {color: #393;} .STRN {color: #393;} .REGX {color: #339;} .line {border-right: 1px dotted #666; color: #666; font-style: normal;} </style></head><body><pre><span class='line'> 1</span> <span class="COMM">/* crypto-1.2.1.js (c) 2013-2017 Kenji Urushima | kjur.github.io/jsrsasign/license <span class='line'> 2</span> */</span><span class="WHIT"> <span class='line'> 3</span> </span><span class="COMM">/* <span class='line'> 4</span> * crypto.js - Cryptographic Algorithm Provider class <span class='line'> 5</span> * <span class='line'> 6</span> * Copyright (c) 2013-2017 Kenji Urushima (kenji.urushima@gmail.com) <span class='line'> 7</span> * <span class='line'> 8</span> * This software is licensed under the terms of the MIT License. <span class='line'> 9</span> * https://kjur.github.io/jsrsasign/license <span class='line'> 10</span> * <span class='line'> 11</span> * The above copyright and license notice shall be <span class='line'> 12</span> * included in all copies or substantial portions of the Software. <span class='line'> 13</span> */</span><span class="WHIT"> <span class='line'> 14</span> <span class='line'> 15</span> </span><span class="COMM">/** <span class='line'> 16</span> * @fileOverview <span class='line'> 17</span> * @name crypto-1.1.js <span class='line'> 18</span> * @author Kenji Urushima kenji.urushima@gmail.com <span class='line'> 19</span> * @version 1.2.1 (2017-Sep-15) <span class='line'> 20</span> * @since jsrsasign 2.2 <span class='line'> 21</span> * @license &lt;a href="https://kjur.github.io/jsrsasign/license/">MIT License&lt;/a> <span class='line'> 22</span> */</span><span class="WHIT"> <span class='line'> 23</span> <span class='line'> 24</span> </span><span class="COMM">/** <span class='line'> 25</span> * kjur's class library name space <span class='line'> 26</span> * @name KJUR <span class='line'> 27</span> * @namespace kjur's class library name space <span class='line'> 28</span> */</span><span class="WHIT"> <span class='line'> 29</span> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="KEYW">typeof</span><span class="WHIT"> </span><span class="NAME">KJUR</span><span class="WHIT"> </span><span class="PUNC">==</span><span class="WHIT"> </span><span class="STRN">"undefined"</span><span class="WHIT"> </span><span class="PUNC">||</span><span class="WHIT"> </span><span class="PUNC">!</span><span class="NAME">KJUR</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="NAME">KJUR</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'> 30</span> </span><span class="COMM">/** <span class='line'> 31</span> * kjur's cryptographic algorithm provider library name space <span class='line'> 32</span> * &lt;p> <span class='line'> 33</span> * This namespace privides following crytpgrahic classes. <span class='line'> 34</span> * &lt;ul> <span class='line'> 35</span> * &lt;li>{@link KJUR.crypto.MessageDigest} - Java JCE(cryptograhic extension) style MessageDigest class&lt;/li> <span class='line'> 36</span> * &lt;li>{@link KJUR.crypto.Signature} - Java JCE(cryptograhic extension) style Signature class&lt;/li> <span class='line'> 37</span> * &lt;li>{@link KJUR.crypto.Cipher} - class for encrypting and decrypting data&lt;/li> <span class='line'> 38</span> * &lt;li>{@link KJUR.crypto.Util} - cryptographic utility functions and properties&lt;/li> <span class='line'> 39</span> * &lt;/ul> <span class='line'> 40</span> * NOTE: Please ignore method summary and document of this namespace. This caused by a bug of jsdoc2. <span class='line'> 41</span> * &lt;/p> <span class='line'> 42</span> * @name KJUR.crypto <span class='line'> 43</span> * @namespace <span class='line'> 44</span> */</span><span class="WHIT"> <span class='line'> 45</span> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="KEYW">typeof</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto</span><span class="WHIT"> </span><span class="PUNC">==</span><span class="WHIT"> </span><span class="STRN">"undefined"</span><span class="WHIT"> </span><span class="PUNC">||</span><span class="WHIT"> </span><span class="PUNC">!</span><span class="NAME">KJUR.crypto</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'> 46</span> <span class='line'> 47</span> </span><span class="COMM">/** <span class='line'> 48</span> * static object for cryptographic function utilities <span class='line'> 49</span> * @name KJUR.crypto.Util <span class='line'> 50</span> * @class static object for cryptographic function utilities <span class='line'> 51</span> * @property {Array} DIGESTINFOHEAD PKCS#1 DigestInfo heading hexadecimal bytes for each hash algorithms <span class='line'> 52</span> * @property {Array} DEFAULTPROVIDER associative array of default provider name for each hash and signature algorithms <span class='line'> 53</span> * @description <span class='line'> 54</span> */</span><span class="WHIT"> <span class='line'> 55</span> </span><span class="NAME">KJUR.crypto.Util</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'> 56</span> </span><span class="WHIT"> </span><span class="NAME">this.DIGESTINFOHEAD</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'> 57</span> </span><span class="WHIT"> </span><span class="STRN">'sha1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3021300906052b0e03021a05000414"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 58</span> </span><span class="WHIT"> </span><span class="STRN">'sha224'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"302d300d06096086480165030402040500041c"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 59</span> </span><span class="WHIT"> </span><span class="STRN">'sha256'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3031300d060960864801650304020105000420"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 60</span> </span><span class="WHIT"> </span><span class="STRN">'sha384'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3041300d060960864801650304020205000430"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 61</span> </span><span class="WHIT"> </span><span class="STRN">'sha512'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3051300d060960864801650304020305000440"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 62</span> </span><span class="WHIT"> </span><span class="STRN">'md2'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3020300c06082a864886f70d020205000410"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 63</span> </span><span class="WHIT"> </span><span class="STRN">'md5'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3020300c06082a864886f70d020505000410"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 64</span> </span><span class="WHIT"> </span><span class="STRN">'ripemd160'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">"3021300906052b2403020105000414"</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 65</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'> 66</span> <span class='line'> 67</span> </span><span class="WHIT"> </span><span class="COMM">/* <span class='line'> 68</span> * @since crypto 1.1.1 <span class='line'> 69</span> */</span><span class="WHIT"> <span class='line'> 70</span> </span><span class="WHIT"> </span><span class="NAME">this.DEFAULTPROVIDER</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'> 71</span> </span><span class="WHIT"> </span><span class="STRN">'md5'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 72</span> </span><span class="WHIT"> </span><span class="STRN">'sha1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 73</span> </span><span class="WHIT"> </span><span class="STRN">'sha224'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 74</span> </span><span class="WHIT"> </span><span class="STRN">'sha256'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 75</span> </span><span class="WHIT"> </span><span class="STRN">'sha384'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 76</span> </span><span class="WHIT"> </span><span class="STRN">'sha512'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 77</span> </span><span class="WHIT"> </span><span class="STRN">'ripemd160'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 78</span> </span><span class="WHIT"> </span><span class="STRN">'hmacmd5'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 79</span> </span><span class="WHIT"> </span><span class="STRN">'hmacsha1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 80</span> </span><span class="WHIT"> </span><span class="STRN">'hmacsha224'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 81</span> </span><span class="WHIT"> </span><span class="STRN">'hmacsha256'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 82</span> </span><span class="WHIT"> </span><span class="STRN">'hmacsha384'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 83</span> </span><span class="WHIT"> </span><span class="STRN">'hmacsha512'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 84</span> </span><span class="WHIT"> </span><span class="STRN">'hmacripemd160'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 85</span> <span class='line'> 86</span> </span><span class="WHIT"> </span><span class="STRN">'MD5withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 87</span> </span><span class="WHIT"> </span><span class="STRN">'SHA1withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 88</span> </span><span class="WHIT"> </span><span class="STRN">'SHA224withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 89</span> </span><span class="WHIT"> </span><span class="STRN">'SHA256withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 90</span> </span><span class="WHIT"> </span><span class="STRN">'SHA384withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 91</span> </span><span class="WHIT"> </span><span class="STRN">'SHA512withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 92</span> </span><span class="WHIT"> </span><span class="STRN">'RIPEMD160withRSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 93</span> <span class='line'> 94</span> </span><span class="WHIT"> </span><span class="STRN">'MD5withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 95</span> </span><span class="WHIT"> </span><span class="STRN">'SHA1withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 96</span> </span><span class="WHIT"> </span><span class="STRN">'SHA224withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 97</span> </span><span class="WHIT"> </span><span class="STRN">'SHA256withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 98</span> </span><span class="WHIT"> </span><span class="STRN">'SHA384withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'> 99</span> </span><span class="WHIT"> </span><span class="STRN">'SHA512withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>100</span> </span><span class="WHIT"> </span><span class="STRN">'RIPEMD160withECDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>101</span> <span class='line'>102</span> </span><span class="WHIT"> </span><span class="STRN">'SHA1withDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>103</span> </span><span class="WHIT"> </span><span class="STRN">'SHA224withDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>104</span> </span><span class="WHIT"> </span><span class="STRN">'SHA256withDSA'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>105</span> <span class='line'>106</span> </span><span class="WHIT"> </span><span class="STRN">'MD5withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>107</span> </span><span class="WHIT"> </span><span class="STRN">'SHA1withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>108</span> </span><span class="WHIT"> </span><span class="STRN">'SHA224withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>109</span> </span><span class="WHIT"> </span><span class="STRN">'SHA256withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>110</span> </span><span class="WHIT"> </span><span class="STRN">'SHA384withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>111</span> </span><span class="WHIT"> </span><span class="STRN">'SHA512withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>112</span> </span><span class="WHIT"> </span><span class="STRN">'RIPEMD160withRSAandMGF1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="STRN">'cryptojs/jsrsa'</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>113</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>114</span> <span class='line'>115</span> </span><span class="WHIT"> </span><span class="COMM">/* <span class='line'>116</span> * @since crypto 1.1.2 <span class='line'>117</span> */</span><span class="WHIT"> <span class='line'>118</span> </span><span class="WHIT"> </span><span class="NAME">this.CRYPTOJSMESSAGEDIGESTNAME</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>119</span> </span><span class="WHIT"> </span><span class="STRN">'md5'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.MD5</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>120</span> </span><span class="WHIT"> </span><span class="STRN">'sha1'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.SHA1</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>121</span> </span><span class="WHIT"> </span><span class="STRN">'sha224'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.SHA224</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>122</span> </span><span class="WHIT"> </span><span class="STRN">'sha256'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.SHA256</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>123</span> </span><span class="WHIT"> </span><span class="STRN">'sha384'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.SHA384</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>124</span> </span><span class="WHIT"> </span><span class="STRN">'sha512'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.SHA512</span><span class="PUNC">,</span><span class="WHIT"> <span class='line'>125</span> </span><span class="WHIT"> </span><span class="STRN">'ripemd160'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">CryptoJS.algo.RIPEMD160</span><span class="WHIT"> <span class='line'>126</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>127</span> <span class='line'>128</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>129</span> * get hexadecimal DigestInfo <span class='line'>130</span> * @name getDigestInfoHex <span class='line'>131</span> * @memberOf KJUR.crypto.Util <span class='line'>132</span> * @function <span class='line'>133</span> * @param {String} hHash hexadecimal hash value <span class='line'>134</span> * @param {String} alg hash algorithm name (ex. 'sha1') <span class='line'>135</span> * @return {String} hexadecimal string DigestInfo ASN.1 structure <span class='line'>136</span> */</span><span class="WHIT"> <span class='line'>137</span> </span><span class="WHIT"> </span><span class="NAME">this.getDigestInfoHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">hHash</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>138</span> </span><span class="WHIT"> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="KEYW">typeof</span><span class="WHIT"> </span><span class="NAME">this.DIGESTINFOHEAD</span><span class="PUNC">[</span><span class="NAME">alg</span><span class="PUNC">]</span><span class="WHIT"> </span><span class="PUNC">==</span><span class="WHIT"> </span><span class="STRN">"undefined"</span><span class="PUNC">)</span><span class="WHIT"> <span class='line'>139</span> </span><span class="WHIT"> </span><span class="KEYW">throw</span><span class="WHIT"> </span><span class="STRN">"alg not supported in Util.DIGESTINFOHEAD: "</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>140</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">this.DIGESTINFOHEAD</span><span class="PUNC">[</span><span class="NAME">alg</span><span class="PUNC">]</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">hHash</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>141</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>142</span> <span class='line'>143</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>144</span> * get PKCS#1 padded hexadecimal DigestInfo <span class='line'>145</span> * @name getPaddedDigestInfoHex <span class='line'>146</span> * @memberOf KJUR.crypto.Util <span class='line'>147</span> * @function <span class='line'>148</span> * @param {String} hHash hexadecimal hash value of message to be signed <span class='line'>149</span> * @param {String} alg hash algorithm name (ex. 'sha1') <span class='line'>150</span> * @param {Integer} keySize key bit length (ex. 1024) <span class='line'>151</span> * @return {String} hexadecimal string of PKCS#1 padded DigestInfo <span class='line'>152</span> */</span><span class="WHIT"> <span class='line'>153</span> </span><span class="WHIT"> </span><span class="NAME">this.getPaddedDigestInfoHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">hHash</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">keySize</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>154</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">hDigestInfo</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">this.getDigestInfoHex</span><span class="PUNC">(</span><span class="NAME">hHash</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>155</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">pmStrLen</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">keySize</span><span class="WHIT"> </span><span class="PUNC">/</span><span class="WHIT"> </span><span class="NUMB">4</span><span class="PUNC">;</span><span class="WHIT"> </span><span class="COMM">// minimum PM length</span><span class="WHIT"> <span class='line'>156</span> <span class='line'>157</span> </span><span class="WHIT"> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="NAME">hDigestInfo.length</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NUMB">22</span><span class="WHIT"> </span><span class="PUNC">></span><span class="WHIT"> </span><span class="NAME">pmStrLen</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="COMM">// len(0001+ff(*8)+00+hDigestInfo)=22</span><span class="WHIT"> <span class='line'>158</span> </span><span class="WHIT"> </span><span class="KEYW">throw</span><span class="WHIT"> </span><span class="STRN">"key is too short for SigAlg: keylen="</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">keySize</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="STRN">","</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>159</span> <span class='line'>160</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">hHead</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="STRN">"0001"</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>161</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">hTail</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="STRN">"00"</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">hDigestInfo</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>162</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">hMid</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="STRN">""</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>163</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">fLen</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">pmStrLen</span><span class="WHIT"> </span><span class="PUNC">-</span><span class="WHIT"> </span><span class="NAME">hHead.length</span><span class="WHIT"> </span><span class="PUNC">-</span><span class="WHIT"> </span><span class="NAME">hTail.length</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>164</span> </span><span class="WHIT"> </span><span class="KEYW">for</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">i</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">;</span><span class="WHIT"> </span><span class="NAME">i</span><span class="WHIT"> </span><span class="PUNC">&lt;</span><span class="WHIT"> </span><span class="NAME">fLen</span><span class="PUNC">;</span><span class="WHIT"> </span><span class="NAME">i</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">2</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>165</span> </span><span class="WHIT"> </span><span class="NAME">hMid</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="PUNC">=</span><span class="WHIT"> </span><span class="STRN">"ff"</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>166</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="WHIT"> <span class='line'>167</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">hPaddedMessage</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">hHead</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">hMid</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">hTail</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>168</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">hPaddedMessage</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>169</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>170</span> <span class='line'>171</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>172</span> * get hexadecimal hash of string with specified algorithm <span class='line'>173</span> * @name hashString <span class='line'>174</span> * @memberOf KJUR.crypto.Util <span class='line'>175</span> * @function <span class='line'>176</span> * @param {String} s input string to be hashed <span class='line'>177</span> * @param {String} alg hash algorithm name <span class='line'>178</span> * @return {String} hexadecimal string of hash value <span class='line'>179</span> * @since 1.1.1 <span class='line'>180</span> */</span><span class="WHIT"> <span class='line'>181</span> </span><span class="WHIT"> </span><span class="NAME">this.hashString</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>182</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>183</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>184</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>185</span> <span class='line'>186</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>187</span> * get hexadecimal hash of hexadecimal string with specified algorithm <span class='line'>188</span> * @name hashHex <span class='line'>189</span> * @memberOf KJUR.crypto.Util <span class='line'>190</span> * @function <span class='line'>191</span> * @param {String} sHex input hexadecimal string to be hashed <span class='line'>192</span> * @param {String} alg hash algorithm name <span class='line'>193</span> * @return {String} hexadecimal string of hash value <span class='line'>194</span> * @since 1.1.1 <span class='line'>195</span> */</span><span class="WHIT"> <span class='line'>196</span> </span><span class="WHIT"> </span><span class="NAME">this.hashHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">sHex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>197</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="WHIT"> </span><span class="NAME">alg</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>198</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestHex</span><span class="PUNC">(</span><span class="NAME">sHex</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>199</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>200</span> <span class='line'>201</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>202</span> * get hexadecimal SHA1 hash of string <span class='line'>203</span> * @name sha1 <span class='line'>204</span> * @memberOf KJUR.crypto.Util <span class='line'>205</span> * @function <span class='line'>206</span> * @param {String} s input string to be hashed <span class='line'>207</span> * @return {String} hexadecimal string of hash value <span class='line'>208</span> * @since 1.0.3 <span class='line'>209</span> */</span><span class="WHIT"> <span class='line'>210</span> </span><span class="WHIT"> </span><span class="NAME">this.sha1</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>211</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'sha1'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>212</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>213</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>214</span> <span class='line'>215</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>216</span> * get hexadecimal SHA256 hash of string <span class='line'>217</span> * @name sha256 <span class='line'>218</span> * @memberOf KJUR.crypto.Util <span class='line'>219</span> * @function <span class='line'>220</span> * @param {String} s input string to be hashed <span class='line'>221</span> * @return {String} hexadecimal string of hash value <span class='line'>222</span> * @since 1.0.3 <span class='line'>223</span> */</span><span class="WHIT"> <span class='line'>224</span> </span><span class="WHIT"> </span><span class="NAME">this.sha256</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>225</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'sha256'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>226</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>227</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>228</span> <span class='line'>229</span> </span><span class="WHIT"> </span><span class="NAME">this.sha256Hex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>230</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'sha256'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>231</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestHex</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>232</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>233</span> <span class='line'>234</span> </span><span class="WHIT"> </span><span class="COMM">/** <span class='line'>235</span> * get hexadecimal SHA512 hash of string <span class='line'>236</span> * @name sha512 <span class='line'>237</span> * @memberOf KJUR.crypto.Util <span class='line'>238</span> * @function <span class='line'>239</span> * @param {String} s input string to be hashed <span class='line'>240</span> * @return {String} hexadecimal string of hash value <span class='line'>241</span> * @since 1.0.3 <span class='line'>242</span> */</span><span class="WHIT"> <span class='line'>243</span> </span><span class="WHIT"> </span><span class="NAME">this.sha512</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>244</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'sha512'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>245</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>246</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>247</span> <span class='line'>248</span> </span><span class="WHIT"> </span><span class="NAME">this.sha512Hex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>249</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'sha512'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>250</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestHex</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>251</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>252</span> <span class='line'>253</span> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>254</span> <span class='line'>255</span> </span><span class="COMM">/** <span class='line'>256</span> * get hexadecimal MD5 hash of string <span class='line'>257</span> * @name md5 <span class='line'>258</span> * @memberOf KJUR.crypto.Util <span class='line'>259</span> * @function <span class='line'>260</span> * @param {String} s input string to be hashed <span class='line'>261</span> * @return {String} hexadecimal string of hash value <span class='line'>262</span> * @since 1.0.3 <span class='line'>263</span> * @example <span class='line'>264</span> * Util.md5('aaa') &rarr; 47bce5c74f589f4867dbd57e9ca9f808 <span class='line'>265</span> */</span><span class="WHIT"> <span class='line'>266</span> </span><span class="NAME">KJUR.crypto.Util.md5</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>267</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'md5'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>268</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>269</span> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>270</span> <span class='line'>271</span> </span><span class="COMM">/** <span class='line'>272</span> * get hexadecimal RIPEMD160 hash of string <span class='line'>273</span> * @name ripemd160 <span class='line'>274</span> * @memberOf KJUR.crypto.Util <span class='line'>275</span> * @function <span class='line'>276</span> * @param {String} s input string to be hashed <span class='line'>277</span> * @return {String} hexadecimal string of hash value <span class='line'>278</span> * @since 1.0.3 <span class='line'>279</span> * @example <span class='line'>280</span> * KJUR.crypto.Util.ripemd160("aaa") &rarr; 08889bd7b151aa174c21f33f59147fa65381edea <span class='line'>281</span> */</span><span class="WHIT"> <span class='line'>282</span> </span><span class="NAME">KJUR.crypto.Util.ripemd160</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT"> <span class='line'>283</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">md</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">KJUR.crypto.MessageDigest</span><span class="PUNC">(</span><span class="PUNC">{</span><span class="STRN">'alg'</span><span class="PUNC">:</span><span class="STRN">'ripemd160'</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">'prov'</span><span class="PUNC">:</span><span class="STRN">'cryptojs'</span><span class="PUNC">}</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>284</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">md.digestString</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>285</span> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT"> <span class='line'>286</span> <span class='line'>287</span> </span><span class="COMM">// @since jsrsasign 7.0.0 crypto 1.1.11</span><span class="WHIT"> <span class='line'>288</span> </span><span class="NAME">KJUR.crypto.Util.SECURERANDOMGEN</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">new</span><span class="WHIT"> </span><span class="NAME">SecureRandom</span><sp