jsencrypt.js 105 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812
  1. import "./chunk-7FP5O474.js";
  2. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/util.js
  3. var BI_RM = "0123456789abcdefghijklmnopqrstuvwxyz";
  4. function int2char(n) {
  5. return BI_RM.charAt(n);
  6. }
  7. function op_and(x, y) {
  8. return x & y;
  9. }
  10. function op_or(x, y) {
  11. return x | y;
  12. }
  13. function op_xor(x, y) {
  14. return x ^ y;
  15. }
  16. function op_andnot(x, y) {
  17. return x & ~y;
  18. }
  19. function lbit(x) {
  20. if (x == 0) {
  21. return -1;
  22. }
  23. var r = 0;
  24. if ((x & 65535) == 0) {
  25. x >>= 16;
  26. r += 16;
  27. }
  28. if ((x & 255) == 0) {
  29. x >>= 8;
  30. r += 8;
  31. }
  32. if ((x & 15) == 0) {
  33. x >>= 4;
  34. r += 4;
  35. }
  36. if ((x & 3) == 0) {
  37. x >>= 2;
  38. r += 2;
  39. }
  40. if ((x & 1) == 0) {
  41. ++r;
  42. }
  43. return r;
  44. }
  45. function cbit(x) {
  46. var r = 0;
  47. while (x != 0) {
  48. x &= x - 1;
  49. ++r;
  50. }
  51. return r;
  52. }
  53. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/base64.js
  54. var b64map = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  55. var b64pad = "=";
  56. function hex2b64(h) {
  57. var i;
  58. var c;
  59. var ret = "";
  60. for (i = 0; i + 3 <= h.length; i += 3) {
  61. c = parseInt(h.substring(i, i + 3), 16);
  62. ret += b64map.charAt(c >> 6) + b64map.charAt(c & 63);
  63. }
  64. if (i + 1 == h.length) {
  65. c = parseInt(h.substring(i, i + 1), 16);
  66. ret += b64map.charAt(c << 2);
  67. } else if (i + 2 == h.length) {
  68. c = parseInt(h.substring(i, i + 2), 16);
  69. ret += b64map.charAt(c >> 2) + b64map.charAt((c & 3) << 4);
  70. }
  71. while ((ret.length & 3) > 0) {
  72. ret += b64pad;
  73. }
  74. return ret;
  75. }
  76. function b64tohex(s) {
  77. var ret = "";
  78. var i;
  79. var k = 0;
  80. var slop = 0;
  81. for (i = 0; i < s.length; ++i) {
  82. if (s.charAt(i) == b64pad) {
  83. break;
  84. }
  85. var v = b64map.indexOf(s.charAt(i));
  86. if (v < 0) {
  87. continue;
  88. }
  89. if (k == 0) {
  90. ret += int2char(v >> 2);
  91. slop = v & 3;
  92. k = 1;
  93. } else if (k == 1) {
  94. ret += int2char(slop << 2 | v >> 4);
  95. slop = v & 15;
  96. k = 2;
  97. } else if (k == 2) {
  98. ret += int2char(slop);
  99. ret += int2char(v >> 2);
  100. slop = v & 3;
  101. k = 3;
  102. } else {
  103. ret += int2char(slop << 2 | v >> 4);
  104. ret += int2char(v & 15);
  105. k = 0;
  106. }
  107. }
  108. if (k == 1) {
  109. ret += int2char(slop << 2);
  110. }
  111. return ret;
  112. }
  113. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/asn1js/hex.js
  114. var decoder;
  115. var Hex = {
  116. decode: function(a) {
  117. var i;
  118. if (decoder === void 0) {
  119. var hex = "0123456789ABCDEF";
  120. var ignore = " \f\n\r  \u2028\u2029";
  121. decoder = {};
  122. for (i = 0; i < 16; ++i) {
  123. decoder[hex.charAt(i)] = i;
  124. }
  125. hex = hex.toLowerCase();
  126. for (i = 10; i < 16; ++i) {
  127. decoder[hex.charAt(i)] = i;
  128. }
  129. for (i = 0; i < ignore.length; ++i) {
  130. decoder[ignore.charAt(i)] = -1;
  131. }
  132. }
  133. var out = [];
  134. var bits = 0;
  135. var char_count = 0;
  136. for (i = 0; i < a.length; ++i) {
  137. var c = a.charAt(i);
  138. if (c == "=") {
  139. break;
  140. }
  141. c = decoder[c];
  142. if (c == -1) {
  143. continue;
  144. }
  145. if (c === void 0) {
  146. throw new Error("Illegal character at offset " + i);
  147. }
  148. bits |= c;
  149. if (++char_count >= 2) {
  150. out[out.length] = bits;
  151. bits = 0;
  152. char_count = 0;
  153. } else {
  154. bits <<= 4;
  155. }
  156. }
  157. if (char_count) {
  158. throw new Error("Hex encoding incomplete: 4 bits missing");
  159. }
  160. return out;
  161. }
  162. };
  163. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/asn1js/base64.js
  164. var decoder2;
  165. var Base64 = {
  166. decode: function(a) {
  167. var i;
  168. if (decoder2 === void 0) {
  169. var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  170. var ignore = "= \f\n\r  \u2028\u2029";
  171. decoder2 = /* @__PURE__ */ Object.create(null);
  172. for (i = 0; i < 64; ++i) {
  173. decoder2[b64.charAt(i)] = i;
  174. }
  175. decoder2["-"] = 62;
  176. decoder2["_"] = 63;
  177. for (i = 0; i < ignore.length; ++i) {
  178. decoder2[ignore.charAt(i)] = -1;
  179. }
  180. }
  181. var out = [];
  182. var bits = 0;
  183. var char_count = 0;
  184. for (i = 0; i < a.length; ++i) {
  185. var c = a.charAt(i);
  186. if (c == "=") {
  187. break;
  188. }
  189. c = decoder2[c];
  190. if (c == -1) {
  191. continue;
  192. }
  193. if (c === void 0) {
  194. throw new Error("Illegal character at offset " + i);
  195. }
  196. bits |= c;
  197. if (++char_count >= 4) {
  198. out[out.length] = bits >> 16;
  199. out[out.length] = bits >> 8 & 255;
  200. out[out.length] = bits & 255;
  201. bits = 0;
  202. char_count = 0;
  203. } else {
  204. bits <<= 6;
  205. }
  206. }
  207. switch (char_count) {
  208. case 1:
  209. throw new Error("Base64 encoding incomplete: at least 2 bits missing");
  210. case 2:
  211. out[out.length] = bits >> 10;
  212. break;
  213. case 3:
  214. out[out.length] = bits >> 16;
  215. out[out.length] = bits >> 8 & 255;
  216. break;
  217. }
  218. return out;
  219. },
  220. re: /-----BEGIN [^-]+-----([A-Za-z0-9+\/=\s]+)-----END [^-]+-----|begin-base64[^\n]+\n([A-Za-z0-9+\/=\s]+)====/,
  221. unarmor: function(a) {
  222. var m = Base64.re.exec(a);
  223. if (m) {
  224. if (m[1]) {
  225. a = m[1];
  226. } else if (m[2]) {
  227. a = m[2];
  228. } else {
  229. throw new Error("RegExp out of sync");
  230. }
  231. }
  232. return Base64.decode(a);
  233. }
  234. };
  235. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/asn1js/int10.js
  236. var max = 1e13;
  237. var Int10 = (
  238. /** @class */
  239. function() {
  240. function Int102(value) {
  241. this.buf = [+value || 0];
  242. }
  243. Int102.prototype.mulAdd = function(m, c) {
  244. var b = this.buf;
  245. var l = b.length;
  246. var i;
  247. var t;
  248. for (i = 0; i < l; ++i) {
  249. t = b[i] * m + c;
  250. if (t < max) {
  251. c = 0;
  252. } else {
  253. c = 0 | t / max;
  254. t -= c * max;
  255. }
  256. b[i] = t;
  257. }
  258. if (c > 0) {
  259. b[i] = c;
  260. }
  261. };
  262. Int102.prototype.sub = function(c) {
  263. var b = this.buf;
  264. var l = b.length;
  265. var i;
  266. var t;
  267. for (i = 0; i < l; ++i) {
  268. t = b[i] - c;
  269. if (t < 0) {
  270. t += max;
  271. c = 1;
  272. } else {
  273. c = 0;
  274. }
  275. b[i] = t;
  276. }
  277. while (b[b.length - 1] === 0) {
  278. b.pop();
  279. }
  280. };
  281. Int102.prototype.toString = function(base) {
  282. if ((base || 10) != 10) {
  283. throw new Error("only base 10 is supported");
  284. }
  285. var b = this.buf;
  286. var s = b[b.length - 1].toString();
  287. for (var i = b.length - 2; i >= 0; --i) {
  288. s += (max + b[i]).toString().substring(1);
  289. }
  290. return s;
  291. };
  292. Int102.prototype.valueOf = function() {
  293. var b = this.buf;
  294. var v = 0;
  295. for (var i = b.length - 1; i >= 0; --i) {
  296. v = v * max + b[i];
  297. }
  298. return v;
  299. };
  300. Int102.prototype.simplify = function() {
  301. var b = this.buf;
  302. return b.length == 1 ? b[0] : this;
  303. };
  304. return Int102;
  305. }()
  306. );
  307. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/asn1js/asn1.js
  308. var ellipsis = "…";
  309. var reTimeS = /^(\d\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])([01]\d|2[0-3])(?:([0-5]\d)(?:([0-5]\d)(?:[.,](\d{1,3}))?)?)?(Z|[-+](?:[0]\d|1[0-2])([0-5]\d)?)?$/;
  310. var reTimeL = /^(\d\d\d\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])([01]\d|2[0-3])(?:([0-5]\d)(?:([0-5]\d)(?:[.,](\d{1,3}))?)?)?(Z|[-+](?:[0]\d|1[0-2])([0-5]\d)?)?$/;
  311. function stringCut(str, len) {
  312. if (str.length > len) {
  313. str = str.substring(0, len) + ellipsis;
  314. }
  315. return str;
  316. }
  317. var Stream = (
  318. /** @class */
  319. function() {
  320. function Stream2(enc, pos) {
  321. this.hexDigits = "0123456789ABCDEF";
  322. if (enc instanceof Stream2) {
  323. this.enc = enc.enc;
  324. this.pos = enc.pos;
  325. } else {
  326. this.enc = enc;
  327. this.pos = pos;
  328. }
  329. }
  330. Stream2.prototype.get = function(pos) {
  331. if (pos === void 0) {
  332. pos = this.pos++;
  333. }
  334. if (pos >= this.enc.length) {
  335. throw new Error("Requesting byte offset ".concat(pos, " on a stream of length ").concat(this.enc.length));
  336. }
  337. return "string" === typeof this.enc ? this.enc.charCodeAt(pos) : this.enc[pos];
  338. };
  339. Stream2.prototype.hexByte = function(b) {
  340. return this.hexDigits.charAt(b >> 4 & 15) + this.hexDigits.charAt(b & 15);
  341. };
  342. Stream2.prototype.hexDump = function(start, end, raw) {
  343. var s = "";
  344. for (var i = start; i < end; ++i) {
  345. s += this.hexByte(this.get(i));
  346. if (raw !== true) {
  347. switch (i & 15) {
  348. case 7:
  349. s += " ";
  350. break;
  351. case 15:
  352. s += "\n";
  353. break;
  354. default:
  355. s += " ";
  356. }
  357. }
  358. }
  359. return s;
  360. };
  361. Stream2.prototype.isASCII = function(start, end) {
  362. for (var i = start; i < end; ++i) {
  363. var c = this.get(i);
  364. if (c < 32 || c > 176) {
  365. return false;
  366. }
  367. }
  368. return true;
  369. };
  370. Stream2.prototype.parseStringISO = function(start, end) {
  371. var s = "";
  372. for (var i = start; i < end; ++i) {
  373. s += String.fromCharCode(this.get(i));
  374. }
  375. return s;
  376. };
  377. Stream2.prototype.parseStringUTF = function(start, end) {
  378. var s = "";
  379. for (var i = start; i < end; ) {
  380. var c = this.get(i++);
  381. if (c < 128) {
  382. s += String.fromCharCode(c);
  383. } else if (c > 191 && c < 224) {
  384. s += String.fromCharCode((c & 31) << 6 | this.get(i++) & 63);
  385. } else {
  386. s += String.fromCharCode((c & 15) << 12 | (this.get(i++) & 63) << 6 | this.get(i++) & 63);
  387. }
  388. }
  389. return s;
  390. };
  391. Stream2.prototype.parseStringBMP = function(start, end) {
  392. var str = "";
  393. var hi;
  394. var lo;
  395. for (var i = start; i < end; ) {
  396. hi = this.get(i++);
  397. lo = this.get(i++);
  398. str += String.fromCharCode(hi << 8 | lo);
  399. }
  400. return str;
  401. };
  402. Stream2.prototype.parseTime = function(start, end, shortYear) {
  403. var s = this.parseStringISO(start, end);
  404. var m = (shortYear ? reTimeS : reTimeL).exec(s);
  405. if (!m) {
  406. return "Unrecognized time: " + s;
  407. }
  408. if (shortYear) {
  409. m[1] = +m[1];
  410. m[1] += +m[1] < 70 ? 2e3 : 1900;
  411. }
  412. s = m[1] + "-" + m[2] + "-" + m[3] + " " + m[4];
  413. if (m[5]) {
  414. s += ":" + m[5];
  415. if (m[6]) {
  416. s += ":" + m[6];
  417. if (m[7]) {
  418. s += "." + m[7];
  419. }
  420. }
  421. }
  422. if (m[8]) {
  423. s += " UTC";
  424. if (m[8] != "Z") {
  425. s += m[8];
  426. if (m[9]) {
  427. s += ":" + m[9];
  428. }
  429. }
  430. }
  431. return s;
  432. };
  433. Stream2.prototype.parseInteger = function(start, end) {
  434. var v = this.get(start);
  435. var neg = v > 127;
  436. var pad = neg ? 255 : 0;
  437. var len;
  438. var s = "";
  439. while (v == pad && ++start < end) {
  440. v = this.get(start);
  441. }
  442. len = end - start;
  443. if (len === 0) {
  444. return neg ? -1 : 0;
  445. }
  446. if (len > 4) {
  447. s = v;
  448. len <<= 3;
  449. while (((+s ^ pad) & 128) == 0) {
  450. s = +s << 1;
  451. --len;
  452. }
  453. s = "(" + len + " bit)\n";
  454. }
  455. if (neg) {
  456. v = v - 256;
  457. }
  458. var n = new Int10(v);
  459. for (var i = start + 1; i < end; ++i) {
  460. n.mulAdd(256, this.get(i));
  461. }
  462. return s + n.toString();
  463. };
  464. Stream2.prototype.parseBitString = function(start, end, maxLength) {
  465. var unusedBit = this.get(start);
  466. var lenBit = (end - start - 1 << 3) - unusedBit;
  467. var intro = "(" + lenBit + " bit)\n";
  468. var s = "";
  469. for (var i = start + 1; i < end; ++i) {
  470. var b = this.get(i);
  471. var skip = i == end - 1 ? unusedBit : 0;
  472. for (var j = 7; j >= skip; --j) {
  473. s += b >> j & 1 ? "1" : "0";
  474. }
  475. if (s.length > maxLength) {
  476. return intro + stringCut(s, maxLength);
  477. }
  478. }
  479. return intro + s;
  480. };
  481. Stream2.prototype.parseOctetString = function(start, end, maxLength) {
  482. if (this.isASCII(start, end)) {
  483. return stringCut(this.parseStringISO(start, end), maxLength);
  484. }
  485. var len = end - start;
  486. var s = "(" + len + " byte)\n";
  487. maxLength /= 2;
  488. if (len > maxLength) {
  489. end = start + maxLength;
  490. }
  491. for (var i = start; i < end; ++i) {
  492. s += this.hexByte(this.get(i));
  493. }
  494. if (len > maxLength) {
  495. s += ellipsis;
  496. }
  497. return s;
  498. };
  499. Stream2.prototype.parseOID = function(start, end, maxLength) {
  500. var s = "";
  501. var n = new Int10();
  502. var bits = 0;
  503. for (var i = start; i < end; ++i) {
  504. var v = this.get(i);
  505. n.mulAdd(128, v & 127);
  506. bits += 7;
  507. if (!(v & 128)) {
  508. if (s === "") {
  509. n = n.simplify();
  510. if (n instanceof Int10) {
  511. n.sub(80);
  512. s = "2." + n.toString();
  513. } else {
  514. var m = n < 80 ? n < 40 ? 0 : 1 : 2;
  515. s = m + "." + (n - m * 40);
  516. }
  517. } else {
  518. s += "." + n.toString();
  519. }
  520. if (s.length > maxLength) {
  521. return stringCut(s, maxLength);
  522. }
  523. n = new Int10();
  524. bits = 0;
  525. }
  526. }
  527. if (bits > 0) {
  528. s += ".incomplete";
  529. }
  530. return s;
  531. };
  532. return Stream2;
  533. }()
  534. );
  535. var ASN1 = (
  536. /** @class */
  537. function() {
  538. function ASN12(stream, header, length, tag, sub) {
  539. if (!(tag instanceof ASN1Tag)) {
  540. throw new Error("Invalid tag value.");
  541. }
  542. this.stream = stream;
  543. this.header = header;
  544. this.length = length;
  545. this.tag = tag;
  546. this.sub = sub;
  547. }
  548. ASN12.prototype.typeName = function() {
  549. switch (this.tag.tagClass) {
  550. case 0:
  551. switch (this.tag.tagNumber) {
  552. case 0:
  553. return "EOC";
  554. case 1:
  555. return "BOOLEAN";
  556. case 2:
  557. return "INTEGER";
  558. case 3:
  559. return "BIT_STRING";
  560. case 4:
  561. return "OCTET_STRING";
  562. case 5:
  563. return "NULL";
  564. case 6:
  565. return "OBJECT_IDENTIFIER";
  566. case 7:
  567. return "ObjectDescriptor";
  568. case 8:
  569. return "EXTERNAL";
  570. case 9:
  571. return "REAL";
  572. case 10:
  573. return "ENUMERATED";
  574. case 11:
  575. return "EMBEDDED_PDV";
  576. case 12:
  577. return "UTF8String";
  578. case 16:
  579. return "SEQUENCE";
  580. case 17:
  581. return "SET";
  582. case 18:
  583. return "NumericString";
  584. case 19:
  585. return "PrintableString";
  586. case 20:
  587. return "TeletexString";
  588. case 21:
  589. return "VideotexString";
  590. case 22:
  591. return "IA5String";
  592. case 23:
  593. return "UTCTime";
  594. case 24:
  595. return "GeneralizedTime";
  596. case 25:
  597. return "GraphicString";
  598. case 26:
  599. return "VisibleString";
  600. case 27:
  601. return "GeneralString";
  602. case 28:
  603. return "UniversalString";
  604. case 30:
  605. return "BMPString";
  606. }
  607. return "Universal_" + this.tag.tagNumber.toString();
  608. case 1:
  609. return "Application_" + this.tag.tagNumber.toString();
  610. case 2:
  611. return "[" + this.tag.tagNumber.toString() + "]";
  612. case 3:
  613. return "Private_" + this.tag.tagNumber.toString();
  614. }
  615. };
  616. ASN12.prototype.content = function(maxLength) {
  617. if (this.tag === void 0) {
  618. return null;
  619. }
  620. if (maxLength === void 0) {
  621. maxLength = Infinity;
  622. }
  623. var content = this.posContent();
  624. var len = Math.abs(this.length);
  625. if (!this.tag.isUniversal()) {
  626. if (this.sub !== null) {
  627. return "(" + this.sub.length + " elem)";
  628. }
  629. return this.stream.parseOctetString(content, content + len, maxLength);
  630. }
  631. switch (this.tag.tagNumber) {
  632. case 1:
  633. return this.stream.get(content) === 0 ? "false" : "true";
  634. case 2:
  635. return this.stream.parseInteger(content, content + len);
  636. case 3:
  637. return this.sub ? "(" + this.sub.length + " elem)" : this.stream.parseBitString(content, content + len, maxLength);
  638. case 4:
  639. return this.sub ? "(" + this.sub.length + " elem)" : this.stream.parseOctetString(content, content + len, maxLength);
  640. case 6:
  641. return this.stream.parseOID(content, content + len, maxLength);
  642. case 16:
  643. case 17:
  644. if (this.sub !== null) {
  645. return "(" + this.sub.length + " elem)";
  646. } else {
  647. return "(no elem)";
  648. }
  649. case 12:
  650. return stringCut(this.stream.parseStringUTF(content, content + len), maxLength);
  651. case 18:
  652. case 19:
  653. case 20:
  654. case 21:
  655. case 22:
  656. case 26:
  657. return stringCut(this.stream.parseStringISO(content, content + len), maxLength);
  658. case 30:
  659. return stringCut(this.stream.parseStringBMP(content, content + len), maxLength);
  660. case 23:
  661. case 24:
  662. return this.stream.parseTime(content, content + len, this.tag.tagNumber == 23);
  663. }
  664. return null;
  665. };
  666. ASN12.prototype.toString = function() {
  667. return this.typeName() + "@" + this.stream.pos + "[header:" + this.header + ",length:" + this.length + ",sub:" + (this.sub === null ? "null" : this.sub.length) + "]";
  668. };
  669. ASN12.prototype.toPrettyString = function(indent) {
  670. if (indent === void 0) {
  671. indent = "";
  672. }
  673. var s = indent + this.typeName() + " @" + this.stream.pos;
  674. if (this.length >= 0) {
  675. s += "+";
  676. }
  677. s += this.length;
  678. if (this.tag.tagConstructed) {
  679. s += " (constructed)";
  680. } else if (this.tag.isUniversal() && (this.tag.tagNumber == 3 || this.tag.tagNumber == 4) && this.sub !== null) {
  681. s += " (encapsulates)";
  682. }
  683. s += "\n";
  684. if (this.sub !== null) {
  685. indent += " ";
  686. for (var i = 0, max2 = this.sub.length; i < max2; ++i) {
  687. s += this.sub[i].toPrettyString(indent);
  688. }
  689. }
  690. return s;
  691. };
  692. ASN12.prototype.posStart = function() {
  693. return this.stream.pos;
  694. };
  695. ASN12.prototype.posContent = function() {
  696. return this.stream.pos + this.header;
  697. };
  698. ASN12.prototype.posEnd = function() {
  699. return this.stream.pos + this.header + Math.abs(this.length);
  700. };
  701. ASN12.prototype.toHexString = function() {
  702. return this.stream.hexDump(this.posStart(), this.posEnd(), true);
  703. };
  704. ASN12.decodeLength = function(stream) {
  705. var buf = stream.get();
  706. var len = buf & 127;
  707. if (len == buf) {
  708. return len;
  709. }
  710. if (len > 6) {
  711. throw new Error("Length over 48 bits not supported at position " + (stream.pos - 1));
  712. }
  713. if (len === 0) {
  714. return null;
  715. }
  716. buf = 0;
  717. for (var i = 0; i < len; ++i) {
  718. buf = buf * 256 + stream.get();
  719. }
  720. return buf;
  721. };
  722. ASN12.prototype.getHexStringValue = function() {
  723. var hexString = this.toHexString();
  724. var offset = this.header * 2;
  725. var length = this.length * 2;
  726. return hexString.substr(offset, length);
  727. };
  728. ASN12.decode = function(str) {
  729. var stream;
  730. if (!(str instanceof Stream)) {
  731. stream = new Stream(str, 0);
  732. } else {
  733. stream = str;
  734. }
  735. var streamStart = new Stream(stream);
  736. var tag = new ASN1Tag(stream);
  737. var len = ASN12.decodeLength(stream);
  738. var start = stream.pos;
  739. var header = start - streamStart.pos;
  740. var sub = null;
  741. var getSub = function() {
  742. var ret = [];
  743. if (len !== null) {
  744. var end = start + len;
  745. while (stream.pos < end) {
  746. ret[ret.length] = ASN12.decode(stream);
  747. }
  748. if (stream.pos != end) {
  749. throw new Error("Content size is not correct for container starting at offset " + start);
  750. }
  751. } else {
  752. try {
  753. for (; ; ) {
  754. var s = ASN12.decode(stream);
  755. if (s.tag.isEOC()) {
  756. break;
  757. }
  758. ret[ret.length] = s;
  759. }
  760. len = start - stream.pos;
  761. } catch (e) {
  762. throw new Error("Exception while decoding undefined length content: " + e);
  763. }
  764. }
  765. return ret;
  766. };
  767. if (tag.tagConstructed) {
  768. sub = getSub();
  769. } else if (tag.isUniversal() && (tag.tagNumber == 3 || tag.tagNumber == 4)) {
  770. try {
  771. if (tag.tagNumber == 3) {
  772. if (stream.get() != 0) {
  773. throw new Error("BIT STRINGs with unused bits cannot encapsulate.");
  774. }
  775. }
  776. sub = getSub();
  777. for (var i = 0; i < sub.length; ++i) {
  778. if (sub[i].tag.isEOC()) {
  779. throw new Error("EOC is not supposed to be actual content.");
  780. }
  781. }
  782. } catch (e) {
  783. sub = null;
  784. }
  785. }
  786. if (sub === null) {
  787. if (len === null) {
  788. throw new Error("We can't skip over an invalid tag with undefined length at offset " + start);
  789. }
  790. stream.pos = start + Math.abs(len);
  791. }
  792. return new ASN12(streamStart, header, len, tag, sub);
  793. };
  794. return ASN12;
  795. }()
  796. );
  797. var ASN1Tag = (
  798. /** @class */
  799. function() {
  800. function ASN1Tag2(stream) {
  801. var buf = stream.get();
  802. this.tagClass = buf >> 6;
  803. this.tagConstructed = (buf & 32) !== 0;
  804. this.tagNumber = buf & 31;
  805. if (this.tagNumber == 31) {
  806. var n = new Int10();
  807. do {
  808. buf = stream.get();
  809. n.mulAdd(128, buf & 127);
  810. } while (buf & 128);
  811. this.tagNumber = n.simplify();
  812. }
  813. }
  814. ASN1Tag2.prototype.isUniversal = function() {
  815. return this.tagClass === 0;
  816. };
  817. ASN1Tag2.prototype.isEOC = function() {
  818. return this.tagClass === 0 && this.tagNumber === 0;
  819. };
  820. return ASN1Tag2;
  821. }()
  822. );
  823. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/jsbn.js
  824. var dbits;
  825. var canary = 244837814094590;
  826. var j_lm = (canary & 16777215) == 15715070;
  827. var lowprimes = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199, 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293, 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397, 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499, 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599, 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691, 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797, 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887, 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997];
  828. var lplim = (1 << 26) / lowprimes[lowprimes.length - 1];
  829. var BigInteger = (
  830. /** @class */
  831. function() {
  832. function BigInteger2(a, b, c) {
  833. if (a != null) {
  834. if ("number" == typeof a) {
  835. this.fromNumber(a, b, c);
  836. } else if (b == null && "string" != typeof a) {
  837. this.fromString(a, 256);
  838. } else {
  839. this.fromString(a, b);
  840. }
  841. }
  842. }
  843. BigInteger2.prototype.toString = function(b) {
  844. if (this.s < 0) {
  845. return "-" + this.negate().toString(b);
  846. }
  847. var k;
  848. if (b == 16) {
  849. k = 4;
  850. } else if (b == 8) {
  851. k = 3;
  852. } else if (b == 2) {
  853. k = 1;
  854. } else if (b == 32) {
  855. k = 5;
  856. } else if (b == 4) {
  857. k = 2;
  858. } else {
  859. return this.toRadix(b);
  860. }
  861. var km = (1 << k) - 1;
  862. var d;
  863. var m = false;
  864. var r = "";
  865. var i = this.t;
  866. var p = this.DB - i * this.DB % k;
  867. if (i-- > 0) {
  868. if (p < this.DB && (d = this[i] >> p) > 0) {
  869. m = true;
  870. r = int2char(d);
  871. }
  872. while (i >= 0) {
  873. if (p < k) {
  874. d = (this[i] & (1 << p) - 1) << k - p;
  875. d |= this[--i] >> (p += this.DB - k);
  876. } else {
  877. d = this[i] >> (p -= k) & km;
  878. if (p <= 0) {
  879. p += this.DB;
  880. --i;
  881. }
  882. }
  883. if (d > 0) {
  884. m = true;
  885. }
  886. if (m) {
  887. r += int2char(d);
  888. }
  889. }
  890. }
  891. return m ? r : "0";
  892. };
  893. BigInteger2.prototype.negate = function() {
  894. var r = nbi();
  895. BigInteger2.ZERO.subTo(this, r);
  896. return r;
  897. };
  898. BigInteger2.prototype.abs = function() {
  899. return this.s < 0 ? this.negate() : this;
  900. };
  901. BigInteger2.prototype.compareTo = function(a) {
  902. var r = this.s - a.s;
  903. if (r != 0) {
  904. return r;
  905. }
  906. var i = this.t;
  907. r = i - a.t;
  908. if (r != 0) {
  909. return this.s < 0 ? -r : r;
  910. }
  911. while (--i >= 0) {
  912. if ((r = this[i] - a[i]) != 0) {
  913. return r;
  914. }
  915. }
  916. return 0;
  917. };
  918. BigInteger2.prototype.bitLength = function() {
  919. if (this.t <= 0) {
  920. return 0;
  921. }
  922. return this.DB * (this.t - 1) + nbits(this[this.t - 1] ^ this.s & this.DM);
  923. };
  924. BigInteger2.prototype.mod = function(a) {
  925. var r = nbi();
  926. this.abs().divRemTo(a, null, r);
  927. if (this.s < 0 && r.compareTo(BigInteger2.ZERO) > 0) {
  928. a.subTo(r, r);
  929. }
  930. return r;
  931. };
  932. BigInteger2.prototype.modPowInt = function(e, m) {
  933. var z;
  934. if (e < 256 || m.isEven()) {
  935. z = new Classic(m);
  936. } else {
  937. z = new Montgomery(m);
  938. }
  939. return this.exp(e, z);
  940. };
  941. BigInteger2.prototype.clone = function() {
  942. var r = nbi();
  943. this.copyTo(r);
  944. return r;
  945. };
  946. BigInteger2.prototype.intValue = function() {
  947. if (this.s < 0) {
  948. if (this.t == 1) {
  949. return this[0] - this.DV;
  950. } else if (this.t == 0) {
  951. return -1;
  952. }
  953. } else if (this.t == 1) {
  954. return this[0];
  955. } else if (this.t == 0) {
  956. return 0;
  957. }
  958. return (this[1] & (1 << 32 - this.DB) - 1) << this.DB | this[0];
  959. };
  960. BigInteger2.prototype.byteValue = function() {
  961. return this.t == 0 ? this.s : this[0] << 24 >> 24;
  962. };
  963. BigInteger2.prototype.shortValue = function() {
  964. return this.t == 0 ? this.s : this[0] << 16 >> 16;
  965. };
  966. BigInteger2.prototype.signum = function() {
  967. if (this.s < 0) {
  968. return -1;
  969. } else if (this.t <= 0 || this.t == 1 && this[0] <= 0) {
  970. return 0;
  971. } else {
  972. return 1;
  973. }
  974. };
  975. BigInteger2.prototype.toByteArray = function() {
  976. var i = this.t;
  977. var r = [];
  978. r[0] = this.s;
  979. var p = this.DB - i * this.DB % 8;
  980. var d;
  981. var k = 0;
  982. if (i-- > 0) {
  983. if (p < this.DB && (d = this[i] >> p) != (this.s & this.DM) >> p) {
  984. r[k++] = d | this.s << this.DB - p;
  985. }
  986. while (i >= 0) {
  987. if (p < 8) {
  988. d = (this[i] & (1 << p) - 1) << 8 - p;
  989. d |= this[--i] >> (p += this.DB - 8);
  990. } else {
  991. d = this[i] >> (p -= 8) & 255;
  992. if (p <= 0) {
  993. p += this.DB;
  994. --i;
  995. }
  996. }
  997. if ((d & 128) != 0) {
  998. d |= -256;
  999. }
  1000. if (k == 0 && (this.s & 128) != (d & 128)) {
  1001. ++k;
  1002. }
  1003. if (k > 0 || d != this.s) {
  1004. r[k++] = d;
  1005. }
  1006. }
  1007. }
  1008. return r;
  1009. };
  1010. BigInteger2.prototype.equals = function(a) {
  1011. return this.compareTo(a) == 0;
  1012. };
  1013. BigInteger2.prototype.min = function(a) {
  1014. return this.compareTo(a) < 0 ? this : a;
  1015. };
  1016. BigInteger2.prototype.max = function(a) {
  1017. return this.compareTo(a) > 0 ? this : a;
  1018. };
  1019. BigInteger2.prototype.and = function(a) {
  1020. var r = nbi();
  1021. this.bitwiseTo(a, op_and, r);
  1022. return r;
  1023. };
  1024. BigInteger2.prototype.or = function(a) {
  1025. var r = nbi();
  1026. this.bitwiseTo(a, op_or, r);
  1027. return r;
  1028. };
  1029. BigInteger2.prototype.xor = function(a) {
  1030. var r = nbi();
  1031. this.bitwiseTo(a, op_xor, r);
  1032. return r;
  1033. };
  1034. BigInteger2.prototype.andNot = function(a) {
  1035. var r = nbi();
  1036. this.bitwiseTo(a, op_andnot, r);
  1037. return r;
  1038. };
  1039. BigInteger2.prototype.not = function() {
  1040. var r = nbi();
  1041. for (var i = 0; i < this.t; ++i) {
  1042. r[i] = this.DM & ~this[i];
  1043. }
  1044. r.t = this.t;
  1045. r.s = ~this.s;
  1046. return r;
  1047. };
  1048. BigInteger2.prototype.shiftLeft = function(n) {
  1049. var r = nbi();
  1050. if (n < 0) {
  1051. this.rShiftTo(-n, r);
  1052. } else {
  1053. this.lShiftTo(n, r);
  1054. }
  1055. return r;
  1056. };
  1057. BigInteger2.prototype.shiftRight = function(n) {
  1058. var r = nbi();
  1059. if (n < 0) {
  1060. this.lShiftTo(-n, r);
  1061. } else {
  1062. this.rShiftTo(n, r);
  1063. }
  1064. return r;
  1065. };
  1066. BigInteger2.prototype.getLowestSetBit = function() {
  1067. for (var i = 0; i < this.t; ++i) {
  1068. if (this[i] != 0) {
  1069. return i * this.DB + lbit(this[i]);
  1070. }
  1071. }
  1072. if (this.s < 0) {
  1073. return this.t * this.DB;
  1074. }
  1075. return -1;
  1076. };
  1077. BigInteger2.prototype.bitCount = function() {
  1078. var r = 0;
  1079. var x = this.s & this.DM;
  1080. for (var i = 0; i < this.t; ++i) {
  1081. r += cbit(this[i] ^ x);
  1082. }
  1083. return r;
  1084. };
  1085. BigInteger2.prototype.testBit = function(n) {
  1086. var j = Math.floor(n / this.DB);
  1087. if (j >= this.t) {
  1088. return this.s != 0;
  1089. }
  1090. return (this[j] & 1 << n % this.DB) != 0;
  1091. };
  1092. BigInteger2.prototype.setBit = function(n) {
  1093. return this.changeBit(n, op_or);
  1094. };
  1095. BigInteger2.prototype.clearBit = function(n) {
  1096. return this.changeBit(n, op_andnot);
  1097. };
  1098. BigInteger2.prototype.flipBit = function(n) {
  1099. return this.changeBit(n, op_xor);
  1100. };
  1101. BigInteger2.prototype.add = function(a) {
  1102. var r = nbi();
  1103. this.addTo(a, r);
  1104. return r;
  1105. };
  1106. BigInteger2.prototype.subtract = function(a) {
  1107. var r = nbi();
  1108. this.subTo(a, r);
  1109. return r;
  1110. };
  1111. BigInteger2.prototype.multiply = function(a) {
  1112. var r = nbi();
  1113. this.multiplyTo(a, r);
  1114. return r;
  1115. };
  1116. BigInteger2.prototype.divide = function(a) {
  1117. var r = nbi();
  1118. this.divRemTo(a, r, null);
  1119. return r;
  1120. };
  1121. BigInteger2.prototype.remainder = function(a) {
  1122. var r = nbi();
  1123. this.divRemTo(a, null, r);
  1124. return r;
  1125. };
  1126. BigInteger2.prototype.divideAndRemainder = function(a) {
  1127. var q = nbi();
  1128. var r = nbi();
  1129. this.divRemTo(a, q, r);
  1130. return [q, r];
  1131. };
  1132. BigInteger2.prototype.modPow = function(e, m) {
  1133. var i = e.bitLength();
  1134. var k;
  1135. var r = nbv(1);
  1136. var z;
  1137. if (i <= 0) {
  1138. return r;
  1139. } else if (i < 18) {
  1140. k = 1;
  1141. } else if (i < 48) {
  1142. k = 3;
  1143. } else if (i < 144) {
  1144. k = 4;
  1145. } else if (i < 768) {
  1146. k = 5;
  1147. } else {
  1148. k = 6;
  1149. }
  1150. if (i < 8) {
  1151. z = new Classic(m);
  1152. } else if (m.isEven()) {
  1153. z = new Barrett(m);
  1154. } else {
  1155. z = new Montgomery(m);
  1156. }
  1157. var g = [];
  1158. var n = 3;
  1159. var k1 = k - 1;
  1160. var km = (1 << k) - 1;
  1161. g[1] = z.convert(this);
  1162. if (k > 1) {
  1163. var g2 = nbi();
  1164. z.sqrTo(g[1], g2);
  1165. while (n <= km) {
  1166. g[n] = nbi();
  1167. z.mulTo(g2, g[n - 2], g[n]);
  1168. n += 2;
  1169. }
  1170. }
  1171. var j = e.t - 1;
  1172. var w;
  1173. var is1 = true;
  1174. var r2 = nbi();
  1175. var t;
  1176. i = nbits(e[j]) - 1;
  1177. while (j >= 0) {
  1178. if (i >= k1) {
  1179. w = e[j] >> i - k1 & km;
  1180. } else {
  1181. w = (e[j] & (1 << i + 1) - 1) << k1 - i;
  1182. if (j > 0) {
  1183. w |= e[j - 1] >> this.DB + i - k1;
  1184. }
  1185. }
  1186. n = k;
  1187. while ((w & 1) == 0) {
  1188. w >>= 1;
  1189. --n;
  1190. }
  1191. if ((i -= n) < 0) {
  1192. i += this.DB;
  1193. --j;
  1194. }
  1195. if (is1) {
  1196. g[w].copyTo(r);
  1197. is1 = false;
  1198. } else {
  1199. while (n > 1) {
  1200. z.sqrTo(r, r2);
  1201. z.sqrTo(r2, r);
  1202. n -= 2;
  1203. }
  1204. if (n > 0) {
  1205. z.sqrTo(r, r2);
  1206. } else {
  1207. t = r;
  1208. r = r2;
  1209. r2 = t;
  1210. }
  1211. z.mulTo(r2, g[w], r);
  1212. }
  1213. while (j >= 0 && (e[j] & 1 << i) == 0) {
  1214. z.sqrTo(r, r2);
  1215. t = r;
  1216. r = r2;
  1217. r2 = t;
  1218. if (--i < 0) {
  1219. i = this.DB - 1;
  1220. --j;
  1221. }
  1222. }
  1223. }
  1224. return z.revert(r);
  1225. };
  1226. BigInteger2.prototype.modInverse = function(m) {
  1227. var ac = m.isEven();
  1228. if (this.isEven() && ac || m.signum() == 0) {
  1229. return BigInteger2.ZERO;
  1230. }
  1231. var u = m.clone();
  1232. var v = this.clone();
  1233. var a = nbv(1);
  1234. var b = nbv(0);
  1235. var c = nbv(0);
  1236. var d = nbv(1);
  1237. while (u.signum() != 0) {
  1238. while (u.isEven()) {
  1239. u.rShiftTo(1, u);
  1240. if (ac) {
  1241. if (!a.isEven() || !b.isEven()) {
  1242. a.addTo(this, a);
  1243. b.subTo(m, b);
  1244. }
  1245. a.rShiftTo(1, a);
  1246. } else if (!b.isEven()) {
  1247. b.subTo(m, b);
  1248. }
  1249. b.rShiftTo(1, b);
  1250. }
  1251. while (v.isEven()) {
  1252. v.rShiftTo(1, v);
  1253. if (ac) {
  1254. if (!c.isEven() || !d.isEven()) {
  1255. c.addTo(this, c);
  1256. d.subTo(m, d);
  1257. }
  1258. c.rShiftTo(1, c);
  1259. } else if (!d.isEven()) {
  1260. d.subTo(m, d);
  1261. }
  1262. d.rShiftTo(1, d);
  1263. }
  1264. if (u.compareTo(v) >= 0) {
  1265. u.subTo(v, u);
  1266. if (ac) {
  1267. a.subTo(c, a);
  1268. }
  1269. b.subTo(d, b);
  1270. } else {
  1271. v.subTo(u, v);
  1272. if (ac) {
  1273. c.subTo(a, c);
  1274. }
  1275. d.subTo(b, d);
  1276. }
  1277. }
  1278. if (v.compareTo(BigInteger2.ONE) != 0) {
  1279. return BigInteger2.ZERO;
  1280. }
  1281. if (d.compareTo(m) >= 0) {
  1282. return d.subtract(m);
  1283. }
  1284. if (d.signum() < 0) {
  1285. d.addTo(m, d);
  1286. } else {
  1287. return d;
  1288. }
  1289. if (d.signum() < 0) {
  1290. return d.add(m);
  1291. } else {
  1292. return d;
  1293. }
  1294. };
  1295. BigInteger2.prototype.pow = function(e) {
  1296. return this.exp(e, new NullExp());
  1297. };
  1298. BigInteger2.prototype.gcd = function(a) {
  1299. var x = this.s < 0 ? this.negate() : this.clone();
  1300. var y = a.s < 0 ? a.negate() : a.clone();
  1301. if (x.compareTo(y) < 0) {
  1302. var t = x;
  1303. x = y;
  1304. y = t;
  1305. }
  1306. var i = x.getLowestSetBit();
  1307. var g = y.getLowestSetBit();
  1308. if (g < 0) {
  1309. return x;
  1310. }
  1311. if (i < g) {
  1312. g = i;
  1313. }
  1314. if (g > 0) {
  1315. x.rShiftTo(g, x);
  1316. y.rShiftTo(g, y);
  1317. }
  1318. while (x.signum() > 0) {
  1319. if ((i = x.getLowestSetBit()) > 0) {
  1320. x.rShiftTo(i, x);
  1321. }
  1322. if ((i = y.getLowestSetBit()) > 0) {
  1323. y.rShiftTo(i, y);
  1324. }
  1325. if (x.compareTo(y) >= 0) {
  1326. x.subTo(y, x);
  1327. x.rShiftTo(1, x);
  1328. } else {
  1329. y.subTo(x, y);
  1330. y.rShiftTo(1, y);
  1331. }
  1332. }
  1333. if (g > 0) {
  1334. y.lShiftTo(g, y);
  1335. }
  1336. return y;
  1337. };
  1338. BigInteger2.prototype.isProbablePrime = function(t) {
  1339. var i;
  1340. var x = this.abs();
  1341. if (x.t == 1 && x[0] <= lowprimes[lowprimes.length - 1]) {
  1342. for (i = 0; i < lowprimes.length; ++i) {
  1343. if (x[0] == lowprimes[i]) {
  1344. return true;
  1345. }
  1346. }
  1347. return false;
  1348. }
  1349. if (x.isEven()) {
  1350. return false;
  1351. }
  1352. i = 1;
  1353. while (i < lowprimes.length) {
  1354. var m = lowprimes[i];
  1355. var j = i + 1;
  1356. while (j < lowprimes.length && m < lplim) {
  1357. m *= lowprimes[j++];
  1358. }
  1359. m = x.modInt(m);
  1360. while (i < j) {
  1361. if (m % lowprimes[i++] == 0) {
  1362. return false;
  1363. }
  1364. }
  1365. }
  1366. return x.millerRabin(t);
  1367. };
  1368. BigInteger2.prototype.copyTo = function(r) {
  1369. for (var i = this.t - 1; i >= 0; --i) {
  1370. r[i] = this[i];
  1371. }
  1372. r.t = this.t;
  1373. r.s = this.s;
  1374. };
  1375. BigInteger2.prototype.fromInt = function(x) {
  1376. this.t = 1;
  1377. this.s = x < 0 ? -1 : 0;
  1378. if (x > 0) {
  1379. this[0] = x;
  1380. } else if (x < -1) {
  1381. this[0] = x + this.DV;
  1382. } else {
  1383. this.t = 0;
  1384. }
  1385. };
  1386. BigInteger2.prototype.fromString = function(s, b) {
  1387. var k;
  1388. if (b == 16) {
  1389. k = 4;
  1390. } else if (b == 8) {
  1391. k = 3;
  1392. } else if (b == 256) {
  1393. k = 8;
  1394. } else if (b == 2) {
  1395. k = 1;
  1396. } else if (b == 32) {
  1397. k = 5;
  1398. } else if (b == 4) {
  1399. k = 2;
  1400. } else {
  1401. this.fromRadix(s, b);
  1402. return;
  1403. }
  1404. this.t = 0;
  1405. this.s = 0;
  1406. var i = s.length;
  1407. var mi = false;
  1408. var sh = 0;
  1409. while (--i >= 0) {
  1410. var x = k == 8 ? +s[i] & 255 : intAt(s, i);
  1411. if (x < 0) {
  1412. if (s.charAt(i) == "-") {
  1413. mi = true;
  1414. }
  1415. continue;
  1416. }
  1417. mi = false;
  1418. if (sh == 0) {
  1419. this[this.t++] = x;
  1420. } else if (sh + k > this.DB) {
  1421. this[this.t - 1] |= (x & (1 << this.DB - sh) - 1) << sh;
  1422. this[this.t++] = x >> this.DB - sh;
  1423. } else {
  1424. this[this.t - 1] |= x << sh;
  1425. }
  1426. sh += k;
  1427. if (sh >= this.DB) {
  1428. sh -= this.DB;
  1429. }
  1430. }
  1431. if (k == 8 && (+s[0] & 128) != 0) {
  1432. this.s = -1;
  1433. if (sh > 0) {
  1434. this[this.t - 1] |= (1 << this.DB - sh) - 1 << sh;
  1435. }
  1436. }
  1437. this.clamp();
  1438. if (mi) {
  1439. BigInteger2.ZERO.subTo(this, this);
  1440. }
  1441. };
  1442. BigInteger2.prototype.clamp = function() {
  1443. var c = this.s & this.DM;
  1444. while (this.t > 0 && this[this.t - 1] == c) {
  1445. --this.t;
  1446. }
  1447. };
  1448. BigInteger2.prototype.dlShiftTo = function(n, r) {
  1449. var i;
  1450. for (i = this.t - 1; i >= 0; --i) {
  1451. r[i + n] = this[i];
  1452. }
  1453. for (i = n - 1; i >= 0; --i) {
  1454. r[i] = 0;
  1455. }
  1456. r.t = this.t + n;
  1457. r.s = this.s;
  1458. };
  1459. BigInteger2.prototype.drShiftTo = function(n, r) {
  1460. for (var i = n; i < this.t; ++i) {
  1461. r[i - n] = this[i];
  1462. }
  1463. r.t = Math.max(this.t - n, 0);
  1464. r.s = this.s;
  1465. };
  1466. BigInteger2.prototype.lShiftTo = function(n, r) {
  1467. var bs = n % this.DB;
  1468. var cbs = this.DB - bs;
  1469. var bm = (1 << cbs) - 1;
  1470. var ds = Math.floor(n / this.DB);
  1471. var c = this.s << bs & this.DM;
  1472. for (var i = this.t - 1; i >= 0; --i) {
  1473. r[i + ds + 1] = this[i] >> cbs | c;
  1474. c = (this[i] & bm) << bs;
  1475. }
  1476. for (var i = ds - 1; i >= 0; --i) {
  1477. r[i] = 0;
  1478. }
  1479. r[ds] = c;
  1480. r.t = this.t + ds + 1;
  1481. r.s = this.s;
  1482. r.clamp();
  1483. };
  1484. BigInteger2.prototype.rShiftTo = function(n, r) {
  1485. r.s = this.s;
  1486. var ds = Math.floor(n / this.DB);
  1487. if (ds >= this.t) {
  1488. r.t = 0;
  1489. return;
  1490. }
  1491. var bs = n % this.DB;
  1492. var cbs = this.DB - bs;
  1493. var bm = (1 << bs) - 1;
  1494. r[0] = this[ds] >> bs;
  1495. for (var i = ds + 1; i < this.t; ++i) {
  1496. r[i - ds - 1] |= (this[i] & bm) << cbs;
  1497. r[i - ds] = this[i] >> bs;
  1498. }
  1499. if (bs > 0) {
  1500. r[this.t - ds - 1] |= (this.s & bm) << cbs;
  1501. }
  1502. r.t = this.t - ds;
  1503. r.clamp();
  1504. };
  1505. BigInteger2.prototype.subTo = function(a, r) {
  1506. var i = 0;
  1507. var c = 0;
  1508. var m = Math.min(a.t, this.t);
  1509. while (i < m) {
  1510. c += this[i] - a[i];
  1511. r[i++] = c & this.DM;
  1512. c >>= this.DB;
  1513. }
  1514. if (a.t < this.t) {
  1515. c -= a.s;
  1516. while (i < this.t) {
  1517. c += this[i];
  1518. r[i++] = c & this.DM;
  1519. c >>= this.DB;
  1520. }
  1521. c += this.s;
  1522. } else {
  1523. c += this.s;
  1524. while (i < a.t) {
  1525. c -= a[i];
  1526. r[i++] = c & this.DM;
  1527. c >>= this.DB;
  1528. }
  1529. c -= a.s;
  1530. }
  1531. r.s = c < 0 ? -1 : 0;
  1532. if (c < -1) {
  1533. r[i++] = this.DV + c;
  1534. } else if (c > 0) {
  1535. r[i++] = c;
  1536. }
  1537. r.t = i;
  1538. r.clamp();
  1539. };
  1540. BigInteger2.prototype.multiplyTo = function(a, r) {
  1541. var x = this.abs();
  1542. var y = a.abs();
  1543. var i = x.t;
  1544. r.t = i + y.t;
  1545. while (--i >= 0) {
  1546. r[i] = 0;
  1547. }
  1548. for (i = 0; i < y.t; ++i) {
  1549. r[i + x.t] = x.am(0, y[i], r, i, 0, x.t);
  1550. }
  1551. r.s = 0;
  1552. r.clamp();
  1553. if (this.s != a.s) {
  1554. BigInteger2.ZERO.subTo(r, r);
  1555. }
  1556. };
  1557. BigInteger2.prototype.squareTo = function(r) {
  1558. var x = this.abs();
  1559. var i = r.t = 2 * x.t;
  1560. while (--i >= 0) {
  1561. r[i] = 0;
  1562. }
  1563. for (i = 0; i < x.t - 1; ++i) {
  1564. var c = x.am(i, x[i], r, 2 * i, 0, 1);
  1565. if ((r[i + x.t] += x.am(i + 1, 2 * x[i], r, 2 * i + 1, c, x.t - i - 1)) >= x.DV) {
  1566. r[i + x.t] -= x.DV;
  1567. r[i + x.t + 1] = 1;
  1568. }
  1569. }
  1570. if (r.t > 0) {
  1571. r[r.t - 1] += x.am(i, x[i], r, 2 * i, 0, 1);
  1572. }
  1573. r.s = 0;
  1574. r.clamp();
  1575. };
  1576. BigInteger2.prototype.divRemTo = function(m, q, r) {
  1577. var pm = m.abs();
  1578. if (pm.t <= 0) {
  1579. return;
  1580. }
  1581. var pt = this.abs();
  1582. if (pt.t < pm.t) {
  1583. if (q != null) {
  1584. q.fromInt(0);
  1585. }
  1586. if (r != null) {
  1587. this.copyTo(r);
  1588. }
  1589. return;
  1590. }
  1591. if (r == null) {
  1592. r = nbi();
  1593. }
  1594. var y = nbi();
  1595. var ts = this.s;
  1596. var ms = m.s;
  1597. var nsh = this.DB - nbits(pm[pm.t - 1]);
  1598. if (nsh > 0) {
  1599. pm.lShiftTo(nsh, y);
  1600. pt.lShiftTo(nsh, r);
  1601. } else {
  1602. pm.copyTo(y);
  1603. pt.copyTo(r);
  1604. }
  1605. var ys = y.t;
  1606. var y0 = y[ys - 1];
  1607. if (y0 == 0) {
  1608. return;
  1609. }
  1610. var yt = y0 * (1 << this.F1) + (ys > 1 ? y[ys - 2] >> this.F2 : 0);
  1611. var d1 = this.FV / yt;
  1612. var d2 = (1 << this.F1) / yt;
  1613. var e = 1 << this.F2;
  1614. var i = r.t;
  1615. var j = i - ys;
  1616. var t = q == null ? nbi() : q;
  1617. y.dlShiftTo(j, t);
  1618. if (r.compareTo(t) >= 0) {
  1619. r[r.t++] = 1;
  1620. r.subTo(t, r);
  1621. }
  1622. BigInteger2.ONE.dlShiftTo(ys, t);
  1623. t.subTo(y, y);
  1624. while (y.t < ys) {
  1625. y[y.t++] = 0;
  1626. }
  1627. while (--j >= 0) {
  1628. var qd = r[--i] == y0 ? this.DM : Math.floor(r[i] * d1 + (r[i - 1] + e) * d2);
  1629. if ((r[i] += y.am(0, qd, r, j, 0, ys)) < qd) {
  1630. y.dlShiftTo(j, t);
  1631. r.subTo(t, r);
  1632. while (r[i] < --qd) {
  1633. r.subTo(t, r);
  1634. }
  1635. }
  1636. }
  1637. if (q != null) {
  1638. r.drShiftTo(ys, q);
  1639. if (ts != ms) {
  1640. BigInteger2.ZERO.subTo(q, q);
  1641. }
  1642. }
  1643. r.t = ys;
  1644. r.clamp();
  1645. if (nsh > 0) {
  1646. r.rShiftTo(nsh, r);
  1647. }
  1648. if (ts < 0) {
  1649. BigInteger2.ZERO.subTo(r, r);
  1650. }
  1651. };
  1652. BigInteger2.prototype.invDigit = function() {
  1653. if (this.t < 1) {
  1654. return 0;
  1655. }
  1656. var x = this[0];
  1657. if ((x & 1) == 0) {
  1658. return 0;
  1659. }
  1660. var y = x & 3;
  1661. y = y * (2 - (x & 15) * y) & 15;
  1662. y = y * (2 - (x & 255) * y) & 255;
  1663. y = y * (2 - ((x & 65535) * y & 65535)) & 65535;
  1664. y = y * (2 - x * y % this.DV) % this.DV;
  1665. return y > 0 ? this.DV - y : -y;
  1666. };
  1667. BigInteger2.prototype.isEven = function() {
  1668. return (this.t > 0 ? this[0] & 1 : this.s) == 0;
  1669. };
  1670. BigInteger2.prototype.exp = function(e, z) {
  1671. if (e > 4294967295 || e < 1) {
  1672. return BigInteger2.ONE;
  1673. }
  1674. var r = nbi();
  1675. var r2 = nbi();
  1676. var g = z.convert(this);
  1677. var i = nbits(e) - 1;
  1678. g.copyTo(r);
  1679. while (--i >= 0) {
  1680. z.sqrTo(r, r2);
  1681. if ((e & 1 << i) > 0) {
  1682. z.mulTo(r2, g, r);
  1683. } else {
  1684. var t = r;
  1685. r = r2;
  1686. r2 = t;
  1687. }
  1688. }
  1689. return z.revert(r);
  1690. };
  1691. BigInteger2.prototype.chunkSize = function(r) {
  1692. return Math.floor(Math.LN2 * this.DB / Math.log(r));
  1693. };
  1694. BigInteger2.prototype.toRadix = function(b) {
  1695. if (b == null) {
  1696. b = 10;
  1697. }
  1698. if (this.signum() == 0 || b < 2 || b > 36) {
  1699. return "0";
  1700. }
  1701. var cs = this.chunkSize(b);
  1702. var a = Math.pow(b, cs);
  1703. var d = nbv(a);
  1704. var y = nbi();
  1705. var z = nbi();
  1706. var r = "";
  1707. this.divRemTo(d, y, z);
  1708. while (y.signum() > 0) {
  1709. r = (a + z.intValue()).toString(b).substr(1) + r;
  1710. y.divRemTo(d, y, z);
  1711. }
  1712. return z.intValue().toString(b) + r;
  1713. };
  1714. BigInteger2.prototype.fromRadix = function(s, b) {
  1715. this.fromInt(0);
  1716. if (b == null) {
  1717. b = 10;
  1718. }
  1719. var cs = this.chunkSize(b);
  1720. var d = Math.pow(b, cs);
  1721. var mi = false;
  1722. var j = 0;
  1723. var w = 0;
  1724. for (var i = 0; i < s.length; ++i) {
  1725. var x = intAt(s, i);
  1726. if (x < 0) {
  1727. if (s.charAt(i) == "-" && this.signum() == 0) {
  1728. mi = true;
  1729. }
  1730. continue;
  1731. }
  1732. w = b * w + x;
  1733. if (++j >= cs) {
  1734. this.dMultiply(d);
  1735. this.dAddOffset(w, 0);
  1736. j = 0;
  1737. w = 0;
  1738. }
  1739. }
  1740. if (j > 0) {
  1741. this.dMultiply(Math.pow(b, j));
  1742. this.dAddOffset(w, 0);
  1743. }
  1744. if (mi) {
  1745. BigInteger2.ZERO.subTo(this, this);
  1746. }
  1747. };
  1748. BigInteger2.prototype.fromNumber = function(a, b, c) {
  1749. if ("number" == typeof b) {
  1750. if (a < 2) {
  1751. this.fromInt(1);
  1752. } else {
  1753. this.fromNumber(a, c);
  1754. if (!this.testBit(a - 1)) {
  1755. this.bitwiseTo(BigInteger2.ONE.shiftLeft(a - 1), op_or, this);
  1756. }
  1757. if (this.isEven()) {
  1758. this.dAddOffset(1, 0);
  1759. }
  1760. while (!this.isProbablePrime(b)) {
  1761. this.dAddOffset(2, 0);
  1762. if (this.bitLength() > a) {
  1763. this.subTo(BigInteger2.ONE.shiftLeft(a - 1), this);
  1764. }
  1765. }
  1766. }
  1767. } else {
  1768. var x = [];
  1769. var t = a & 7;
  1770. x.length = (a >> 3) + 1;
  1771. b.nextBytes(x);
  1772. if (t > 0) {
  1773. x[0] &= (1 << t) - 1;
  1774. } else {
  1775. x[0] = 0;
  1776. }
  1777. this.fromString(x, 256);
  1778. }
  1779. };
  1780. BigInteger2.prototype.bitwiseTo = function(a, op, r) {
  1781. var i;
  1782. var f;
  1783. var m = Math.min(a.t, this.t);
  1784. for (i = 0; i < m; ++i) {
  1785. r[i] = op(this[i], a[i]);
  1786. }
  1787. if (a.t < this.t) {
  1788. f = a.s & this.DM;
  1789. for (i = m; i < this.t; ++i) {
  1790. r[i] = op(this[i], f);
  1791. }
  1792. r.t = this.t;
  1793. } else {
  1794. f = this.s & this.DM;
  1795. for (i = m; i < a.t; ++i) {
  1796. r[i] = op(f, a[i]);
  1797. }
  1798. r.t = a.t;
  1799. }
  1800. r.s = op(this.s, a.s);
  1801. r.clamp();
  1802. };
  1803. BigInteger2.prototype.changeBit = function(n, op) {
  1804. var r = BigInteger2.ONE.shiftLeft(n);
  1805. this.bitwiseTo(r, op, r);
  1806. return r;
  1807. };
  1808. BigInteger2.prototype.addTo = function(a, r) {
  1809. var i = 0;
  1810. var c = 0;
  1811. var m = Math.min(a.t, this.t);
  1812. while (i < m) {
  1813. c += this[i] + a[i];
  1814. r[i++] = c & this.DM;
  1815. c >>= this.DB;
  1816. }
  1817. if (a.t < this.t) {
  1818. c += a.s;
  1819. while (i < this.t) {
  1820. c += this[i];
  1821. r[i++] = c & this.DM;
  1822. c >>= this.DB;
  1823. }
  1824. c += this.s;
  1825. } else {
  1826. c += this.s;
  1827. while (i < a.t) {
  1828. c += a[i];
  1829. r[i++] = c & this.DM;
  1830. c >>= this.DB;
  1831. }
  1832. c += a.s;
  1833. }
  1834. r.s = c < 0 ? -1 : 0;
  1835. if (c > 0) {
  1836. r[i++] = c;
  1837. } else if (c < -1) {
  1838. r[i++] = this.DV + c;
  1839. }
  1840. r.t = i;
  1841. r.clamp();
  1842. };
  1843. BigInteger2.prototype.dMultiply = function(n) {
  1844. this[this.t] = this.am(0, n - 1, this, 0, 0, this.t);
  1845. ++this.t;
  1846. this.clamp();
  1847. };
  1848. BigInteger2.prototype.dAddOffset = function(n, w) {
  1849. if (n == 0) {
  1850. return;
  1851. }
  1852. while (this.t <= w) {
  1853. this[this.t++] = 0;
  1854. }
  1855. this[w] += n;
  1856. while (this[w] >= this.DV) {
  1857. this[w] -= this.DV;
  1858. if (++w >= this.t) {
  1859. this[this.t++] = 0;
  1860. }
  1861. ++this[w];
  1862. }
  1863. };
  1864. BigInteger2.prototype.multiplyLowerTo = function(a, n, r) {
  1865. var i = Math.min(this.t + a.t, n);
  1866. r.s = 0;
  1867. r.t = i;
  1868. while (i > 0) {
  1869. r[--i] = 0;
  1870. }
  1871. for (var j = r.t - this.t; i < j; ++i) {
  1872. r[i + this.t] = this.am(0, a[i], r, i, 0, this.t);
  1873. }
  1874. for (var j = Math.min(a.t, n); i < j; ++i) {
  1875. this.am(0, a[i], r, i, 0, n - i);
  1876. }
  1877. r.clamp();
  1878. };
  1879. BigInteger2.prototype.multiplyUpperTo = function(a, n, r) {
  1880. --n;
  1881. var i = r.t = this.t + a.t - n;
  1882. r.s = 0;
  1883. while (--i >= 0) {
  1884. r[i] = 0;
  1885. }
  1886. for (i = Math.max(n - this.t, 0); i < a.t; ++i) {
  1887. r[this.t + i - n] = this.am(n - i, a[i], r, 0, 0, this.t + i - n);
  1888. }
  1889. r.clamp();
  1890. r.drShiftTo(1, r);
  1891. };
  1892. BigInteger2.prototype.modInt = function(n) {
  1893. if (n <= 0) {
  1894. return 0;
  1895. }
  1896. var d = this.DV % n;
  1897. var r = this.s < 0 ? n - 1 : 0;
  1898. if (this.t > 0) {
  1899. if (d == 0) {
  1900. r = this[0] % n;
  1901. } else {
  1902. for (var i = this.t - 1; i >= 0; --i) {
  1903. r = (d * r + this[i]) % n;
  1904. }
  1905. }
  1906. }
  1907. return r;
  1908. };
  1909. BigInteger2.prototype.millerRabin = function(t) {
  1910. var n1 = this.subtract(BigInteger2.ONE);
  1911. var k = n1.getLowestSetBit();
  1912. if (k <= 0) {
  1913. return false;
  1914. }
  1915. var r = n1.shiftRight(k);
  1916. t = t + 1 >> 1;
  1917. if (t > lowprimes.length) {
  1918. t = lowprimes.length;
  1919. }
  1920. var a = nbi();
  1921. for (var i = 0; i < t; ++i) {
  1922. a.fromInt(lowprimes[Math.floor(Math.random() * lowprimes.length)]);
  1923. var y = a.modPow(r, this);
  1924. if (y.compareTo(BigInteger2.ONE) != 0 && y.compareTo(n1) != 0) {
  1925. var j = 1;
  1926. while (j++ < k && y.compareTo(n1) != 0) {
  1927. y = y.modPowInt(2, this);
  1928. if (y.compareTo(BigInteger2.ONE) == 0) {
  1929. return false;
  1930. }
  1931. }
  1932. if (y.compareTo(n1) != 0) {
  1933. return false;
  1934. }
  1935. }
  1936. }
  1937. return true;
  1938. };
  1939. BigInteger2.prototype.square = function() {
  1940. var r = nbi();
  1941. this.squareTo(r);
  1942. return r;
  1943. };
  1944. BigInteger2.prototype.gcda = function(a, callback) {
  1945. var x = this.s < 0 ? this.negate() : this.clone();
  1946. var y = a.s < 0 ? a.negate() : a.clone();
  1947. if (x.compareTo(y) < 0) {
  1948. var t = x;
  1949. x = y;
  1950. y = t;
  1951. }
  1952. var i = x.getLowestSetBit();
  1953. var g = y.getLowestSetBit();
  1954. if (g < 0) {
  1955. callback(x);
  1956. return;
  1957. }
  1958. if (i < g) {
  1959. g = i;
  1960. }
  1961. if (g > 0) {
  1962. x.rShiftTo(g, x);
  1963. y.rShiftTo(g, y);
  1964. }
  1965. var gcda1 = function() {
  1966. if ((i = x.getLowestSetBit()) > 0) {
  1967. x.rShiftTo(i, x);
  1968. }
  1969. if ((i = y.getLowestSetBit()) > 0) {
  1970. y.rShiftTo(i, y);
  1971. }
  1972. if (x.compareTo(y) >= 0) {
  1973. x.subTo(y, x);
  1974. x.rShiftTo(1, x);
  1975. } else {
  1976. y.subTo(x, y);
  1977. y.rShiftTo(1, y);
  1978. }
  1979. if (!(x.signum() > 0)) {
  1980. if (g > 0) {
  1981. y.lShiftTo(g, y);
  1982. }
  1983. setTimeout(function() {
  1984. callback(y);
  1985. }, 0);
  1986. } else {
  1987. setTimeout(gcda1, 0);
  1988. }
  1989. };
  1990. setTimeout(gcda1, 10);
  1991. };
  1992. BigInteger2.prototype.fromNumberAsync = function(a, b, c, callback) {
  1993. if ("number" == typeof b) {
  1994. if (a < 2) {
  1995. this.fromInt(1);
  1996. } else {
  1997. this.fromNumber(a, c);
  1998. if (!this.testBit(a - 1)) {
  1999. this.bitwiseTo(BigInteger2.ONE.shiftLeft(a - 1), op_or, this);
  2000. }
  2001. if (this.isEven()) {
  2002. this.dAddOffset(1, 0);
  2003. }
  2004. var bnp_1 = this;
  2005. var bnpfn1_1 = function() {
  2006. bnp_1.dAddOffset(2, 0);
  2007. if (bnp_1.bitLength() > a) {
  2008. bnp_1.subTo(BigInteger2.ONE.shiftLeft(a - 1), bnp_1);
  2009. }
  2010. if (bnp_1.isProbablePrime(b)) {
  2011. setTimeout(function() {
  2012. callback();
  2013. }, 0);
  2014. } else {
  2015. setTimeout(bnpfn1_1, 0);
  2016. }
  2017. };
  2018. setTimeout(bnpfn1_1, 0);
  2019. }
  2020. } else {
  2021. var x = [];
  2022. var t = a & 7;
  2023. x.length = (a >> 3) + 1;
  2024. b.nextBytes(x);
  2025. if (t > 0) {
  2026. x[0] &= (1 << t) - 1;
  2027. } else {
  2028. x[0] = 0;
  2029. }
  2030. this.fromString(x, 256);
  2031. }
  2032. };
  2033. return BigInteger2;
  2034. }()
  2035. );
  2036. var NullExp = (
  2037. /** @class */
  2038. function() {
  2039. function NullExp2() {
  2040. }
  2041. NullExp2.prototype.convert = function(x) {
  2042. return x;
  2043. };
  2044. NullExp2.prototype.revert = function(x) {
  2045. return x;
  2046. };
  2047. NullExp2.prototype.mulTo = function(x, y, r) {
  2048. x.multiplyTo(y, r);
  2049. };
  2050. NullExp2.prototype.sqrTo = function(x, r) {
  2051. x.squareTo(r);
  2052. };
  2053. return NullExp2;
  2054. }()
  2055. );
  2056. var Classic = (
  2057. /** @class */
  2058. function() {
  2059. function Classic2(m) {
  2060. this.m = m;
  2061. }
  2062. Classic2.prototype.convert = function(x) {
  2063. if (x.s < 0 || x.compareTo(this.m) >= 0) {
  2064. return x.mod(this.m);
  2065. } else {
  2066. return x;
  2067. }
  2068. };
  2069. Classic2.prototype.revert = function(x) {
  2070. return x;
  2071. };
  2072. Classic2.prototype.reduce = function(x) {
  2073. x.divRemTo(this.m, null, x);
  2074. };
  2075. Classic2.prototype.mulTo = function(x, y, r) {
  2076. x.multiplyTo(y, r);
  2077. this.reduce(r);
  2078. };
  2079. Classic2.prototype.sqrTo = function(x, r) {
  2080. x.squareTo(r);
  2081. this.reduce(r);
  2082. };
  2083. return Classic2;
  2084. }()
  2085. );
  2086. var Montgomery = (
  2087. /** @class */
  2088. function() {
  2089. function Montgomery2(m) {
  2090. this.m = m;
  2091. this.mp = m.invDigit();
  2092. this.mpl = this.mp & 32767;
  2093. this.mph = this.mp >> 15;
  2094. this.um = (1 << m.DB - 15) - 1;
  2095. this.mt2 = 2 * m.t;
  2096. }
  2097. Montgomery2.prototype.convert = function(x) {
  2098. var r = nbi();
  2099. x.abs().dlShiftTo(this.m.t, r);
  2100. r.divRemTo(this.m, null, r);
  2101. if (x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) {
  2102. this.m.subTo(r, r);
  2103. }
  2104. return r;
  2105. };
  2106. Montgomery2.prototype.revert = function(x) {
  2107. var r = nbi();
  2108. x.copyTo(r);
  2109. this.reduce(r);
  2110. return r;
  2111. };
  2112. Montgomery2.prototype.reduce = function(x) {
  2113. while (x.t <= this.mt2) {
  2114. x[x.t++] = 0;
  2115. }
  2116. for (var i = 0; i < this.m.t; ++i) {
  2117. var j = x[i] & 32767;
  2118. var u0 = j * this.mpl + ((j * this.mph + (x[i] >> 15) * this.mpl & this.um) << 15) & x.DM;
  2119. j = i + this.m.t;
  2120. x[j] += this.m.am(0, u0, x, i, 0, this.m.t);
  2121. while (x[j] >= x.DV) {
  2122. x[j] -= x.DV;
  2123. x[++j]++;
  2124. }
  2125. }
  2126. x.clamp();
  2127. x.drShiftTo(this.m.t, x);
  2128. if (x.compareTo(this.m) >= 0) {
  2129. x.subTo(this.m, x);
  2130. }
  2131. };
  2132. Montgomery2.prototype.mulTo = function(x, y, r) {
  2133. x.multiplyTo(y, r);
  2134. this.reduce(r);
  2135. };
  2136. Montgomery2.prototype.sqrTo = function(x, r) {
  2137. x.squareTo(r);
  2138. this.reduce(r);
  2139. };
  2140. return Montgomery2;
  2141. }()
  2142. );
  2143. var Barrett = (
  2144. /** @class */
  2145. function() {
  2146. function Barrett2(m) {
  2147. this.m = m;
  2148. this.r2 = nbi();
  2149. this.q3 = nbi();
  2150. BigInteger.ONE.dlShiftTo(2 * m.t, this.r2);
  2151. this.mu = this.r2.divide(m);
  2152. }
  2153. Barrett2.prototype.convert = function(x) {
  2154. if (x.s < 0 || x.t > 2 * this.m.t) {
  2155. return x.mod(this.m);
  2156. } else if (x.compareTo(this.m) < 0) {
  2157. return x;
  2158. } else {
  2159. var r = nbi();
  2160. x.copyTo(r);
  2161. this.reduce(r);
  2162. return r;
  2163. }
  2164. };
  2165. Barrett2.prototype.revert = function(x) {
  2166. return x;
  2167. };
  2168. Barrett2.prototype.reduce = function(x) {
  2169. x.drShiftTo(this.m.t - 1, this.r2);
  2170. if (x.t > this.m.t + 1) {
  2171. x.t = this.m.t + 1;
  2172. x.clamp();
  2173. }
  2174. this.mu.multiplyUpperTo(this.r2, this.m.t + 1, this.q3);
  2175. this.m.multiplyLowerTo(this.q3, this.m.t + 1, this.r2);
  2176. while (x.compareTo(this.r2) < 0) {
  2177. x.dAddOffset(1, this.m.t + 1);
  2178. }
  2179. x.subTo(this.r2, x);
  2180. while (x.compareTo(this.m) >= 0) {
  2181. x.subTo(this.m, x);
  2182. }
  2183. };
  2184. Barrett2.prototype.mulTo = function(x, y, r) {
  2185. x.multiplyTo(y, r);
  2186. this.reduce(r);
  2187. };
  2188. Barrett2.prototype.sqrTo = function(x, r) {
  2189. x.squareTo(r);
  2190. this.reduce(r);
  2191. };
  2192. return Barrett2;
  2193. }()
  2194. );
  2195. function nbi() {
  2196. return new BigInteger(null);
  2197. }
  2198. function parseBigInt(str, r) {
  2199. return new BigInteger(str, r);
  2200. }
  2201. var inBrowser = typeof navigator !== "undefined";
  2202. if (inBrowser && j_lm && navigator.appName == "Microsoft Internet Explorer") {
  2203. BigInteger.prototype.am = function am2(i, x, w, j, c, n) {
  2204. var xl = x & 32767;
  2205. var xh = x >> 15;
  2206. while (--n >= 0) {
  2207. var l = this[i] & 32767;
  2208. var h = this[i++] >> 15;
  2209. var m = xh * l + h * xl;
  2210. l = xl * l + ((m & 32767) << 15) + w[j] + (c & 1073741823);
  2211. c = (l >>> 30) + (m >>> 15) + xh * h + (c >>> 30);
  2212. w[j++] = l & 1073741823;
  2213. }
  2214. return c;
  2215. };
  2216. dbits = 30;
  2217. } else if (inBrowser && j_lm && navigator.appName != "Netscape") {
  2218. BigInteger.prototype.am = function am1(i, x, w, j, c, n) {
  2219. while (--n >= 0) {
  2220. var v = x * this[i++] + w[j] + c;
  2221. c = Math.floor(v / 67108864);
  2222. w[j++] = v & 67108863;
  2223. }
  2224. return c;
  2225. };
  2226. dbits = 26;
  2227. } else {
  2228. BigInteger.prototype.am = function am3(i, x, w, j, c, n) {
  2229. var xl = x & 16383;
  2230. var xh = x >> 14;
  2231. while (--n >= 0) {
  2232. var l = this[i] & 16383;
  2233. var h = this[i++] >> 14;
  2234. var m = xh * l + h * xl;
  2235. l = xl * l + ((m & 16383) << 14) + w[j] + c;
  2236. c = (l >> 28) + (m >> 14) + xh * h;
  2237. w[j++] = l & 268435455;
  2238. }
  2239. return c;
  2240. };
  2241. dbits = 28;
  2242. }
  2243. BigInteger.prototype.DB = dbits;
  2244. BigInteger.prototype.DM = (1 << dbits) - 1;
  2245. BigInteger.prototype.DV = 1 << dbits;
  2246. var BI_FP = 52;
  2247. BigInteger.prototype.FV = Math.pow(2, BI_FP);
  2248. BigInteger.prototype.F1 = BI_FP - dbits;
  2249. BigInteger.prototype.F2 = 2 * dbits - BI_FP;
  2250. var BI_RC = [];
  2251. var rr;
  2252. var vv;
  2253. rr = "0".charCodeAt(0);
  2254. for (vv = 0; vv <= 9; ++vv) {
  2255. BI_RC[rr++] = vv;
  2256. }
  2257. rr = "a".charCodeAt(0);
  2258. for (vv = 10; vv < 36; ++vv) {
  2259. BI_RC[rr++] = vv;
  2260. }
  2261. rr = "A".charCodeAt(0);
  2262. for (vv = 10; vv < 36; ++vv) {
  2263. BI_RC[rr++] = vv;
  2264. }
  2265. function intAt(s, i) {
  2266. var c = BI_RC[s.charCodeAt(i)];
  2267. return c == null ? -1 : c;
  2268. }
  2269. function nbv(i) {
  2270. var r = nbi();
  2271. r.fromInt(i);
  2272. return r;
  2273. }
  2274. function nbits(x) {
  2275. var r = 1;
  2276. var t;
  2277. if ((t = x >>> 16) != 0) {
  2278. x = t;
  2279. r += 16;
  2280. }
  2281. if ((t = x >> 8) != 0) {
  2282. x = t;
  2283. r += 8;
  2284. }
  2285. if ((t = x >> 4) != 0) {
  2286. x = t;
  2287. r += 4;
  2288. }
  2289. if ((t = x >> 2) != 0) {
  2290. x = t;
  2291. r += 2;
  2292. }
  2293. if ((t = x >> 1) != 0) {
  2294. x = t;
  2295. r += 1;
  2296. }
  2297. return r;
  2298. }
  2299. BigInteger.ZERO = nbv(0);
  2300. BigInteger.ONE = nbv(1);
  2301. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/prng4.js
  2302. var Arcfour = (
  2303. /** @class */
  2304. function() {
  2305. function Arcfour2() {
  2306. this.i = 0;
  2307. this.j = 0;
  2308. this.S = [];
  2309. }
  2310. Arcfour2.prototype.init = function(key) {
  2311. var i;
  2312. var j;
  2313. var t;
  2314. for (i = 0; i < 256; ++i) {
  2315. this.S[i] = i;
  2316. }
  2317. j = 0;
  2318. for (i = 0; i < 256; ++i) {
  2319. j = j + this.S[i] + key[i % key.length] & 255;
  2320. t = this.S[i];
  2321. this.S[i] = this.S[j];
  2322. this.S[j] = t;
  2323. }
  2324. this.i = 0;
  2325. this.j = 0;
  2326. };
  2327. Arcfour2.prototype.next = function() {
  2328. var t;
  2329. this.i = this.i + 1 & 255;
  2330. this.j = this.j + this.S[this.i] & 255;
  2331. t = this.S[this.i];
  2332. this.S[this.i] = this.S[this.j];
  2333. this.S[this.j] = t;
  2334. return this.S[t + this.S[this.i] & 255];
  2335. };
  2336. return Arcfour2;
  2337. }()
  2338. );
  2339. function prng_newstate() {
  2340. return new Arcfour();
  2341. }
  2342. var rng_psize = 256;
  2343. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/rng.js
  2344. var rng_state;
  2345. var rng_pool = null;
  2346. var rng_pptr;
  2347. if (rng_pool == null) {
  2348. rng_pool = [];
  2349. rng_pptr = 0;
  2350. t = void 0;
  2351. if (typeof window !== "undefined" && window.crypto && window.crypto.getRandomValues) {
  2352. z = new Uint32Array(256);
  2353. window.crypto.getRandomValues(z);
  2354. for (t = 0; t < z.length; ++t) {
  2355. rng_pool[rng_pptr++] = z[t] & 255;
  2356. }
  2357. }
  2358. count = 0;
  2359. onMouseMoveListener_1 = function(ev) {
  2360. count = count || 0;
  2361. if (count >= 256 || rng_pptr >= rng_psize) {
  2362. if (window.removeEventListener) {
  2363. window.removeEventListener("mousemove", onMouseMoveListener_1, false);
  2364. } else if (window.detachEvent) {
  2365. window.detachEvent("onmousemove", onMouseMoveListener_1);
  2366. }
  2367. return;
  2368. }
  2369. try {
  2370. var mouseCoordinates = ev.x + ev.y;
  2371. rng_pool[rng_pptr++] = mouseCoordinates & 255;
  2372. count += 1;
  2373. } catch (e) {
  2374. }
  2375. };
  2376. if (typeof window !== "undefined") {
  2377. if (window.addEventListener) {
  2378. window.addEventListener("mousemove", onMouseMoveListener_1, false);
  2379. } else if (window.attachEvent) {
  2380. window.attachEvent("onmousemove", onMouseMoveListener_1);
  2381. }
  2382. }
  2383. }
  2384. var t;
  2385. var z;
  2386. var count;
  2387. var onMouseMoveListener_1;
  2388. function rng_get_byte() {
  2389. if (rng_state == null) {
  2390. rng_state = prng_newstate();
  2391. while (rng_pptr < rng_psize) {
  2392. var random = Math.floor(65536 * Math.random());
  2393. rng_pool[rng_pptr++] = random & 255;
  2394. }
  2395. rng_state.init(rng_pool);
  2396. for (rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr) {
  2397. rng_pool[rng_pptr] = 0;
  2398. }
  2399. rng_pptr = 0;
  2400. }
  2401. return rng_state.next();
  2402. }
  2403. var SecureRandom = (
  2404. /** @class */
  2405. function() {
  2406. function SecureRandom2() {
  2407. }
  2408. SecureRandom2.prototype.nextBytes = function(ba) {
  2409. for (var i = 0; i < ba.length; ++i) {
  2410. ba[i] = rng_get_byte();
  2411. }
  2412. };
  2413. return SecureRandom2;
  2414. }()
  2415. );
  2416. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsbn/rsa.js
  2417. function pkcs1pad1(s, n) {
  2418. if (n < s.length + 22) {
  2419. console.error("Message too long for RSA");
  2420. return null;
  2421. }
  2422. var len = n - s.length - 6;
  2423. var filler = "";
  2424. for (var f = 0; f < len; f += 2) {
  2425. filler += "ff";
  2426. }
  2427. var m = "0001" + filler + "00" + s;
  2428. return parseBigInt(m, 16);
  2429. }
  2430. function pkcs1pad2(s, n) {
  2431. if (n < s.length + 11) {
  2432. console.error("Message too long for RSA");
  2433. return null;
  2434. }
  2435. var ba = [];
  2436. var i = s.length - 1;
  2437. while (i >= 0 && n > 0) {
  2438. var c = s.charCodeAt(i--);
  2439. if (c < 128) {
  2440. ba[--n] = c;
  2441. } else if (c > 127 && c < 2048) {
  2442. ba[--n] = c & 63 | 128;
  2443. ba[--n] = c >> 6 | 192;
  2444. } else {
  2445. ba[--n] = c & 63 | 128;
  2446. ba[--n] = c >> 6 & 63 | 128;
  2447. ba[--n] = c >> 12 | 224;
  2448. }
  2449. }
  2450. ba[--n] = 0;
  2451. var rng = new SecureRandom();
  2452. var x = [];
  2453. while (n > 2) {
  2454. x[0] = 0;
  2455. while (x[0] == 0) {
  2456. rng.nextBytes(x);
  2457. }
  2458. ba[--n] = x[0];
  2459. }
  2460. ba[--n] = 2;
  2461. ba[--n] = 0;
  2462. return new BigInteger(ba);
  2463. }
  2464. var RSAKey = (
  2465. /** @class */
  2466. function() {
  2467. function RSAKey2() {
  2468. this.n = null;
  2469. this.e = 0;
  2470. this.d = null;
  2471. this.p = null;
  2472. this.q = null;
  2473. this.dmp1 = null;
  2474. this.dmq1 = null;
  2475. this.coeff = null;
  2476. }
  2477. RSAKey2.prototype.doPublic = function(x) {
  2478. return x.modPowInt(this.e, this.n);
  2479. };
  2480. RSAKey2.prototype.doPrivate = function(x) {
  2481. if (this.p == null || this.q == null) {
  2482. return x.modPow(this.d, this.n);
  2483. }
  2484. var xp = x.mod(this.p).modPow(this.dmp1, this.p);
  2485. var xq = x.mod(this.q).modPow(this.dmq1, this.q);
  2486. while (xp.compareTo(xq) < 0) {
  2487. xp = xp.add(this.p);
  2488. }
  2489. return xp.subtract(xq).multiply(this.coeff).mod(this.p).multiply(this.q).add(xq);
  2490. };
  2491. RSAKey2.prototype.setPublic = function(N, E) {
  2492. if (N != null && E != null && N.length > 0 && E.length > 0) {
  2493. this.n = parseBigInt(N, 16);
  2494. this.e = parseInt(E, 16);
  2495. } else {
  2496. console.error("Invalid RSA public key");
  2497. }
  2498. };
  2499. RSAKey2.prototype.encrypt = function(text) {
  2500. var maxLength = this.n.bitLength() + 7 >> 3;
  2501. var m = pkcs1pad2(text, maxLength);
  2502. if (m == null) {
  2503. return null;
  2504. }
  2505. var c = this.doPublic(m);
  2506. if (c == null) {
  2507. return null;
  2508. }
  2509. var h = c.toString(16);
  2510. var length = h.length;
  2511. for (var i = 0; i < maxLength * 2 - length; i++) {
  2512. h = "0" + h;
  2513. }
  2514. return h;
  2515. };
  2516. RSAKey2.prototype.setPrivate = function(N, E, D) {
  2517. if (N != null && E != null && N.length > 0 && E.length > 0) {
  2518. this.n = parseBigInt(N, 16);
  2519. this.e = parseInt(E, 16);
  2520. this.d = parseBigInt(D, 16);
  2521. } else {
  2522. console.error("Invalid RSA private key");
  2523. }
  2524. };
  2525. RSAKey2.prototype.setPrivateEx = function(N, E, D, P, Q, DP, DQ, C) {
  2526. if (N != null && E != null && N.length > 0 && E.length > 0) {
  2527. this.n = parseBigInt(N, 16);
  2528. this.e = parseInt(E, 16);
  2529. this.d = parseBigInt(D, 16);
  2530. this.p = parseBigInt(P, 16);
  2531. this.q = parseBigInt(Q, 16);
  2532. this.dmp1 = parseBigInt(DP, 16);
  2533. this.dmq1 = parseBigInt(DQ, 16);
  2534. this.coeff = parseBigInt(C, 16);
  2535. } else {
  2536. console.error("Invalid RSA private key");
  2537. }
  2538. };
  2539. RSAKey2.prototype.generate = function(B, E) {
  2540. var rng = new SecureRandom();
  2541. var qs = B >> 1;
  2542. this.e = parseInt(E, 16);
  2543. var ee = new BigInteger(E, 16);
  2544. for (; ; ) {
  2545. for (; ; ) {
  2546. this.p = new BigInteger(B - qs, 1, rng);
  2547. if (this.p.subtract(BigInteger.ONE).gcd(ee).compareTo(BigInteger.ONE) == 0 && this.p.isProbablePrime(10)) {
  2548. break;
  2549. }
  2550. }
  2551. for (; ; ) {
  2552. this.q = new BigInteger(qs, 1, rng);
  2553. if (this.q.subtract(BigInteger.ONE).gcd(ee).compareTo(BigInteger.ONE) == 0 && this.q.isProbablePrime(10)) {
  2554. break;
  2555. }
  2556. }
  2557. if (this.p.compareTo(this.q) <= 0) {
  2558. var t = this.p;
  2559. this.p = this.q;
  2560. this.q = t;
  2561. }
  2562. var p1 = this.p.subtract(BigInteger.ONE);
  2563. var q1 = this.q.subtract(BigInteger.ONE);
  2564. var phi = p1.multiply(q1);
  2565. if (phi.gcd(ee).compareTo(BigInteger.ONE) == 0) {
  2566. this.n = this.p.multiply(this.q);
  2567. this.d = ee.modInverse(phi);
  2568. this.dmp1 = this.d.mod(p1);
  2569. this.dmq1 = this.d.mod(q1);
  2570. this.coeff = this.q.modInverse(this.p);
  2571. break;
  2572. }
  2573. }
  2574. };
  2575. RSAKey2.prototype.decrypt = function(ctext) {
  2576. var c = parseBigInt(ctext, 16);
  2577. var m = this.doPublic(c);
  2578. if (m == null) {
  2579. return null;
  2580. }
  2581. return pkcs1unpad2(m, this.n.bitLength() + 7 >> 3);
  2582. };
  2583. RSAKey2.prototype.generateAsync = function(B, E, callback) {
  2584. var rng = new SecureRandom();
  2585. var qs = B >> 1;
  2586. this.e = parseInt(E, 16);
  2587. var ee = new BigInteger(E, 16);
  2588. var rsa = this;
  2589. var loop1 = function() {
  2590. var loop4 = function() {
  2591. if (rsa.p.compareTo(rsa.q) <= 0) {
  2592. var t = rsa.p;
  2593. rsa.p = rsa.q;
  2594. rsa.q = t;
  2595. }
  2596. var p1 = rsa.p.subtract(BigInteger.ONE);
  2597. var q1 = rsa.q.subtract(BigInteger.ONE);
  2598. var phi = p1.multiply(q1);
  2599. if (phi.gcd(ee).compareTo(BigInteger.ONE) == 0) {
  2600. rsa.n = rsa.p.multiply(rsa.q);
  2601. rsa.d = ee.modInverse(phi);
  2602. rsa.dmp1 = rsa.d.mod(p1);
  2603. rsa.dmq1 = rsa.d.mod(q1);
  2604. rsa.coeff = rsa.q.modInverse(rsa.p);
  2605. setTimeout(function() {
  2606. callback();
  2607. }, 0);
  2608. } else {
  2609. setTimeout(loop1, 0);
  2610. }
  2611. };
  2612. var loop3 = function() {
  2613. rsa.q = nbi();
  2614. rsa.q.fromNumberAsync(qs, 1, rng, function() {
  2615. rsa.q.subtract(BigInteger.ONE).gcda(ee, function(r) {
  2616. if (r.compareTo(BigInteger.ONE) == 0 && rsa.q.isProbablePrime(10)) {
  2617. setTimeout(loop4, 0);
  2618. } else {
  2619. setTimeout(loop3, 0);
  2620. }
  2621. });
  2622. });
  2623. };
  2624. var loop2 = function() {
  2625. rsa.p = nbi();
  2626. rsa.p.fromNumberAsync(B - qs, 1, rng, function() {
  2627. rsa.p.subtract(BigInteger.ONE).gcda(ee, function(r) {
  2628. if (r.compareTo(BigInteger.ONE) == 0 && rsa.p.isProbablePrime(10)) {
  2629. setTimeout(loop3, 0);
  2630. } else {
  2631. setTimeout(loop2, 0);
  2632. }
  2633. });
  2634. });
  2635. };
  2636. setTimeout(loop2, 0);
  2637. };
  2638. setTimeout(loop1, 0);
  2639. };
  2640. RSAKey2.prototype.sign = function(text, digestMethod, digestName) {
  2641. var header = getDigestHeader(digestName);
  2642. var digest = header + digestMethod(text).toString();
  2643. var m = pkcs1pad1(digest, this.n.bitLength() / 4);
  2644. if (m == null) {
  2645. return null;
  2646. }
  2647. var c = this.doPrivate(m);
  2648. if (c == null) {
  2649. return null;
  2650. }
  2651. var h = c.toString(16);
  2652. if ((h.length & 1) == 0) {
  2653. return h;
  2654. } else {
  2655. return "0" + h;
  2656. }
  2657. };
  2658. RSAKey2.prototype.verify = function(text, signature, digestMethod) {
  2659. var c = parseBigInt(signature, 16);
  2660. var m = this.doPublic(c);
  2661. if (m == null) {
  2662. return null;
  2663. }
  2664. var unpadded = m.toString(16).replace(/^1f+00/, "");
  2665. var digest = removeDigestHeader(unpadded);
  2666. return digest == digestMethod(text).toString();
  2667. };
  2668. return RSAKey2;
  2669. }()
  2670. );
  2671. function pkcs1unpad2(d, n) {
  2672. var b = d.toByteArray();
  2673. var i = 0;
  2674. while (i < b.length && b[i] == 0) {
  2675. ++i;
  2676. }
  2677. ++i;
  2678. while (b[i] != 0) {
  2679. if (++i >= b.length) {
  2680. return null;
  2681. }
  2682. }
  2683. var ret = "";
  2684. while (++i < b.length) {
  2685. var c = b[i] & 255;
  2686. if (c < 128) {
  2687. ret += String.fromCharCode(c);
  2688. } else if (c > 191 && c < 224) {
  2689. ret += String.fromCharCode((c & 31) << 6 | b[i + 1] & 63);
  2690. ++i;
  2691. } else {
  2692. ret += String.fromCharCode((c & 15) << 12 | (b[i + 1] & 63) << 6 | b[i + 2] & 63);
  2693. i += 2;
  2694. }
  2695. }
  2696. return ret;
  2697. }
  2698. var DIGEST_HEADERS = {
  2699. md2: "3020300c06082a864886f70d020205000410",
  2700. md5: "3020300c06082a864886f70d020505000410",
  2701. sha1: "3021300906052b0e03021a05000414",
  2702. sha224: "302d300d06096086480165030402040500041c",
  2703. sha256: "3031300d060960864801650304020105000420",
  2704. sha384: "3041300d060960864801650304020205000430",
  2705. sha512: "3051300d060960864801650304020305000440",
  2706. ripemd160: "3021300906052b2403020105000414"
  2707. };
  2708. function getDigestHeader(name) {
  2709. return DIGEST_HEADERS[name] || "";
  2710. }
  2711. function removeDigestHeader(str) {
  2712. for (var name_1 in DIGEST_HEADERS) {
  2713. if (DIGEST_HEADERS.hasOwnProperty(name_1)) {
  2714. var header = DIGEST_HEADERS[name_1];
  2715. var len = header.length;
  2716. if (str.substr(0, len) == header) {
  2717. return str.substr(len);
  2718. }
  2719. }
  2720. }
  2721. return str;
  2722. }
  2723. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsrsasign/yahoo.js
  2724. var YAHOO = {};
  2725. YAHOO.lang = {
  2726. /**
  2727. * Utility to set up the prototype, constructor and superclass properties to
  2728. * support an inheritance strategy that can chain constructors and methods.
  2729. * Static members will not be inherited.
  2730. *
  2731. * @method extend
  2732. * @static
  2733. * @param {Function} subc the object to modify
  2734. * @param {Function} superc the object to inherit
  2735. * @param {Object} overrides additional properties/methods to add to the
  2736. * subclass prototype. These will override the
  2737. * matching items obtained from the superclass
  2738. * if present.
  2739. */
  2740. extend: function(subc, superc, overrides) {
  2741. if (!superc || !subc) {
  2742. throw new Error("YAHOO.lang.extend failed, please check that all dependencies are included.");
  2743. }
  2744. var F = function() {
  2745. };
  2746. F.prototype = superc.prototype;
  2747. subc.prototype = new F();
  2748. subc.prototype.constructor = subc;
  2749. subc.superclass = superc.prototype;
  2750. if (superc.prototype.constructor == Object.prototype.constructor) {
  2751. superc.prototype.constructor = superc;
  2752. }
  2753. if (overrides) {
  2754. var i;
  2755. for (i in overrides) {
  2756. subc.prototype[i] = overrides[i];
  2757. }
  2758. var _IEEnumFix = function() {
  2759. }, ADD = ["toString", "valueOf"];
  2760. try {
  2761. if (/MSIE/.test(navigator.userAgent)) {
  2762. _IEEnumFix = function(r, s) {
  2763. for (i = 0; i < ADD.length; i = i + 1) {
  2764. var fname = ADD[i], f = s[fname];
  2765. if (typeof f === "function" && f != Object.prototype[fname]) {
  2766. r[fname] = f;
  2767. }
  2768. }
  2769. };
  2770. }
  2771. } catch (ex) {
  2772. }
  2773. ;
  2774. _IEEnumFix(subc.prototype, overrides);
  2775. }
  2776. }
  2777. };
  2778. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/lib/jsrsasign/asn1-1.0.js
  2779. var KJUR = {};
  2780. if (typeof KJUR.asn1 == "undefined" || !KJUR.asn1)
  2781. KJUR.asn1 = {};
  2782. KJUR.asn1.ASN1Util = new function() {
  2783. this.integerToByteHex = function(i) {
  2784. var h = i.toString(16);
  2785. if (h.length % 2 == 1)
  2786. h = "0" + h;
  2787. return h;
  2788. };
  2789. this.bigIntToMinTwosComplementsHex = function(bigIntegerValue) {
  2790. var h = bigIntegerValue.toString(16);
  2791. if (h.substr(0, 1) != "-") {
  2792. if (h.length % 2 == 1) {
  2793. h = "0" + h;
  2794. } else {
  2795. if (!h.match(/^[0-7]/)) {
  2796. h = "00" + h;
  2797. }
  2798. }
  2799. } else {
  2800. var hPos = h.substr(1);
  2801. var xorLen = hPos.length;
  2802. if (xorLen % 2 == 1) {
  2803. xorLen += 1;
  2804. } else {
  2805. if (!h.match(/^[0-7]/)) {
  2806. xorLen += 2;
  2807. }
  2808. }
  2809. var hMask = "";
  2810. for (var i = 0; i < xorLen; i++) {
  2811. hMask += "f";
  2812. }
  2813. var biMask = new BigInteger(hMask, 16);
  2814. var biNeg = biMask.xor(bigIntegerValue).add(BigInteger.ONE);
  2815. h = biNeg.toString(16).replace(/^-/, "");
  2816. }
  2817. return h;
  2818. };
  2819. this.getPEMStringFromHex = function(dataHex, pemHeader) {
  2820. return hextopem(dataHex, pemHeader);
  2821. };
  2822. this.newObject = function(param) {
  2823. var _KJUR = KJUR, _KJUR_asn1 = _KJUR.asn1, _DERBoolean = _KJUR_asn1.DERBoolean, _DERInteger = _KJUR_asn1.DERInteger, _DERBitString = _KJUR_asn1.DERBitString, _DEROctetString = _KJUR_asn1.DEROctetString, _DERNull = _KJUR_asn1.DERNull, _DERObjectIdentifier = _KJUR_asn1.DERObjectIdentifier, _DEREnumerated = _KJUR_asn1.DEREnumerated, _DERUTF8String = _KJUR_asn1.DERUTF8String, _DERNumericString = _KJUR_asn1.DERNumericString, _DERPrintableString = _KJUR_asn1.DERPrintableString, _DERTeletexString = _KJUR_asn1.DERTeletexString, _DERIA5String = _KJUR_asn1.DERIA5String, _DERUTCTime = _KJUR_asn1.DERUTCTime, _DERGeneralizedTime = _KJUR_asn1.DERGeneralizedTime, _DERSequence = _KJUR_asn1.DERSequence, _DERSet = _KJUR_asn1.DERSet, _DERTaggedObject = _KJUR_asn1.DERTaggedObject, _newObject = _KJUR_asn1.ASN1Util.newObject;
  2824. var keys = Object.keys(param);
  2825. if (keys.length != 1)
  2826. throw "key of param shall be only one.";
  2827. var key = keys[0];
  2828. if (":bool:int:bitstr:octstr:null:oid:enum:utf8str:numstr:prnstr:telstr:ia5str:utctime:gentime:seq:set:tag:".indexOf(":" + key + ":") == -1)
  2829. throw "undefined key: " + key;
  2830. if (key == "bool")
  2831. return new _DERBoolean(param[key]);
  2832. if (key == "int")
  2833. return new _DERInteger(param[key]);
  2834. if (key == "bitstr")
  2835. return new _DERBitString(param[key]);
  2836. if (key == "octstr")
  2837. return new _DEROctetString(param[key]);
  2838. if (key == "null")
  2839. return new _DERNull(param[key]);
  2840. if (key == "oid")
  2841. return new _DERObjectIdentifier(param[key]);
  2842. if (key == "enum")
  2843. return new _DEREnumerated(param[key]);
  2844. if (key == "utf8str")
  2845. return new _DERUTF8String(param[key]);
  2846. if (key == "numstr")
  2847. return new _DERNumericString(param[key]);
  2848. if (key == "prnstr")
  2849. return new _DERPrintableString(param[key]);
  2850. if (key == "telstr")
  2851. return new _DERTeletexString(param[key]);
  2852. if (key == "ia5str")
  2853. return new _DERIA5String(param[key]);
  2854. if (key == "utctime")
  2855. return new _DERUTCTime(param[key]);
  2856. if (key == "gentime")
  2857. return new _DERGeneralizedTime(param[key]);
  2858. if (key == "seq") {
  2859. var paramList = param[key];
  2860. var a = [];
  2861. for (var i = 0; i < paramList.length; i++) {
  2862. var asn1Obj = _newObject(paramList[i]);
  2863. a.push(asn1Obj);
  2864. }
  2865. return new _DERSequence({ "array": a });
  2866. }
  2867. if (key == "set") {
  2868. var paramList = param[key];
  2869. var a = [];
  2870. for (var i = 0; i < paramList.length; i++) {
  2871. var asn1Obj = _newObject(paramList[i]);
  2872. a.push(asn1Obj);
  2873. }
  2874. return new _DERSet({ "array": a });
  2875. }
  2876. if (key == "tag") {
  2877. var tagParam = param[key];
  2878. if (Object.prototype.toString.call(tagParam) === "[object Array]" && tagParam.length == 3) {
  2879. var obj = _newObject(tagParam[2]);
  2880. return new _DERTaggedObject({
  2881. tag: tagParam[0],
  2882. explicit: tagParam[1],
  2883. obj
  2884. });
  2885. } else {
  2886. var newParam = {};
  2887. if (tagParam.explicit !== void 0)
  2888. newParam.explicit = tagParam.explicit;
  2889. if (tagParam.tag !== void 0)
  2890. newParam.tag = tagParam.tag;
  2891. if (tagParam.obj === void 0)
  2892. throw "obj shall be specified for 'tag'.";
  2893. newParam.obj = _newObject(tagParam.obj);
  2894. return new _DERTaggedObject(newParam);
  2895. }
  2896. }
  2897. };
  2898. this.jsonToASN1HEX = function(param) {
  2899. var asn1Obj = this.newObject(param);
  2900. return asn1Obj.getEncodedHex();
  2901. };
  2902. }();
  2903. KJUR.asn1.ASN1Util.oidHexToInt = function(hex) {
  2904. var s = "";
  2905. var i01 = parseInt(hex.substr(0, 2), 16);
  2906. var i0 = Math.floor(i01 / 40);
  2907. var i1 = i01 % 40;
  2908. var s = i0 + "." + i1;
  2909. var binbuf = "";
  2910. for (var i = 2; i < hex.length; i += 2) {
  2911. var value = parseInt(hex.substr(i, 2), 16);
  2912. var bin = ("00000000" + value.toString(2)).slice(-8);
  2913. binbuf = binbuf + bin.substr(1, 7);
  2914. if (bin.substr(0, 1) == "0") {
  2915. var bi = new BigInteger(binbuf, 2);
  2916. s = s + "." + bi.toString(10);
  2917. binbuf = "";
  2918. }
  2919. }
  2920. ;
  2921. return s;
  2922. };
  2923. KJUR.asn1.ASN1Util.oidIntToHex = function(oidString) {
  2924. var itox = function(i2) {
  2925. var h2 = i2.toString(16);
  2926. if (h2.length == 1)
  2927. h2 = "0" + h2;
  2928. return h2;
  2929. };
  2930. var roidtox = function(roid) {
  2931. var h2 = "";
  2932. var bi = new BigInteger(roid, 10);
  2933. var b = bi.toString(2);
  2934. var padLen = 7 - b.length % 7;
  2935. if (padLen == 7)
  2936. padLen = 0;
  2937. var bPad = "";
  2938. for (var i2 = 0; i2 < padLen; i2++)
  2939. bPad += "0";
  2940. b = bPad + b;
  2941. for (var i2 = 0; i2 < b.length - 1; i2 += 7) {
  2942. var b8 = b.substr(i2, 7);
  2943. if (i2 != b.length - 7)
  2944. b8 = "1" + b8;
  2945. h2 += itox(parseInt(b8, 2));
  2946. }
  2947. return h2;
  2948. };
  2949. if (!oidString.match(/^[0-9.]+$/)) {
  2950. throw "malformed oid string: " + oidString;
  2951. }
  2952. var h = "";
  2953. var a = oidString.split(".");
  2954. var i0 = parseInt(a[0]) * 40 + parseInt(a[1]);
  2955. h += itox(i0);
  2956. a.splice(0, 2);
  2957. for (var i = 0; i < a.length; i++) {
  2958. h += roidtox(a[i]);
  2959. }
  2960. return h;
  2961. };
  2962. KJUR.asn1.ASN1Object = function() {
  2963. var isModified = true;
  2964. var hTLV = null;
  2965. var hT = "00";
  2966. var hL = "00";
  2967. var hV = "";
  2968. this.getLengthHexFromValue = function() {
  2969. if (typeof this.hV == "undefined" || this.hV == null) {
  2970. throw "this.hV is null or undefined.";
  2971. }
  2972. if (this.hV.length % 2 == 1) {
  2973. throw "value hex must be even length: n=" + hV.length + ",v=" + this.hV;
  2974. }
  2975. var n = this.hV.length / 2;
  2976. var hN = n.toString(16);
  2977. if (hN.length % 2 == 1) {
  2978. hN = "0" + hN;
  2979. }
  2980. if (n < 128) {
  2981. return hN;
  2982. } else {
  2983. var hNlen = hN.length / 2;
  2984. if (hNlen > 15) {
  2985. throw "ASN.1 length too long to represent by 8x: n = " + n.toString(16);
  2986. }
  2987. var head = 128 + hNlen;
  2988. return head.toString(16) + hN;
  2989. }
  2990. };
  2991. this.getEncodedHex = function() {
  2992. if (this.hTLV == null || this.isModified) {
  2993. this.hV = this.getFreshValueHex();
  2994. this.hL = this.getLengthHexFromValue();
  2995. this.hTLV = this.hT + this.hL + this.hV;
  2996. this.isModified = false;
  2997. }
  2998. return this.hTLV;
  2999. };
  3000. this.getValueHex = function() {
  3001. this.getEncodedHex();
  3002. return this.hV;
  3003. };
  3004. this.getFreshValueHex = function() {
  3005. return "";
  3006. };
  3007. };
  3008. KJUR.asn1.DERAbstractString = function(params) {
  3009. KJUR.asn1.DERAbstractString.superclass.constructor.call(this);
  3010. var s = null;
  3011. var hV = null;
  3012. this.getString = function() {
  3013. return this.s;
  3014. };
  3015. this.setString = function(newS) {
  3016. this.hTLV = null;
  3017. this.isModified = true;
  3018. this.s = newS;
  3019. this.hV = stohex(this.s);
  3020. };
  3021. this.setStringHex = function(newHexString) {
  3022. this.hTLV = null;
  3023. this.isModified = true;
  3024. this.s = null;
  3025. this.hV = newHexString;
  3026. };
  3027. this.getFreshValueHex = function() {
  3028. return this.hV;
  3029. };
  3030. if (typeof params != "undefined") {
  3031. if (typeof params == "string") {
  3032. this.setString(params);
  3033. } else if (typeof params["str"] != "undefined") {
  3034. this.setString(params["str"]);
  3035. } else if (typeof params["hex"] != "undefined") {
  3036. this.setStringHex(params["hex"]);
  3037. }
  3038. }
  3039. };
  3040. YAHOO.lang.extend(KJUR.asn1.DERAbstractString, KJUR.asn1.ASN1Object);
  3041. KJUR.asn1.DERAbstractTime = function(params) {
  3042. KJUR.asn1.DERAbstractTime.superclass.constructor.call(this);
  3043. var s = null;
  3044. var date = null;
  3045. this.localDateToUTC = function(d) {
  3046. utc = d.getTime() + d.getTimezoneOffset() * 6e4;
  3047. var utcDate = new Date(utc);
  3048. return utcDate;
  3049. };
  3050. this.formatDate = function(dateObject, type, withMillis) {
  3051. var pad = this.zeroPadding;
  3052. var d = this.localDateToUTC(dateObject);
  3053. var year = String(d.getFullYear());
  3054. if (type == "utc")
  3055. year = year.substr(2, 2);
  3056. var month = pad(String(d.getMonth() + 1), 2);
  3057. var day = pad(String(d.getDate()), 2);
  3058. var hour = pad(String(d.getHours()), 2);
  3059. var min = pad(String(d.getMinutes()), 2);
  3060. var sec = pad(String(d.getSeconds()), 2);
  3061. var s2 = year + month + day + hour + min + sec;
  3062. if (withMillis === true) {
  3063. var millis = d.getMilliseconds();
  3064. if (millis != 0) {
  3065. var sMillis = pad(String(millis), 3);
  3066. sMillis = sMillis.replace(/[0]+$/, "");
  3067. s2 = s2 + "." + sMillis;
  3068. }
  3069. }
  3070. return s2 + "Z";
  3071. };
  3072. this.zeroPadding = function(s2, len) {
  3073. if (s2.length >= len)
  3074. return s2;
  3075. return new Array(len - s2.length + 1).join("0") + s2;
  3076. };
  3077. this.getString = function() {
  3078. return this.s;
  3079. };
  3080. this.setString = function(newS) {
  3081. this.hTLV = null;
  3082. this.isModified = true;
  3083. this.s = newS;
  3084. this.hV = stohex(newS);
  3085. };
  3086. this.setByDateValue = function(year, month, day, hour, min, sec) {
  3087. var dateObject = new Date(Date.UTC(year, month - 1, day, hour, min, sec, 0));
  3088. this.setByDate(dateObject);
  3089. };
  3090. this.getFreshValueHex = function() {
  3091. return this.hV;
  3092. };
  3093. };
  3094. YAHOO.lang.extend(KJUR.asn1.DERAbstractTime, KJUR.asn1.ASN1Object);
  3095. KJUR.asn1.DERAbstractStructured = function(params) {
  3096. KJUR.asn1.DERAbstractString.superclass.constructor.call(this);
  3097. var asn1Array = null;
  3098. this.setByASN1ObjectArray = function(asn1ObjectArray) {
  3099. this.hTLV = null;
  3100. this.isModified = true;
  3101. this.asn1Array = asn1ObjectArray;
  3102. };
  3103. this.appendASN1Object = function(asn1Object) {
  3104. this.hTLV = null;
  3105. this.isModified = true;
  3106. this.asn1Array.push(asn1Object);
  3107. };
  3108. this.asn1Array = new Array();
  3109. if (typeof params != "undefined") {
  3110. if (typeof params["array"] != "undefined") {
  3111. this.asn1Array = params["array"];
  3112. }
  3113. }
  3114. };
  3115. YAHOO.lang.extend(KJUR.asn1.DERAbstractStructured, KJUR.asn1.ASN1Object);
  3116. KJUR.asn1.DERBoolean = function() {
  3117. KJUR.asn1.DERBoolean.superclass.constructor.call(this);
  3118. this.hT = "01";
  3119. this.hTLV = "0101ff";
  3120. };
  3121. YAHOO.lang.extend(KJUR.asn1.DERBoolean, KJUR.asn1.ASN1Object);
  3122. KJUR.asn1.DERInteger = function(params) {
  3123. KJUR.asn1.DERInteger.superclass.constructor.call(this);
  3124. this.hT = "02";
  3125. this.setByBigInteger = function(bigIntegerValue) {
  3126. this.hTLV = null;
  3127. this.isModified = true;
  3128. this.hV = KJUR.asn1.ASN1Util.bigIntToMinTwosComplementsHex(bigIntegerValue);
  3129. };
  3130. this.setByInteger = function(intValue) {
  3131. var bi = new BigInteger(String(intValue), 10);
  3132. this.setByBigInteger(bi);
  3133. };
  3134. this.setValueHex = function(newHexString) {
  3135. this.hV = newHexString;
  3136. };
  3137. this.getFreshValueHex = function() {
  3138. return this.hV;
  3139. };
  3140. if (typeof params != "undefined") {
  3141. if (typeof params["bigint"] != "undefined") {
  3142. this.setByBigInteger(params["bigint"]);
  3143. } else if (typeof params["int"] != "undefined") {
  3144. this.setByInteger(params["int"]);
  3145. } else if (typeof params == "number") {
  3146. this.setByInteger(params);
  3147. } else if (typeof params["hex"] != "undefined") {
  3148. this.setValueHex(params["hex"]);
  3149. }
  3150. }
  3151. };
  3152. YAHOO.lang.extend(KJUR.asn1.DERInteger, KJUR.asn1.ASN1Object);
  3153. KJUR.asn1.DERBitString = function(params) {
  3154. if (params !== void 0 && typeof params.obj !== "undefined") {
  3155. var o = KJUR.asn1.ASN1Util.newObject(params.obj);
  3156. params.hex = "00" + o.getEncodedHex();
  3157. }
  3158. KJUR.asn1.DERBitString.superclass.constructor.call(this);
  3159. this.hT = "03";
  3160. this.setHexValueIncludingUnusedBits = function(newHexStringIncludingUnusedBits) {
  3161. this.hTLV = null;
  3162. this.isModified = true;
  3163. this.hV = newHexStringIncludingUnusedBits;
  3164. };
  3165. this.setUnusedBitsAndHexValue = function(unusedBits, hValue) {
  3166. if (unusedBits < 0 || 7 < unusedBits) {
  3167. throw "unused bits shall be from 0 to 7: u = " + unusedBits;
  3168. }
  3169. var hUnusedBits = "0" + unusedBits;
  3170. this.hTLV = null;
  3171. this.isModified = true;
  3172. this.hV = hUnusedBits + hValue;
  3173. };
  3174. this.setByBinaryString = function(binaryString) {
  3175. binaryString = binaryString.replace(/0+$/, "");
  3176. var unusedBits = 8 - binaryString.length % 8;
  3177. if (unusedBits == 8)
  3178. unusedBits = 0;
  3179. for (var i = 0; i <= unusedBits; i++) {
  3180. binaryString += "0";
  3181. }
  3182. var h = "";
  3183. for (var i = 0; i < binaryString.length - 1; i += 8) {
  3184. var b = binaryString.substr(i, 8);
  3185. var x = parseInt(b, 2).toString(16);
  3186. if (x.length == 1)
  3187. x = "0" + x;
  3188. h += x;
  3189. }
  3190. this.hTLV = null;
  3191. this.isModified = true;
  3192. this.hV = "0" + unusedBits + h;
  3193. };
  3194. this.setByBooleanArray = function(booleanArray) {
  3195. var s = "";
  3196. for (var i = 0; i < booleanArray.length; i++) {
  3197. if (booleanArray[i] == true) {
  3198. s += "1";
  3199. } else {
  3200. s += "0";
  3201. }
  3202. }
  3203. this.setByBinaryString(s);
  3204. };
  3205. this.newFalseArray = function(nLength) {
  3206. var a = new Array(nLength);
  3207. for (var i = 0; i < nLength; i++) {
  3208. a[i] = false;
  3209. }
  3210. return a;
  3211. };
  3212. this.getFreshValueHex = function() {
  3213. return this.hV;
  3214. };
  3215. if (typeof params != "undefined") {
  3216. if (typeof params == "string" && params.toLowerCase().match(/^[0-9a-f]+$/)) {
  3217. this.setHexValueIncludingUnusedBits(params);
  3218. } else if (typeof params["hex"] != "undefined") {
  3219. this.setHexValueIncludingUnusedBits(params["hex"]);
  3220. } else if (typeof params["bin"] != "undefined") {
  3221. this.setByBinaryString(params["bin"]);
  3222. } else if (typeof params["array"] != "undefined") {
  3223. this.setByBooleanArray(params["array"]);
  3224. }
  3225. }
  3226. };
  3227. YAHOO.lang.extend(KJUR.asn1.DERBitString, KJUR.asn1.ASN1Object);
  3228. KJUR.asn1.DEROctetString = function(params) {
  3229. if (params !== void 0 && typeof params.obj !== "undefined") {
  3230. var o = KJUR.asn1.ASN1Util.newObject(params.obj);
  3231. params.hex = o.getEncodedHex();
  3232. }
  3233. KJUR.asn1.DEROctetString.superclass.constructor.call(this, params);
  3234. this.hT = "04";
  3235. };
  3236. YAHOO.lang.extend(KJUR.asn1.DEROctetString, KJUR.asn1.DERAbstractString);
  3237. KJUR.asn1.DERNull = function() {
  3238. KJUR.asn1.DERNull.superclass.constructor.call(this);
  3239. this.hT = "05";
  3240. this.hTLV = "0500";
  3241. };
  3242. YAHOO.lang.extend(KJUR.asn1.DERNull, KJUR.asn1.ASN1Object);
  3243. KJUR.asn1.DERObjectIdentifier = function(params) {
  3244. var itox = function(i) {
  3245. var h = i.toString(16);
  3246. if (h.length == 1)
  3247. h = "0" + h;
  3248. return h;
  3249. };
  3250. var roidtox = function(roid) {
  3251. var h = "";
  3252. var bi = new BigInteger(roid, 10);
  3253. var b = bi.toString(2);
  3254. var padLen = 7 - b.length % 7;
  3255. if (padLen == 7)
  3256. padLen = 0;
  3257. var bPad = "";
  3258. for (var i = 0; i < padLen; i++)
  3259. bPad += "0";
  3260. b = bPad + b;
  3261. for (var i = 0; i < b.length - 1; i += 7) {
  3262. var b8 = b.substr(i, 7);
  3263. if (i != b.length - 7)
  3264. b8 = "1" + b8;
  3265. h += itox(parseInt(b8, 2));
  3266. }
  3267. return h;
  3268. };
  3269. KJUR.asn1.DERObjectIdentifier.superclass.constructor.call(this);
  3270. this.hT = "06";
  3271. this.setValueHex = function(newHexString) {
  3272. this.hTLV = null;
  3273. this.isModified = true;
  3274. this.s = null;
  3275. this.hV = newHexString;
  3276. };
  3277. this.setValueOidString = function(oidString) {
  3278. if (!oidString.match(/^[0-9.]+$/)) {
  3279. throw "malformed oid string: " + oidString;
  3280. }
  3281. var h = "";
  3282. var a = oidString.split(".");
  3283. var i0 = parseInt(a[0]) * 40 + parseInt(a[1]);
  3284. h += itox(i0);
  3285. a.splice(0, 2);
  3286. for (var i = 0; i < a.length; i++) {
  3287. h += roidtox(a[i]);
  3288. }
  3289. this.hTLV = null;
  3290. this.isModified = true;
  3291. this.s = null;
  3292. this.hV = h;
  3293. };
  3294. this.setValueName = function(oidName) {
  3295. var oid = KJUR.asn1.x509.OID.name2oid(oidName);
  3296. if (oid !== "") {
  3297. this.setValueOidString(oid);
  3298. } else {
  3299. throw "DERObjectIdentifier oidName undefined: " + oidName;
  3300. }
  3301. };
  3302. this.getFreshValueHex = function() {
  3303. return this.hV;
  3304. };
  3305. if (params !== void 0) {
  3306. if (typeof params === "string") {
  3307. if (params.match(/^[0-2].[0-9.]+$/)) {
  3308. this.setValueOidString(params);
  3309. } else {
  3310. this.setValueName(params);
  3311. }
  3312. } else if (params.oid !== void 0) {
  3313. this.setValueOidString(params.oid);
  3314. } else if (params.hex !== void 0) {
  3315. this.setValueHex(params.hex);
  3316. } else if (params.name !== void 0) {
  3317. this.setValueName(params.name);
  3318. }
  3319. }
  3320. };
  3321. YAHOO.lang.extend(KJUR.asn1.DERObjectIdentifier, KJUR.asn1.ASN1Object);
  3322. KJUR.asn1.DEREnumerated = function(params) {
  3323. KJUR.asn1.DEREnumerated.superclass.constructor.call(this);
  3324. this.hT = "0a";
  3325. this.setByBigInteger = function(bigIntegerValue) {
  3326. this.hTLV = null;
  3327. this.isModified = true;
  3328. this.hV = KJUR.asn1.ASN1Util.bigIntToMinTwosComplementsHex(bigIntegerValue);
  3329. };
  3330. this.setByInteger = function(intValue) {
  3331. var bi = new BigInteger(String(intValue), 10);
  3332. this.setByBigInteger(bi);
  3333. };
  3334. this.setValueHex = function(newHexString) {
  3335. this.hV = newHexString;
  3336. };
  3337. this.getFreshValueHex = function() {
  3338. return this.hV;
  3339. };
  3340. if (typeof params != "undefined") {
  3341. if (typeof params["int"] != "undefined") {
  3342. this.setByInteger(params["int"]);
  3343. } else if (typeof params == "number") {
  3344. this.setByInteger(params);
  3345. } else if (typeof params["hex"] != "undefined") {
  3346. this.setValueHex(params["hex"]);
  3347. }
  3348. }
  3349. };
  3350. YAHOO.lang.extend(KJUR.asn1.DEREnumerated, KJUR.asn1.ASN1Object);
  3351. KJUR.asn1.DERUTF8String = function(params) {
  3352. KJUR.asn1.DERUTF8String.superclass.constructor.call(this, params);
  3353. this.hT = "0c";
  3354. };
  3355. YAHOO.lang.extend(KJUR.asn1.DERUTF8String, KJUR.asn1.DERAbstractString);
  3356. KJUR.asn1.DERNumericString = function(params) {
  3357. KJUR.asn1.DERNumericString.superclass.constructor.call(this, params);
  3358. this.hT = "12";
  3359. };
  3360. YAHOO.lang.extend(KJUR.asn1.DERNumericString, KJUR.asn1.DERAbstractString);
  3361. KJUR.asn1.DERPrintableString = function(params) {
  3362. KJUR.asn1.DERPrintableString.superclass.constructor.call(this, params);
  3363. this.hT = "13";
  3364. };
  3365. YAHOO.lang.extend(KJUR.asn1.DERPrintableString, KJUR.asn1.DERAbstractString);
  3366. KJUR.asn1.DERTeletexString = function(params) {
  3367. KJUR.asn1.DERTeletexString.superclass.constructor.call(this, params);
  3368. this.hT = "14";
  3369. };
  3370. YAHOO.lang.extend(KJUR.asn1.DERTeletexString, KJUR.asn1.DERAbstractString);
  3371. KJUR.asn1.DERIA5String = function(params) {
  3372. KJUR.asn1.DERIA5String.superclass.constructor.call(this, params);
  3373. this.hT = "16";
  3374. };
  3375. YAHOO.lang.extend(KJUR.asn1.DERIA5String, KJUR.asn1.DERAbstractString);
  3376. KJUR.asn1.DERUTCTime = function(params) {
  3377. KJUR.asn1.DERUTCTime.superclass.constructor.call(this, params);
  3378. this.hT = "17";
  3379. this.setByDate = function(dateObject) {
  3380. this.hTLV = null;
  3381. this.isModified = true;
  3382. this.date = dateObject;
  3383. this.s = this.formatDate(this.date, "utc");
  3384. this.hV = stohex(this.s);
  3385. };
  3386. this.getFreshValueHex = function() {
  3387. if (typeof this.date == "undefined" && typeof this.s == "undefined") {
  3388. this.date = new Date();
  3389. this.s = this.formatDate(this.date, "utc");
  3390. this.hV = stohex(this.s);
  3391. }
  3392. return this.hV;
  3393. };
  3394. if (params !== void 0) {
  3395. if (params.str !== void 0) {
  3396. this.setString(params.str);
  3397. } else if (typeof params == "string" && params.match(/^[0-9]{12}Z$/)) {
  3398. this.setString(params);
  3399. } else if (params.hex !== void 0) {
  3400. this.setStringHex(params.hex);
  3401. } else if (params.date !== void 0) {
  3402. this.setByDate(params.date);
  3403. }
  3404. }
  3405. };
  3406. YAHOO.lang.extend(KJUR.asn1.DERUTCTime, KJUR.asn1.DERAbstractTime);
  3407. KJUR.asn1.DERGeneralizedTime = function(params) {
  3408. KJUR.asn1.DERGeneralizedTime.superclass.constructor.call(this, params);
  3409. this.hT = "18";
  3410. this.withMillis = false;
  3411. this.setByDate = function(dateObject) {
  3412. this.hTLV = null;
  3413. this.isModified = true;
  3414. this.date = dateObject;
  3415. this.s = this.formatDate(this.date, "gen", this.withMillis);
  3416. this.hV = stohex(this.s);
  3417. };
  3418. this.getFreshValueHex = function() {
  3419. if (this.date === void 0 && this.s === void 0) {
  3420. this.date = new Date();
  3421. this.s = this.formatDate(this.date, "gen", this.withMillis);
  3422. this.hV = stohex(this.s);
  3423. }
  3424. return this.hV;
  3425. };
  3426. if (params !== void 0) {
  3427. if (params.str !== void 0) {
  3428. this.setString(params.str);
  3429. } else if (typeof params == "string" && params.match(/^[0-9]{14}Z$/)) {
  3430. this.setString(params);
  3431. } else if (params.hex !== void 0) {
  3432. this.setStringHex(params.hex);
  3433. } else if (params.date !== void 0) {
  3434. this.setByDate(params.date);
  3435. }
  3436. if (params.millis === true) {
  3437. this.withMillis = true;
  3438. }
  3439. }
  3440. };
  3441. YAHOO.lang.extend(KJUR.asn1.DERGeneralizedTime, KJUR.asn1.DERAbstractTime);
  3442. KJUR.asn1.DERSequence = function(params) {
  3443. KJUR.asn1.DERSequence.superclass.constructor.call(this, params);
  3444. this.hT = "30";
  3445. this.getFreshValueHex = function() {
  3446. var h = "";
  3447. for (var i = 0; i < this.asn1Array.length; i++) {
  3448. var asn1Obj = this.asn1Array[i];
  3449. h += asn1Obj.getEncodedHex();
  3450. }
  3451. this.hV = h;
  3452. return this.hV;
  3453. };
  3454. };
  3455. YAHOO.lang.extend(KJUR.asn1.DERSequence, KJUR.asn1.DERAbstractStructured);
  3456. KJUR.asn1.DERSet = function(params) {
  3457. KJUR.asn1.DERSet.superclass.constructor.call(this, params);
  3458. this.hT = "31";
  3459. this.sortFlag = true;
  3460. this.getFreshValueHex = function() {
  3461. var a = new Array();
  3462. for (var i = 0; i < this.asn1Array.length; i++) {
  3463. var asn1Obj = this.asn1Array[i];
  3464. a.push(asn1Obj.getEncodedHex());
  3465. }
  3466. if (this.sortFlag == true)
  3467. a.sort();
  3468. this.hV = a.join("");
  3469. return this.hV;
  3470. };
  3471. if (typeof params != "undefined") {
  3472. if (typeof params.sortflag != "undefined" && params.sortflag == false)
  3473. this.sortFlag = false;
  3474. }
  3475. };
  3476. YAHOO.lang.extend(KJUR.asn1.DERSet, KJUR.asn1.DERAbstractStructured);
  3477. KJUR.asn1.DERTaggedObject = function(params) {
  3478. KJUR.asn1.DERTaggedObject.superclass.constructor.call(this);
  3479. this.hT = "a0";
  3480. this.hV = "";
  3481. this.isExplicit = true;
  3482. this.asn1Object = null;
  3483. this.setASN1Object = function(isExplicitFlag, tagNoHex, asn1Object) {
  3484. this.hT = tagNoHex;
  3485. this.isExplicit = isExplicitFlag;
  3486. this.asn1Object = asn1Object;
  3487. if (this.isExplicit) {
  3488. this.hV = this.asn1Object.getEncodedHex();
  3489. this.hTLV = null;
  3490. this.isModified = true;
  3491. } else {
  3492. this.hV = null;
  3493. this.hTLV = asn1Object.getEncodedHex();
  3494. this.hTLV = this.hTLV.replace(/^../, tagNoHex);
  3495. this.isModified = false;
  3496. }
  3497. };
  3498. this.getFreshValueHex = function() {
  3499. return this.hV;
  3500. };
  3501. if (typeof params != "undefined") {
  3502. if (typeof params["tag"] != "undefined") {
  3503. this.hT = params["tag"];
  3504. }
  3505. if (typeof params["explicit"] != "undefined") {
  3506. this.isExplicit = params["explicit"];
  3507. }
  3508. if (typeof params["obj"] != "undefined") {
  3509. this.asn1Object = params["obj"];
  3510. this.setASN1Object(this.isExplicit, this.hT, this.asn1Object);
  3511. }
  3512. }
  3513. };
  3514. YAHOO.lang.extend(KJUR.asn1.DERTaggedObject, KJUR.asn1.ASN1Object);
  3515. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/JSEncryptRSAKey.js
  3516. var __extends = function() {
  3517. var extendStatics = function(d, b) {
  3518. extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d2, b2) {
  3519. d2.__proto__ = b2;
  3520. } || function(d2, b2) {
  3521. for (var p in b2)
  3522. if (Object.prototype.hasOwnProperty.call(b2, p))
  3523. d2[p] = b2[p];
  3524. };
  3525. return extendStatics(d, b);
  3526. };
  3527. return function(d, b) {
  3528. if (typeof b !== "function" && b !== null)
  3529. throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
  3530. extendStatics(d, b);
  3531. function __() {
  3532. this.constructor = d;
  3533. }
  3534. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  3535. };
  3536. }();
  3537. var JSEncryptRSAKey = (
  3538. /** @class */
  3539. function(_super) {
  3540. __extends(JSEncryptRSAKey2, _super);
  3541. function JSEncryptRSAKey2(key) {
  3542. var _this = _super.call(this) || this;
  3543. if (key) {
  3544. if (typeof key === "string") {
  3545. _this.parseKey(key);
  3546. } else if (JSEncryptRSAKey2.hasPrivateKeyProperty(key) || JSEncryptRSAKey2.hasPublicKeyProperty(key)) {
  3547. _this.parsePropertiesFrom(key);
  3548. }
  3549. }
  3550. return _this;
  3551. }
  3552. JSEncryptRSAKey2.prototype.parseKey = function(pem) {
  3553. try {
  3554. var modulus = 0;
  3555. var public_exponent = 0;
  3556. var reHex = /^\s*(?:[0-9A-Fa-f][0-9A-Fa-f]\s*)+$/;
  3557. var der = reHex.test(pem) ? Hex.decode(pem) : Base64.unarmor(pem);
  3558. var asn1 = ASN1.decode(der);
  3559. if (asn1.sub.length === 3) {
  3560. asn1 = asn1.sub[2].sub[0];
  3561. }
  3562. if (asn1.sub.length === 9) {
  3563. modulus = asn1.sub[1].getHexStringValue();
  3564. this.n = parseBigInt(modulus, 16);
  3565. public_exponent = asn1.sub[2].getHexStringValue();
  3566. this.e = parseInt(public_exponent, 16);
  3567. var private_exponent = asn1.sub[3].getHexStringValue();
  3568. this.d = parseBigInt(private_exponent, 16);
  3569. var prime1 = asn1.sub[4].getHexStringValue();
  3570. this.p = parseBigInt(prime1, 16);
  3571. var prime2 = asn1.sub[5].getHexStringValue();
  3572. this.q = parseBigInt(prime2, 16);
  3573. var exponent1 = asn1.sub[6].getHexStringValue();
  3574. this.dmp1 = parseBigInt(exponent1, 16);
  3575. var exponent2 = asn1.sub[7].getHexStringValue();
  3576. this.dmq1 = parseBigInt(exponent2, 16);
  3577. var coefficient = asn1.sub[8].getHexStringValue();
  3578. this.coeff = parseBigInt(coefficient, 16);
  3579. } else if (asn1.sub.length === 2) {
  3580. if (asn1.sub[0].sub) {
  3581. var bit_string = asn1.sub[1];
  3582. var sequence = bit_string.sub[0];
  3583. modulus = sequence.sub[0].getHexStringValue();
  3584. this.n = parseBigInt(modulus, 16);
  3585. public_exponent = sequence.sub[1].getHexStringValue();
  3586. this.e = parseInt(public_exponent, 16);
  3587. } else {
  3588. modulus = asn1.sub[0].getHexStringValue();
  3589. this.n = parseBigInt(modulus, 16);
  3590. public_exponent = asn1.sub[1].getHexStringValue();
  3591. this.e = parseInt(public_exponent, 16);
  3592. }
  3593. } else {
  3594. return false;
  3595. }
  3596. return true;
  3597. } catch (ex) {
  3598. return false;
  3599. }
  3600. };
  3601. JSEncryptRSAKey2.prototype.getPrivateBaseKey = function() {
  3602. var options = {
  3603. array: [
  3604. new KJUR.asn1.DERInteger({ int: 0 }),
  3605. new KJUR.asn1.DERInteger({ bigint: this.n }),
  3606. new KJUR.asn1.DERInteger({ int: this.e }),
  3607. new KJUR.asn1.DERInteger({ bigint: this.d }),
  3608. new KJUR.asn1.DERInteger({ bigint: this.p }),
  3609. new KJUR.asn1.DERInteger({ bigint: this.q }),
  3610. new KJUR.asn1.DERInteger({ bigint: this.dmp1 }),
  3611. new KJUR.asn1.DERInteger({ bigint: this.dmq1 }),
  3612. new KJUR.asn1.DERInteger({ bigint: this.coeff })
  3613. ]
  3614. };
  3615. var seq = new KJUR.asn1.DERSequence(options);
  3616. return seq.getEncodedHex();
  3617. };
  3618. JSEncryptRSAKey2.prototype.getPrivateBaseKeyB64 = function() {
  3619. return hex2b64(this.getPrivateBaseKey());
  3620. };
  3621. JSEncryptRSAKey2.prototype.getPublicBaseKey = function() {
  3622. var first_sequence = new KJUR.asn1.DERSequence({
  3623. array: [
  3624. new KJUR.asn1.DERObjectIdentifier({ oid: "1.2.840.113549.1.1.1" }),
  3625. new KJUR.asn1.DERNull()
  3626. ]
  3627. });
  3628. var second_sequence = new KJUR.asn1.DERSequence({
  3629. array: [
  3630. new KJUR.asn1.DERInteger({ bigint: this.n }),
  3631. new KJUR.asn1.DERInteger({ int: this.e })
  3632. ]
  3633. });
  3634. var bit_string = new KJUR.asn1.DERBitString({
  3635. hex: "00" + second_sequence.getEncodedHex()
  3636. });
  3637. var seq = new KJUR.asn1.DERSequence({
  3638. array: [first_sequence, bit_string]
  3639. });
  3640. return seq.getEncodedHex();
  3641. };
  3642. JSEncryptRSAKey2.prototype.getPublicBaseKeyB64 = function() {
  3643. return hex2b64(this.getPublicBaseKey());
  3644. };
  3645. JSEncryptRSAKey2.wordwrap = function(str, width) {
  3646. width = width || 64;
  3647. if (!str) {
  3648. return str;
  3649. }
  3650. var regex = "(.{1," + width + "})( +|$\n?)|(.{1," + width + "})";
  3651. return str.match(RegExp(regex, "g")).join("\n");
  3652. };
  3653. JSEncryptRSAKey2.prototype.getPrivateKey = function() {
  3654. var key = "-----BEGIN RSA PRIVATE KEY-----\n";
  3655. key += JSEncryptRSAKey2.wordwrap(this.getPrivateBaseKeyB64()) + "\n";
  3656. key += "-----END RSA PRIVATE KEY-----";
  3657. return key;
  3658. };
  3659. JSEncryptRSAKey2.prototype.getPublicKey = function() {
  3660. var key = "-----BEGIN PUBLIC KEY-----\n";
  3661. key += JSEncryptRSAKey2.wordwrap(this.getPublicBaseKeyB64()) + "\n";
  3662. key += "-----END PUBLIC KEY-----";
  3663. return key;
  3664. };
  3665. JSEncryptRSAKey2.hasPublicKeyProperty = function(obj) {
  3666. obj = obj || {};
  3667. return obj.hasOwnProperty("n") && obj.hasOwnProperty("e");
  3668. };
  3669. JSEncryptRSAKey2.hasPrivateKeyProperty = function(obj) {
  3670. obj = obj || {};
  3671. return obj.hasOwnProperty("n") && obj.hasOwnProperty("e") && obj.hasOwnProperty("d") && obj.hasOwnProperty("p") && obj.hasOwnProperty("q") && obj.hasOwnProperty("dmp1") && obj.hasOwnProperty("dmq1") && obj.hasOwnProperty("coeff");
  3672. };
  3673. JSEncryptRSAKey2.prototype.parsePropertiesFrom = function(obj) {
  3674. this.n = obj.n;
  3675. this.e = obj.e;
  3676. if (obj.hasOwnProperty("d")) {
  3677. this.d = obj.d;
  3678. this.p = obj.p;
  3679. this.q = obj.q;
  3680. this.dmp1 = obj.dmp1;
  3681. this.dmq1 = obj.dmq1;
  3682. this.coeff = obj.coeff;
  3683. }
  3684. };
  3685. return JSEncryptRSAKey2;
  3686. }(RSAKey)
  3687. );
  3688. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/JSEncrypt.js
  3689. var _a;
  3690. var version = typeof process !== "undefined" ? (_a = process.env) === null || _a === void 0 ? void 0 : _a.npm_package_version : void 0;
  3691. var JSEncrypt = (
  3692. /** @class */
  3693. function() {
  3694. function JSEncrypt2(options) {
  3695. if (options === void 0) {
  3696. options = {};
  3697. }
  3698. options = options || {};
  3699. this.default_key_size = options.default_key_size ? parseInt(options.default_key_size, 10) : 1024;
  3700. this.default_public_exponent = options.default_public_exponent || "010001";
  3701. this.log = options.log || false;
  3702. this.key = null;
  3703. }
  3704. JSEncrypt2.prototype.setKey = function(key) {
  3705. if (this.log && this.key) {
  3706. console.warn("A key was already set, overriding existing.");
  3707. }
  3708. this.key = new JSEncryptRSAKey(key);
  3709. };
  3710. JSEncrypt2.prototype.setPrivateKey = function(privkey) {
  3711. this.setKey(privkey);
  3712. };
  3713. JSEncrypt2.prototype.setPublicKey = function(pubkey) {
  3714. this.setKey(pubkey);
  3715. };
  3716. JSEncrypt2.prototype.decrypt = function(str) {
  3717. try {
  3718. return this.getKey().decrypt(b64tohex(str));
  3719. } catch (ex) {
  3720. return false;
  3721. }
  3722. };
  3723. JSEncrypt2.prototype.encrypt = function(str) {
  3724. try {
  3725. return hex2b64(this.getKey().encrypt(str));
  3726. } catch (ex) {
  3727. return false;
  3728. }
  3729. };
  3730. JSEncrypt2.prototype.sign = function(str, digestMethod, digestName) {
  3731. try {
  3732. return hex2b64(this.getKey().sign(str, digestMethod, digestName));
  3733. } catch (ex) {
  3734. return false;
  3735. }
  3736. };
  3737. JSEncrypt2.prototype.verify = function(str, signature, digestMethod) {
  3738. try {
  3739. return this.getKey().verify(str, b64tohex(signature), digestMethod);
  3740. } catch (ex) {
  3741. return false;
  3742. }
  3743. };
  3744. JSEncrypt2.prototype.getKey = function(cb) {
  3745. if (!this.key) {
  3746. this.key = new JSEncryptRSAKey();
  3747. if (cb && {}.toString.call(cb) === "[object Function]") {
  3748. this.key.generateAsync(this.default_key_size, this.default_public_exponent, cb);
  3749. return;
  3750. }
  3751. this.key.generate(this.default_key_size, this.default_public_exponent);
  3752. }
  3753. return this.key;
  3754. };
  3755. JSEncrypt2.prototype.getPrivateKey = function() {
  3756. return this.getKey().getPrivateKey();
  3757. };
  3758. JSEncrypt2.prototype.getPrivateKeyB64 = function() {
  3759. return this.getKey().getPrivateBaseKeyB64();
  3760. };
  3761. JSEncrypt2.prototype.getPublicKey = function() {
  3762. return this.getKey().getPublicKey();
  3763. };
  3764. JSEncrypt2.prototype.getPublicKeyB64 = function() {
  3765. return this.getKey().getPublicBaseKeyB64();
  3766. };
  3767. JSEncrypt2.version = version;
  3768. return JSEncrypt2;
  3769. }()
  3770. );
  3771. // ../../../../xueYi/18_xinjiang/xinjiangApp/node_modules/jsencrypt/lib/index.js
  3772. var lib_default = JSEncrypt;
  3773. export {
  3774. JSEncrypt,
  3775. lib_default as default
  3776. };
  3777. /*! Bundled license information:
  3778. jsencrypt/lib/lib/jsrsasign/yahoo.js:
  3779. (*!
  3780. Copyright (c) 2011, Yahoo! Inc. All rights reserved.
  3781. Code licensed under the BSD License:
  3782. http://developer.yahoo.com/yui/license.html
  3783. version: 2.9.0
  3784. *)
  3785. jsencrypt/lib/lib/jsrsasign/asn1-1.0.js:
  3786. (**
  3787. * @fileOverview
  3788. * @name asn1-1.0.js
  3789. * @author Kenji Urushima kenji.urushima@gmail.com
  3790. * @version asn1 1.0.13 (2017-Jun-02)
  3791. * @since jsrsasign 2.1
  3792. * @license <a href="https://kjur.github.io/jsrsasign/license/">MIT License</a>
  3793. *)
  3794. */
  3795. //# sourceMappingURL=jsencrypt.js.map