privacy.html 57 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>privacy.md - 来自HBuilderX的文档分享</title>
  5. <meta charset="utf-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1">
  7. <style>
  8. body {
  9. margin: 0;
  10. }
  11. #markdown-body {
  12. padding: 10px;
  13. }
  14. @media screen and (max-width: 750px) {
  15. #mobile {
  16. display: none !important;
  17. }
  18. }
  19. </style>
  20. <script type="text/javascript">
  21. var QRCode;
  22. ! function() {
  23. function a(a) {
  24. this.mode = c.MODE_8BIT_BYTE, this.data = a, this.parsedData = [];
  25. for (var b = [], d = 0, e = this.data.length; e > d; d++) {
  26. var f = this.data.charCodeAt(d);
  27. f > 65536 ? (b[0] = 240 | (1835008 & f) >>> 18, b[1] = 128 | (258048 & f) >>> 12, b[2] = 128 | (4032 &
  28. f) >>> 6, b[3] = 128 | 63 & f) : f > 2048 ? (b[0] = 224 | (61440 & f) >>> 12, b[1] = 128 | (4032 &
  29. f) >>> 6, b[2] = 128 | 63 & f) : f > 128 ? (b[0] = 192 | (1984 & f) >>> 6, b[1] = 128 | 63 & f) : b[0] =
  30. f, this.parsedData = this.parsedData.concat(b)
  31. }
  32. this.parsedData.length != this.data.length && (this.parsedData.unshift(191), this.parsedData.unshift(187),
  33. this.parsedData.unshift(239))
  34. }
  35. function b(a, b) {
  36. this.typeNumber = a, this.errorCorrectLevel = b, this.modules = null, this.moduleCount = 0, this.dataCache =
  37. null, this.dataList = []
  38. }
  39. function i(a, b) {
  40. if (void 0 == a.length) throw new Error(a.length + "/" + b);
  41. for (var c = 0; c < a.length && 0 == a[c];) c++;
  42. this.num = new Array(a.length - c + b);
  43. for (var d = 0; d < a.length - c; d++) this.num[d] = a[d + c]
  44. }
  45. function j(a, b) {
  46. this.totalCount = a, this.dataCount = b
  47. }
  48. function k() {
  49. this.buffer = [], this.length = 0
  50. }
  51. function m() {
  52. return "undefined" != typeof CanvasRenderingContext2D
  53. }
  54. function n() {
  55. var a = !1,
  56. b = navigator.userAgent;
  57. return /android/i.test(b) && (a = !0, aMat = b.toString().match(/android ([0-9].[0-9])/i), aMat && aMat[1] &&
  58. (a = parseFloat(aMat[1]))), a
  59. }
  60. function r(a, b) {
  61. for (var c = 1, e = s(a), f = 0, g = l.length; g >= f; f++) {
  62. var h = 0;
  63. switch (b) {
  64. case d.L:
  65. h = l[f][0];
  66. break;
  67. case d.M:
  68. h = l[f][1];
  69. break;
  70. case d.Q:
  71. h = l[f][2];
  72. break;
  73. case d.H:
  74. h = l[f][3]
  75. }
  76. if (h >= e) break;
  77. c++
  78. }
  79. if (c > l.length) throw new Error("Too long data");
  80. return c
  81. }
  82. function s(a) {
  83. var b = encodeURI(a).toString().replace(/%[0-9a-fA-F]{2}/g, "a");
  84. return b.length + (b.length != a ? 3 : 0)
  85. }
  86. a.prototype = {
  87. getLength: function() {
  88. return this.parsedData.length
  89. },
  90. write: function(a) {
  91. for (var b = 0, c = this.parsedData.length; c > b; b++) a.put(this.parsedData[b], 8)
  92. }
  93. }, b.prototype = {
  94. addData: function(b) {
  95. var c = new a(b);
  96. this.dataList.push(c), this.dataCache = null
  97. },
  98. isDark: function(a, b) {
  99. if (0 > a || this.moduleCount <= a || 0 > b || this.moduleCount <= b) throw new Error(a + "," + b);
  100. return this.modules[a][b]
  101. },
  102. getModuleCount: function() {
  103. return this.moduleCount
  104. },
  105. make: function() {
  106. this.makeImpl(!1, this.getBestMaskPattern())
  107. },
  108. makeImpl: function(a, c) {
  109. this.moduleCount = 4 * this.typeNumber + 17, this.modules = new Array(this.moduleCount);
  110. for (var d = 0; d < this.moduleCount; d++) {
  111. this.modules[d] = new Array(this.moduleCount);
  112. for (var e = 0; e < this.moduleCount; e++) this.modules[d][e] = null
  113. }
  114. this.setupPositionProbePattern(0, 0), this.setupPositionProbePattern(this.moduleCount - 7, 0), this
  115. .setupPositionProbePattern(0, this.moduleCount - 7), this.setupPositionAdjustPattern(), this
  116. .setupTimingPattern(), this.setupTypeInfo(a, c), this.typeNumber >= 7 && this.setupTypeNumber(a),
  117. null == this.dataCache && (this.dataCache = b.createData(this.typeNumber, this.errorCorrectLevel, this
  118. .dataList)), this.mapData(this.dataCache, c)
  119. },
  120. setupPositionProbePattern: function(a, b) {
  121. for (var c = -1; 7 >= c; c++)
  122. if (!(-1 >= a + c || this.moduleCount <= a + c))
  123. for (var d = -1; 7 >= d; d++) - 1 >= b + d || this.moduleCount <= b + d || (this.modules[a + c][b +
  124. d
  125. ] = c >= 0 && 6 >= c && (0 == d || 6 == d) || d >= 0 && 6 >= d && (0 == c || 6 == c) || c >=
  126. 2 && 4 >= c && d >= 2 && 4 >= d ? !0 : !1)
  127. },
  128. getBestMaskPattern: function() {
  129. for (var a = 0, b = 0, c = 0; 8 > c; c++) {
  130. this.makeImpl(!0, c);
  131. var d = f.getLostPoint(this);
  132. (0 == c || a > d) && (a = d, b = c)
  133. }
  134. return b
  135. },
  136. createMovieClip: function(a, b, c) {
  137. var d = a.createEmptyMovieClip(b, c),
  138. e = 1;
  139. this.make();
  140. for (var f = 0; f < this.modules.length; f++)
  141. for (var g = f * e, h = 0; h < this.modules[f].length; h++) {
  142. var i = h * e,
  143. j = this.modules[f][h];
  144. j && (d.beginFill(0, 100), d.moveTo(i, g), d.lineTo(i + e, g), d.lineTo(i + e, g + e), d.lineTo(i,
  145. g + e), d.endFill())
  146. }
  147. return d
  148. },
  149. setupTimingPattern: function() {
  150. for (var a = 8; a < this.moduleCount - 8; a++) null == this.modules[a][6] && (this.modules[a][6] = 0 ==
  151. a % 2);
  152. for (var b = 8; b < this.moduleCount - 8; b++) null == this.modules[6][b] && (this.modules[6][b] = 0 ==
  153. b % 2)
  154. },
  155. setupPositionAdjustPattern: function() {
  156. for (var a = f.getPatternPosition(this.typeNumber), b = 0; b < a.length; b++)
  157. for (var c = 0; c < a.length; c++) {
  158. var d = a[b],
  159. e = a[c];
  160. if (null == this.modules[d][e])
  161. for (var g = -2; 2 >= g; g++)
  162. for (var h = -2; 2 >= h; h++) this.modules[d + g][e + h] = -2 == g || 2 == g || -2 == h || 2 ==
  163. h || 0 == g && 0 == h ? !0 : !1
  164. }
  165. },
  166. setupTypeNumber: function(a) {
  167. for (var b = f.getBCHTypeNumber(this.typeNumber), c = 0; 18 > c; c++) {
  168. var d = !a && 1 == (1 & b >> c);
  169. this.modules[Math.floor(c / 3)][c % 3 + this.moduleCount - 8 - 3] = d
  170. }
  171. for (var c = 0; 18 > c; c++) {
  172. var d = !a && 1 == (1 & b >> c);
  173. this.modules[c % 3 + this.moduleCount - 8 - 3][Math.floor(c / 3)] = d
  174. }
  175. },
  176. setupTypeInfo: function(a, b) {
  177. for (var c = this.errorCorrectLevel << 3 | b, d = f.getBCHTypeInfo(c), e = 0; 15 > e; e++) {
  178. var g = !a && 1 == (1 & d >> e);
  179. 6 > e ? this.modules[e][8] = g : 8 > e ? this.modules[e + 1][8] = g : this.modules[this.moduleCount -
  180. 15 + e][8] = g
  181. }
  182. for (var e = 0; 15 > e; e++) {
  183. var g = !a && 1 == (1 & d >> e);
  184. 8 > e ? this.modules[8][this.moduleCount - e - 1] = g : 9 > e ? this.modules[8][15 - e - 1 + 1] = g :
  185. this.modules[8][15 - e - 1] = g
  186. }
  187. this.modules[this.moduleCount - 8][8] = !a
  188. },
  189. mapData: function(a, b) {
  190. for (var c = -1, d = this.moduleCount - 1, e = 7, g = 0, h = this.moduleCount - 1; h > 0; h -= 2)
  191. for (6 == h && h--;;) {
  192. for (var i = 0; 2 > i; i++)
  193. if (null == this.modules[d][h - i]) {
  194. var j = !1;
  195. g < a.length && (j = 1 == (1 & a[g] >>> e));
  196. var k = f.getMask(b, d, h - i);
  197. k && (j = !j), this.modules[d][h - i] = j, e--, -1 == e && (g++, e = 7)
  198. } if (d += c, 0 > d || this.moduleCount <= d) {
  199. d -= c, c = -c;
  200. break
  201. }
  202. }
  203. }
  204. }, b.PAD0 = 236, b.PAD1 = 17, b.createData = function(a, c, d) {
  205. for (var e = j.getRSBlocks(a, c), g = new k, h = 0; h < d.length; h++) {
  206. var i = d[h];
  207. g.put(i.mode, 4), g.put(i.getLength(), f.getLengthInBits(i.mode, a)), i.write(g)
  208. }
  209. for (var l = 0, h = 0; h < e.length; h++) l += e[h].dataCount;
  210. if (g.getLengthInBits() > 8 * l) throw new Error("code length overflow. (" + g.getLengthInBits() + ">" + 8 *
  211. l + ")");
  212. for (g.getLengthInBits() + 4 <= 8 * l && g.put(0, 4); 0 != g.getLengthInBits() % 8;) g.putBit(!1);
  213. for (;;) {
  214. if (g.getLengthInBits() >= 8 * l) break;
  215. if (g.put(b.PAD0, 8), g.getLengthInBits() >= 8 * l) break;
  216. g.put(b.PAD1, 8)
  217. }
  218. return b.createBytes(g, e)
  219. }, b.createBytes = function(a, b) {
  220. for (var c = 0, d = 0, e = 0, g = new Array(b.length), h = new Array(b.length), j = 0; j < b.length; j++) {
  221. var k = b[j].dataCount,
  222. l = b[j].totalCount - k;
  223. d = Math.max(d, k), e = Math.max(e, l), g[j] = new Array(k);
  224. for (var m = 0; m < g[j].length; m++) g[j][m] = 255 & a.buffer[m + c];
  225. c += k;
  226. var n = f.getErrorCorrectPolynomial(l),
  227. o = new i(g[j], n.getLength() - 1),
  228. p = o.mod(n);
  229. h[j] = new Array(n.getLength() - 1);
  230. for (var m = 0; m < h[j].length; m++) {
  231. var q = m + p.getLength() - h[j].length;
  232. h[j][m] = q >= 0 ? p.get(q) : 0
  233. }
  234. }
  235. for (var r = 0, m = 0; m < b.length; m++) r += b[m].totalCount;
  236. for (var s = new Array(r), t = 0, m = 0; d > m; m++)
  237. for (var j = 0; j < b.length; j++) m < g[j].length && (s[t++] = g[j][m]);
  238. for (var m = 0; e > m; m++)
  239. for (var j = 0; j < b.length; j++) m < h[j].length && (s[t++] = h[j][m]);
  240. return s
  241. };
  242. for (var c = {
  243. MODE_NUMBER: 1,
  244. MODE_ALPHA_NUM: 2,
  245. MODE_8BIT_BYTE: 4,
  246. MODE_KANJI: 8
  247. }, d = {
  248. L: 1,
  249. M: 0,
  250. Q: 3,
  251. H: 2
  252. }, e = {
  253. PATTERN000: 0,
  254. PATTERN001: 1,
  255. PATTERN010: 2,
  256. PATTERN011: 3,
  257. PATTERN100: 4,
  258. PATTERN101: 5,
  259. PATTERN110: 6,
  260. PATTERN111: 7
  261. }, f = {
  262. PATTERN_POSITION_TABLE: [
  263. [],
  264. [6, 18],
  265. [6, 22],
  266. [6, 26],
  267. [6, 30],
  268. [6, 34],
  269. [6, 22, 38],
  270. [6, 24, 42],
  271. [6, 26, 46],
  272. [6, 28, 50],
  273. [6, 30, 54],
  274. [6, 32, 58],
  275. [6, 34, 62],
  276. [6, 26, 46, 66],
  277. [6, 26, 48, 70],
  278. [6, 26, 50, 74],
  279. [6, 30, 54, 78],
  280. [6, 30, 56, 82],
  281. [6, 30, 58, 86],
  282. [6, 34, 62, 90],
  283. [6, 28, 50, 72, 94],
  284. [6, 26, 50, 74, 98],
  285. [6, 30, 54, 78, 102],
  286. [6, 28, 54, 80, 106],
  287. [6, 32, 58, 84, 110],
  288. [6, 30, 58, 86, 114],
  289. [6, 34, 62, 90, 118],
  290. [6, 26, 50, 74, 98, 122],
  291. [6, 30, 54, 78, 102, 126],
  292. [6, 26, 52, 78, 104, 130],
  293. [6, 30, 56, 82, 108, 134],
  294. [6, 34, 60, 86, 112, 138],
  295. [6, 30, 58, 86, 114, 142],
  296. [6, 34, 62, 90, 118, 146],
  297. [6, 30, 54, 78, 102, 126, 150],
  298. [6, 24, 50, 76, 102, 128, 154],
  299. [6, 28, 54, 80, 106, 132, 158],
  300. [6, 32, 58, 84, 110, 136, 162],
  301. [6, 26, 54, 82, 110, 138, 166],
  302. [6, 30, 58, 86, 114, 142, 170]
  303. ],
  304. G15: 1335,
  305. G18: 7973,
  306. G15_MASK: 21522,
  307. getBCHTypeInfo: function(a) {
  308. for (var b = a << 10; f.getBCHDigit(b) - f.getBCHDigit(f.G15) >= 0;) b ^= f.G15 << f.getBCHDigit(b) -
  309. f.getBCHDigit(f.G15);
  310. return (a << 10 | b) ^ f.G15_MASK
  311. },
  312. getBCHTypeNumber: function(a) {
  313. for (var b = a << 12; f.getBCHDigit(b) - f.getBCHDigit(f.G18) >= 0;) b ^= f.G18 << f.getBCHDigit(b) -
  314. f.getBCHDigit(f.G18);
  315. return a << 12 | b
  316. },
  317. getBCHDigit: function(a) {
  318. for (var b = 0; 0 != a;) b++, a >>>= 1;
  319. return b
  320. },
  321. getPatternPosition: function(a) {
  322. return f.PATTERN_POSITION_TABLE[a - 1]
  323. },
  324. getMask: function(a, b, c) {
  325. switch (a) {
  326. case e.PATTERN000:
  327. return 0 == (b + c) % 2;
  328. case e.PATTERN001:
  329. return 0 == b % 2;
  330. case e.PATTERN010:
  331. return 0 == c % 3;
  332. case e.PATTERN011:
  333. return 0 == (b + c) % 3;
  334. case e.PATTERN100:
  335. return 0 == (Math.floor(b / 2) + Math.floor(c / 3)) % 2;
  336. case e.PATTERN101:
  337. return 0 == b * c % 2 + b * c % 3;
  338. case e.PATTERN110:
  339. return 0 == (b * c % 2 + b * c % 3) % 2;
  340. case e.PATTERN111:
  341. return 0 == (b * c % 3 + (b + c) % 2) % 2;
  342. default:
  343. throw new Error("bad maskPattern:" + a)
  344. }
  345. },
  346. getErrorCorrectPolynomial: function(a) {
  347. for (var b = new i([1], 0), c = 0; a > c; c++) b = b.multiply(new i([1, g.gexp(c)], 0));
  348. return b
  349. },
  350. getLengthInBits: function(a, b) {
  351. if (b >= 1 && 10 > b) switch (a) {
  352. case c.MODE_NUMBER:
  353. return 10;
  354. case c.MODE_ALPHA_NUM:
  355. return 9;
  356. case c.MODE_8BIT_BYTE:
  357. return 8;
  358. case c.MODE_KANJI:
  359. return 8;
  360. default:
  361. throw new Error("mode:" + a)
  362. } else if (27 > b) switch (a) {
  363. case c.MODE_NUMBER:
  364. return 12;
  365. case c.MODE_ALPHA_NUM:
  366. return 11;
  367. case c.MODE_8BIT_BYTE:
  368. return 16;
  369. case c.MODE_KANJI:
  370. return 10;
  371. default:
  372. throw new Error("mode:" + a)
  373. } else {
  374. if (!(41 > b)) throw new Error("type:" + b);
  375. switch (a) {
  376. case c.MODE_NUMBER:
  377. return 14;
  378. case c.MODE_ALPHA_NUM:
  379. return 13;
  380. case c.MODE_8BIT_BYTE:
  381. return 16;
  382. case c.MODE_KANJI:
  383. return 12;
  384. default:
  385. throw new Error("mode:" + a)
  386. }
  387. }
  388. },
  389. getLostPoint: function(a) {
  390. for (var b = a.getModuleCount(), c = 0, d = 0; b > d; d++)
  391. for (var e = 0; b > e; e++) {
  392. for (var f = 0, g = a.isDark(d, e), h = -1; 1 >= h; h++)
  393. if (!(0 > d + h || d + h >= b))
  394. for (var i = -1; 1 >= i; i++) 0 > e + i || e + i >= b || (0 != h || 0 != i) && g == a.isDark(
  395. d + h, e + i) && f++;
  396. f > 5 && (c += 3 + f - 5)
  397. }
  398. for (var d = 0; b - 1 > d; d++)
  399. for (var e = 0; b - 1 > e; e++) {
  400. var j = 0;
  401. a.isDark(d, e) && j++, a.isDark(d + 1, e) && j++, a.isDark(d, e + 1) && j++, a.isDark(d + 1, e +
  402. 1) && j++, (0 == j || 4 == j) && (c += 3)
  403. }
  404. for (var d = 0; b > d; d++)
  405. for (var e = 0; b - 6 > e; e++) a.isDark(d, e) && !a.isDark(d, e + 1) && a.isDark(d, e + 2) && a
  406. .isDark(d, e + 3) && a.isDark(d, e + 4) && !a.isDark(d, e + 5) && a.isDark(d, e + 6) && (c += 40);
  407. for (var e = 0; b > e; e++)
  408. for (var d = 0; b - 6 > d; d++) a.isDark(d, e) && !a.isDark(d + 1, e) && a.isDark(d + 2, e) && a
  409. .isDark(d + 3, e) && a.isDark(d + 4, e) && !a.isDark(d + 5, e) && a.isDark(d + 6, e) && (c += 40);
  410. for (var k = 0, e = 0; b > e; e++)
  411. for (var d = 0; b > d; d++) a.isDark(d, e) && k++;
  412. var l = Math.abs(100 * k / b / b - 50) / 5;
  413. return c += 10 * l
  414. }
  415. }, g = {
  416. glog: function(a) {
  417. if (1 > a) throw new Error("glog(" + a + ")");
  418. return g.LOG_TABLE[a]
  419. },
  420. gexp: function(a) {
  421. for (; 0 > a;) a += 255;
  422. for (; a >= 256;) a -= 255;
  423. return g.EXP_TABLE[a]
  424. },
  425. EXP_TABLE: new Array(256),
  426. LOG_TABLE: new Array(256)
  427. }, h = 0; 8 > h; h++) g.EXP_TABLE[h] = 1 << h;
  428. for (var h = 8; 256 > h; h++) g.EXP_TABLE[h] = g.EXP_TABLE[h - 4] ^ g.EXP_TABLE[h - 5] ^ g.EXP_TABLE[h - 6] ^ g
  429. .EXP_TABLE[h - 8];
  430. for (var h = 0; 255 > h; h++) g.LOG_TABLE[g.EXP_TABLE[h]] = h;
  431. i.prototype = {
  432. get: function(a) {
  433. return this.num[a]
  434. },
  435. getLength: function() {
  436. return this.num.length
  437. },
  438. multiply: function(a) {
  439. for (var b = new Array(this.getLength() + a.getLength() - 1), c = 0; c < this.getLength(); c++)
  440. for (var d = 0; d < a.getLength(); d++) b[c + d] ^= g.gexp(g.glog(this.get(c)) + g.glog(a.get(d)));
  441. return new i(b, 0)
  442. },
  443. mod: function(a) {
  444. if (this.getLength() - a.getLength() < 0) return this;
  445. for (var b = g.glog(this.get(0)) - g.glog(a.get(0)), c = new Array(this.getLength()), d = 0; d < this
  446. .getLength(); d++) c[d] = this.get(d);
  447. for (var d = 0; d < a.getLength(); d++) c[d] ^= g.gexp(g.glog(a.get(d)) + b);
  448. return new i(c, 0).mod(a)
  449. }
  450. }, j.RS_BLOCK_TABLE = [
  451. [1, 26, 19],
  452. [1, 26, 16],
  453. [1, 26, 13],
  454. [1, 26, 9],
  455. [1, 44, 34],
  456. [1, 44, 28],
  457. [1, 44, 22],
  458. [1, 44, 16],
  459. [1, 70, 55],
  460. [1, 70, 44],
  461. [2, 35, 17],
  462. [2, 35, 13],
  463. [1, 100, 80],
  464. [2, 50, 32],
  465. [2, 50, 24],
  466. [4, 25, 9],
  467. [1, 134, 108],
  468. [2, 67, 43],
  469. [2, 33, 15, 2, 34, 16],
  470. [2, 33, 11, 2, 34, 12],
  471. [2, 86, 68],
  472. [4, 43, 27],
  473. [4, 43, 19],
  474. [4, 43, 15],
  475. [2, 98, 78],
  476. [4, 49, 31],
  477. [2, 32, 14, 4, 33, 15],
  478. [4, 39, 13, 1, 40, 14],
  479. [2, 121, 97],
  480. [2, 60, 38, 2, 61, 39],
  481. [4, 40, 18, 2, 41, 19],
  482. [4, 40, 14, 2, 41, 15],
  483. [2, 146, 116],
  484. [3, 58, 36, 2, 59, 37],
  485. [4, 36, 16, 4, 37, 17],
  486. [4, 36, 12, 4, 37, 13],
  487. [2, 86, 68, 2, 87, 69],
  488. [4, 69, 43, 1, 70, 44],
  489. [6, 43, 19, 2, 44, 20],
  490. [6, 43, 15, 2, 44, 16],
  491. [4, 101, 81],
  492. [1, 80, 50, 4, 81, 51],
  493. [4, 50, 22, 4, 51, 23],
  494. [3, 36, 12, 8, 37, 13],
  495. [2, 116, 92, 2, 117, 93],
  496. [6, 58, 36, 2, 59, 37],
  497. [4, 46, 20, 6, 47, 21],
  498. [7, 42, 14, 4, 43, 15],
  499. [4, 133, 107],
  500. [8, 59, 37, 1, 60, 38],
  501. [8, 44, 20, 4, 45, 21],
  502. [12, 33, 11, 4, 34, 12],
  503. [3, 145, 115, 1, 146, 116],
  504. [4, 64, 40, 5, 65, 41],
  505. [11, 36, 16, 5, 37, 17],
  506. [11, 36, 12, 5, 37, 13],
  507. [5, 109, 87, 1, 110, 88],
  508. [5, 65, 41, 5, 66, 42],
  509. [5, 54, 24, 7, 55, 25],
  510. [11, 36, 12],
  511. [5, 122, 98, 1, 123, 99],
  512. [7, 73, 45, 3, 74, 46],
  513. [15, 43, 19, 2, 44, 20],
  514. [3, 45, 15, 13, 46, 16],
  515. [1, 135, 107, 5, 136, 108],
  516. [10, 74, 46, 1, 75, 47],
  517. [1, 50, 22, 15, 51, 23],
  518. [2, 42, 14, 17, 43, 15],
  519. [5, 150, 120, 1, 151, 121],
  520. [9, 69, 43, 4, 70, 44],
  521. [17, 50, 22, 1, 51, 23],
  522. [2, 42, 14, 19, 43, 15],
  523. [3, 141, 113, 4, 142, 114],
  524. [3, 70, 44, 11, 71, 45],
  525. [17, 47, 21, 4, 48, 22],
  526. [9, 39, 13, 16, 40, 14],
  527. [3, 135, 107, 5, 136, 108],
  528. [3, 67, 41, 13, 68, 42],
  529. [15, 54, 24, 5, 55, 25],
  530. [15, 43, 15, 10, 44, 16],
  531. [4, 144, 116, 4, 145, 117],
  532. [17, 68, 42],
  533. [17, 50, 22, 6, 51, 23],
  534. [19, 46, 16, 6, 47, 17],
  535. [2, 139, 111, 7, 140, 112],
  536. [17, 74, 46],
  537. [7, 54, 24, 16, 55, 25],
  538. [34, 37, 13],
  539. [4, 151, 121, 5, 152, 122],
  540. [4, 75, 47, 14, 76, 48],
  541. [11, 54, 24, 14, 55, 25],
  542. [16, 45, 15, 14, 46, 16],
  543. [6, 147, 117, 4, 148, 118],
  544. [6, 73, 45, 14, 74, 46],
  545. [11, 54, 24, 16, 55, 25],
  546. [30, 46, 16, 2, 47, 17],
  547. [8, 132, 106, 4, 133, 107],
  548. [8, 75, 47, 13, 76, 48],
  549. [7, 54, 24, 22, 55, 25],
  550. [22, 45, 15, 13, 46, 16],
  551. [10, 142, 114, 2, 143, 115],
  552. [19, 74, 46, 4, 75, 47],
  553. [28, 50, 22, 6, 51, 23],
  554. [33, 46, 16, 4, 47, 17],
  555. [8, 152, 122, 4, 153, 123],
  556. [22, 73, 45, 3, 74, 46],
  557. [8, 53, 23, 26, 54, 24],
  558. [12, 45, 15, 28, 46, 16],
  559. [3, 147, 117, 10, 148, 118],
  560. [3, 73, 45, 23, 74, 46],
  561. [4, 54, 24, 31, 55, 25],
  562. [11, 45, 15, 31, 46, 16],
  563. [7, 146, 116, 7, 147, 117],
  564. [21, 73, 45, 7, 74, 46],
  565. [1, 53, 23, 37, 54, 24],
  566. [19, 45, 15, 26, 46, 16],
  567. [5, 145, 115, 10, 146, 116],
  568. [19, 75, 47, 10, 76, 48],
  569. [15, 54, 24, 25, 55, 25],
  570. [23, 45, 15, 25, 46, 16],
  571. [13, 145, 115, 3, 146, 116],
  572. [2, 74, 46, 29, 75, 47],
  573. [42, 54, 24, 1, 55, 25],
  574. [23, 45, 15, 28, 46, 16],
  575. [17, 145, 115],
  576. [10, 74, 46, 23, 75, 47],
  577. [10, 54, 24, 35, 55, 25],
  578. [19, 45, 15, 35, 46, 16],
  579. [17, 145, 115, 1, 146, 116],
  580. [14, 74, 46, 21, 75, 47],
  581. [29, 54, 24, 19, 55, 25],
  582. [11, 45, 15, 46, 46, 16],
  583. [13, 145, 115, 6, 146, 116],
  584. [14, 74, 46, 23, 75, 47],
  585. [44, 54, 24, 7, 55, 25],
  586. [59, 46, 16, 1, 47, 17],
  587. [12, 151, 121, 7, 152, 122],
  588. [12, 75, 47, 26, 76, 48],
  589. [39, 54, 24, 14, 55, 25],
  590. [22, 45, 15, 41, 46, 16],
  591. [6, 151, 121, 14, 152, 122],
  592. [6, 75, 47, 34, 76, 48],
  593. [46, 54, 24, 10, 55, 25],
  594. [2, 45, 15, 64, 46, 16],
  595. [17, 152, 122, 4, 153, 123],
  596. [29, 74, 46, 14, 75, 47],
  597. [49, 54, 24, 10, 55, 25],
  598. [24, 45, 15, 46, 46, 16],
  599. [4, 152, 122, 18, 153, 123],
  600. [13, 74, 46, 32, 75, 47],
  601. [48, 54, 24, 14, 55, 25],
  602. [42, 45, 15, 32, 46, 16],
  603. [20, 147, 117, 4, 148, 118],
  604. [40, 75, 47, 7, 76, 48],
  605. [43, 54, 24, 22, 55, 25],
  606. [10, 45, 15, 67, 46, 16],
  607. [19, 148, 118, 6, 149, 119],
  608. [18, 75, 47, 31, 76, 48],
  609. [34, 54, 24, 34, 55, 25],
  610. [20, 45, 15, 61, 46, 16]
  611. ], j.getRSBlocks = function(a, b) {
  612. var c = j.getRsBlockTable(a, b);
  613. if (void 0 == c) throw new Error("bad rs block @ typeNumber:" + a + "/errorCorrectLevel:" + b);
  614. for (var d = c.length / 3, e = [], f = 0; d > f; f++)
  615. for (var g = c[3 * f + 0], h = c[3 * f + 1], i = c[3 * f + 2], k = 0; g > k; k++) e.push(new j(h, i));
  616. return e
  617. }, j.getRsBlockTable = function(a, b) {
  618. switch (b) {
  619. case d.L:
  620. return j.RS_BLOCK_TABLE[4 * (a - 1) + 0];
  621. case d.M:
  622. return j.RS_BLOCK_TABLE[4 * (a - 1) + 1];
  623. case d.Q:
  624. return j.RS_BLOCK_TABLE[4 * (a - 1) + 2];
  625. case d.H:
  626. return j.RS_BLOCK_TABLE[4 * (a - 1) + 3];
  627. default:
  628. return void 0
  629. }
  630. }, k.prototype = {
  631. get: function(a) {
  632. var b = Math.floor(a / 8);
  633. return 1 == (1 & this.buffer[b] >>> 7 - a % 8)
  634. },
  635. put: function(a, b) {
  636. for (var c = 0; b > c; c++) this.putBit(1 == (1 & a >>> b - c - 1))
  637. },
  638. getLengthInBits: function() {
  639. return this.length
  640. },
  641. putBit: function(a) {
  642. var b = Math.floor(this.length / 8);
  643. this.buffer.length <= b && this.buffer.push(0), a && (this.buffer[b] |= 128 >>> this.length % 8), this
  644. .length++
  645. }
  646. };
  647. var l = [
  648. [17, 14, 11, 7],
  649. [32, 26, 20, 14],
  650. [53, 42, 32, 24],
  651. [78, 62, 46, 34],
  652. [106, 84, 60, 44],
  653. [134, 106, 74, 58],
  654. [154, 122, 86, 64],
  655. [192, 152, 108, 84],
  656. [230, 180, 130, 98],
  657. [271, 213, 151, 119],
  658. [321, 251, 177, 137],
  659. [367, 287, 203, 155],
  660. [425, 331, 241, 177],
  661. [458, 362, 258, 194],
  662. [520, 412, 292, 220],
  663. [586, 450, 322, 250],
  664. [644, 504, 364, 280],
  665. [718, 560, 394, 310],
  666. [792, 624, 442, 338],
  667. [858, 666, 482, 382],
  668. [929, 711, 509, 403],
  669. [1003, 779, 565, 439],
  670. [1091, 857, 611, 461],
  671. [1171, 911, 661, 511],
  672. [1273, 997, 715, 535],
  673. [1367, 1059, 751, 593],
  674. [1465, 1125, 805, 625],
  675. [1528, 1190, 868, 658],
  676. [1628, 1264, 908, 698],
  677. [1732, 1370, 982, 742],
  678. [1840, 1452, 1030, 790],
  679. [1952, 1538, 1112, 842],
  680. [2068, 1628, 1168, 898],
  681. [2188, 1722, 1228, 958],
  682. [2303, 1809, 1283, 983],
  683. [2431, 1911, 1351, 1051],
  684. [2563, 1989, 1423, 1093],
  685. [2699, 2099, 1499, 1139],
  686. [2809, 2213, 1579, 1219],
  687. [2953, 2331, 1663, 1273]
  688. ],
  689. o = function() {
  690. var a = function(a, b) {
  691. this._el = a, this._htOption = b
  692. };
  693. return a.prototype.draw = function(a) {
  694. function g(a, b) {
  695. var c = document.createElementNS("http://www.w3.org/2000/svg", a);
  696. for (var d in b) b.hasOwnProperty(d) && c.setAttribute(d, b[d]);
  697. return c
  698. }
  699. var b = this._htOption,
  700. c = this._el,
  701. d = a.getModuleCount();
  702. Math.floor(b.width / d), Math.floor(b.height / d), this.clear();
  703. var h = g("svg", {
  704. viewBox: "0 0 " + String(d) + " " + String(d),
  705. width: "100%",
  706. height: "100%",
  707. fill: b.colorLight
  708. });
  709. h.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xlink", "http://www.w3.org/1999/xlink"), c
  710. .appendChild(h), h.appendChild(g("rect", {
  711. fill: b.colorDark,
  712. width: "1",
  713. height: "1",
  714. id: "template"
  715. }));
  716. for (var i = 0; d > i; i++)
  717. for (var j = 0; d > j; j++)
  718. if (a.isDark(i, j)) {
  719. var k = g("use", {
  720. x: String(i),
  721. y: String(j)
  722. });
  723. k.setAttributeNS("http://www.w3.org/1999/xlink", "href", "#template"), h.appendChild(k)
  724. }
  725. }, a.prototype.clear = function() {
  726. for (; this._el.hasChildNodes();) this._el.removeChild(this._el.lastChild)
  727. }, a
  728. }(),
  729. p = "svg" === document.documentElement.tagName.toLowerCase(),
  730. q = p ? o : m() ? function() {
  731. function a() {
  732. this._elImage.src = this._elCanvas.toDataURL("image/png"), this._elImage.style.display = "block", this
  733. ._elCanvas.style.display = "none"
  734. }
  735. function d(a, b) {
  736. var c = this;
  737. if (c._fFail = b, c._fSuccess = a, null === c._bSupportDataURI) {
  738. var d = document.createElement("img"),
  739. e = function() {
  740. c._bSupportDataURI = !1, c._fFail && _fFail.call(c)
  741. },
  742. f = function() {
  743. c._bSupportDataURI = !0, c._fSuccess && c._fSuccess.call(c)
  744. };
  745. return d.onabort = e, d.onerror = e, d.onload = f, d.src =
  746. "",
  747. void 0
  748. }
  749. c._bSupportDataURI === !0 && c._fSuccess ? c._fSuccess.call(c) : c._bSupportDataURI === !1 && c._fFail &&
  750. c._fFail.call(c)
  751. }
  752. if (this._android && this._android <= 2.1) {
  753. var b = 1 / window.devicePixelRatio,
  754. c = CanvasRenderingContext2D.prototype.drawImage;
  755. CanvasRenderingContext2D.prototype.drawImage = function(a, d, e, f, g, h, i, j) {
  756. if ("nodeName" in a && /img/i.test(a.nodeName))
  757. for (var l = arguments.length - 1; l >= 1; l--) arguments[l] = arguments[l] * b;
  758. else "undefined" == typeof j && (arguments[1] *= b, arguments[2] *= b, arguments[3] *= b, arguments[
  759. 4] *= b);
  760. c.apply(this, arguments)
  761. }
  762. }
  763. var e = function(a, b) {
  764. this._bIsPainted = !1, this._android = n(), this._htOption = b, this._elCanvas = document.createElement(
  765. "canvas"), this._elCanvas.width = b.width, this._elCanvas.height = b.height, a.appendChild(this
  766. ._elCanvas), this._el = a, this._oContext = this._elCanvas.getContext("2d"), this._bIsPainted = !1,
  767. this._elImage = document.createElement("img"), this._elImage.style.display = "none", this._el
  768. .appendChild(this._elImage), this._bSupportDataURI = null
  769. };
  770. return e.prototype.draw = function(a) {
  771. var b = this._elImage,
  772. c = this._oContext,
  773. d = this._htOption,
  774. e = a.getModuleCount(),
  775. f = d.width / e,
  776. g = d.height / e,
  777. h = Math.round(f),
  778. i = Math.round(g);
  779. b.style.display = "none", this.clear();
  780. for (var j = 0; e > j; j++)
  781. for (var k = 0; e > k; k++) {
  782. var l = a.isDark(j, k),
  783. m = k * f,
  784. n = j * g;
  785. c.strokeStyle = l ? d.colorDark : d.colorLight, c.lineWidth = 1, c.fillStyle = l ? d.colorDark : d
  786. .colorLight, c.fillRect(m, n, f, g), c.strokeRect(Math.floor(m) + .5, Math.floor(n) + .5, h, i), c
  787. .strokeRect(Math.ceil(m) - .5, Math.ceil(n) - .5, h, i)
  788. }
  789. this._bIsPainted = !0
  790. }, e.prototype.makeImage = function() {
  791. this._bIsPainted && d.call(this, a)
  792. }, e.prototype.isPainted = function() {
  793. return this._bIsPainted
  794. }, e.prototype.clear = function() {
  795. this._oContext.clearRect(0, 0, this._elCanvas.width, this._elCanvas.height), this._bIsPainted = !1
  796. }, e.prototype.round = function(a) {
  797. return a ? Math.floor(1e3 * a) / 1e3 : a
  798. }, e
  799. }() : function() {
  800. var a = function(a, b) {
  801. this._el = a, this._htOption = b
  802. };
  803. return a.prototype.draw = function(a) {
  804. for (var b = this._htOption, c = this._el, d = a.getModuleCount(), e = Math.floor(b.width / d), f = Math
  805. .floor(b.height / d), g = ['<table style="border:0;border-collapse:collapse;">'], h = 0; d >
  806. h; h++) {
  807. g.push("<tr>");
  808. for (var i = 0; d > i; i++) g.push(
  809. '<td style="border:0;border-collapse:collapse;padding:0;margin:0;width:' + e + "px;height:" + f +
  810. "px;background-color:" + (a.isDark(h, i) ? b.colorDark : b.colorLight) + ';"></td>');
  811. g.push("</tr>")
  812. }
  813. g.push("</table>"), c.innerHTML = g.join("");
  814. var j = c.childNodes[0],
  815. k = (b.width - j.offsetWidth) / 2,
  816. l = (b.height - j.offsetHeight) / 2;
  817. k > 0 && l > 0 && (j.style.margin = l + "px " + k + "px")
  818. }, a.prototype.clear = function() {
  819. this._el.innerHTML = ""
  820. }, a
  821. }();
  822. QRCode = function(a, b) {
  823. if (this._htOption = {
  824. width: 256,
  825. height: 256,
  826. typeNumber: 4,
  827. colorDark: "#000000",
  828. colorLight: "#ffffff",
  829. correctLevel: d.H
  830. }, "string" == typeof b && (b = {
  831. text: b
  832. }), b)
  833. for (var c in b) this._htOption[c] = b[c];
  834. "string" == typeof a && (a = document.getElementById(a)), this._android = n(), this._el = a, this._oQRCode =
  835. null, this._oDrawing = new q(this._el, this._htOption), this._htOption.text && this.makeCode(this
  836. ._htOption.text)
  837. }, QRCode.prototype.makeCode = function(a) {
  838. this._oQRCode = new b(r(a, this._htOption.correctLevel), this._htOption.correctLevel), this._oQRCode
  839. .addData(a), this._oQRCode.make(), this._el.title = a, this._oDrawing.draw(this._oQRCode), this
  840. .makeImage()
  841. }, QRCode.prototype.makeImage = function() {
  842. "function" == typeof this._oDrawing.makeImage && (!this._android || this._android >= 3) && this._oDrawing
  843. .makeImage()
  844. }, QRCode.prototype.clear = function() {
  845. this._oDrawing.clear()
  846. }, QRCode.CorrectLevel = d
  847. }();
  848. </script>
  849. <style>
  850. #mobile {
  851. display: none;
  852. position: absolute;
  853. right: 20px;
  854. box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);
  855. padding: 10px;
  856. text-align: center;
  857. font-size: 12px;
  858. line-height: 31px;
  859. }
  860. </style>
  861. </head>
  862. <body>
  863. <div id="mobile">
  864. <div id="qrcode"></div>
  865. <span>打开手机扫一扫</span>
  866. </div>
  867. <div class="markdown-body" id="markdown-body">
  868. <p>隐私政策</p>
  869. <p>最近更新日期:2025年04月09日</p>
  870. <p>本政策仅适用于数字天堂(北京)网络技术有限公司的DCloud开发者中心系统应用产品或服务。</p>
  871. <p>本政策将帮助您了解以下内容:</p>
  872. <ol>
  873. <li>我们如何收集和使用您的用户信息</li>
  874. <li>我们如何使用 Cookie 和同类技术</li>
  875. <li>我们如何共享、转让、公开披露您的用户信息</li>
  876. <li>我们如何保护您的用户信息</li>
  877. <li>您的权利</li>
  878. <li>我们如何处理儿童的个人信息</li>
  879. <li>您的用户信息如何储存及如何在全球范围转移</li>
  880. <li>本政策如何更新</li>
  881. <li>如何联系我们</li>
  882. </ol>
  883. <p>
  884. 我们深知用户信息对您的重要性,并会尽全力保护您的用户信息安全可靠。我们致力于维持您对我们的信任,恪守以下原则,保护您的用户信息:权责一致原则、目的明确原则、选择同意原则、最少够用原则、确保安全原则、主体参与原则、公开透明原则等。同时,我们承诺,我们将按业界成熟的安全标准,采取相应的安全保护措施来保护您的用户信息。
  885. </p>
  886. <p>请在使用我们的产品(或服务)前,仔细阅读并了解本隐私政策。</p>
  887. <p>一、我们如何收集和使用您的用户信息</p>
  888. <p>我们的产品基于DCloud uni-app x开发,应用运行期间需要收集您的设备唯一识别码(ODID/OAID)以提供统计分析服务,并通过应用启动数据及异常错误日志分析改进性能和用户体验,为用户提供更好的服务。详情内容请访问《DCloud用户服务条款》。</p>
  889. <p>(一)<strong>我们可能会申请以下权限,仅用于演示 uni-app x 框架的功能</strong></p>
  890. <ul>
  891. <li><strong>网络</strong></li>
  892. <li><strong>位置</strong></li>
  893. <li><strong>存储</strong></li>
  894. <li><strong>相册</strong></li>
  895. <li><strong>摄像头</strong></li>
  896. <li><strong>麦克风</strong></li>
  897. <li><strong>蓝牙</strong></li>
  898. <li><strong>联系人</strong></li>
  899. <li><strong>日历</strong></li>
  900. <li><strong>隐私窗口</strong></li>
  901. <li><strong>读取剪贴板</strong></li>
  902. <li><strong>生物特征识别能力</strong></li>
  903. </ul>
  904. <p>(二)<strong>征得授权同意的例外</strong></p>
  905. <p>请您理解,根据法律法规及相关国家标准,以下情形中,我们收集和使用您的用户信息无需征得您的授权同意:</p>
  906. <ol>
  907. <li><strong>与国家安全、国防安全直接相关的;</strong></li>
  908. <li><strong>与公共安全、公共卫生、重大公共利益直接相关的;</strong></li>
  909. <li><strong>与犯罪侦查、起诉、审判和判决执行等直接相关的;</strong></li>
  910. <li><strong>出于维护您或其他个人的生命、财产等重大合法权益但又很难得到本人同意的;</strong></li>
  911. <li><strong>所收集的您的用户信息是您自行向社会公众公开的;</strong></li>
  912. <li><strong>从合法公开披露的信息中收集的您的用户信息,如合法的新闻报道、政府信息公开等渠道;</strong></li>
  913. <li><strong>根据您的要求签订或履行合同所必需的;</strong></li>
  914. <li><strong>用于维护软件及相关服务的安全稳定运行所必需的,例如发现、处置软件及相关服务的故障;</strong></li>
  915. <li><strong>个人信息控制者为新闻单位且其在开展合法的新闻报道所必需的;</strong></li>
  916. <li><strong>学术研究机构基于公共利益开展统计或学术研究所必要,且对外提供学术研究或描述的结果时,对结果中所包含的个人信息进行去标识化处理的。</strong></li>
  917. <li><strong>法律法规规定的其他情形。</strong></li>
  918. </ol>
  919. <p>二、我们如何使用 Cookie 和同类技术</p>
  920. <p>(一)Cookie</p>
  921. <p>为确保网站正常运转,我们会在您的计算机或移动设备上存储名为 Cookie 的小数据文件。Cookie 通常包含标识符、站点名称以及一些号码和字符。借助于 Cookie,网站能够存储您的访问偏好数据。</p>
  922. <p>我们不会将 Cookie 用于本政策所述目的之外的任何用途。您可根据自己的偏好管理或删除 Cookie。您可以清除计算机上保存的所有 Cookie,大部分网络浏览器都设有阻止Cookie
  923. 的功能。但如果您这么做,则需要在每一次访问我们的网站时亲自更改用户设置。</p>
  924. <p>(二)网站信标和像素标签</p>
  925. <p>除 Cookie 外,我们还会在网站上使用网站信标和像素标签等其他同类技术。例如,我们向您发送的电子邮件可能含有链接至我们网站内容的点击URL。</p>
  926. <p>
  927. 如果您点击该链接,我们则会跟踪此次点击,帮助我们了解您的产品或服务偏好并改善客户服务。网站信标通常是一种嵌入到网站或电子邮件中的透明图像。借助于电子邮件中的像素标签,我们能够获知电子邮件是否被打开。如果您不希望自己的活动以这种方式被追踪,则可以随时从我们的寄信名单中退订。
  928. </p>
  929. <p>(三)Do Not Track(请勿追踪)</p>
  930. <p>很多网络浏览器均设有Do Not Track功能,该功能可向网站发布Do Not Track请求。目前,主要互联网标准组织尚未设立相关政策来规定网站应如何应对此类请求。但如果您的浏览器启用了 Do Not
  931. Track,那么我们的所有网站都会尊重您的选择。</p>
  932. <p>三、我们如何共享、转让、公开披露您的用户信息</p>
  933. <p>(一)共享</p>
  934. <p>我们不会与其他的任何公司、组织和个人分享您的用户信息,但以下情况除外:</p>
  935. <ol>
  936. <li>在获取明确同意的情况下共享:获得您的明确同意后,我们会与其他方共享您的用户信息。</li>
  937. <li>我们可能会根据法律法规规定,或按政府主管部门的强制性要求,对外共享您的用户信息。</li>
  938. <li>与我们的关联公司共享:您的用户信息可能会与我们的关联公司共享。我们只会共享必要的用户信息,且受本隐私政策中所声明目的的约束。关联公司如要改变用户信息的处理目的,将再次征求您的授权同意。</li>
  939. <li>
  940. 与授权合作伙伴共享:仅为实现本政策中声明的目的,我们的某些服务将由授权合作伙伴提供。我们可能会与合作伙伴共享您的某些用户信息,以提供更好的客户服务和用户体验。我们仅会出于合法、正当、必要、特定、明确的目的共享您的用户信息,并且只会共享提供服务所必要的用户信息。为了更好运营和改善技术和服务,您同意我们和授权合作伙伴在符合相关法律法规的前提下可将收集的信息用于其他服务和用途。
  941. </li>
  942. </ol>
  943. <p>(二)转让</p>
  944. <p>我们不会将您的用户信息转让给任何公司、组织和个人,但以下情况除外:</p>
  945. <ol>
  946. <li>在获取明确同意的情况下转让:获得您的明确同意后,我们会向其他方转让您的用户信息;</li>
  947. <li>在涉及合并、收购或破产清算时,如涉及到用户信息转让,我们会再要求新的持有您用户信息的公司、组织继续受此隐私政策的约束,否则我们将要求该公司、组织重新向您征求授权同意。</li>
  948. </ol>
  949. <p>(三)公开披露</p>
  950. <p>我们仅会在以下情况下,公开披露您的用户信息:</p>
  951. <ol>
  952. <li>获得您明确同意后;</li>
  953. <li>基于法律的披露:在法律、法律程序、诉讼或政府主管部门强制性要求的情况下,我们可能会公开披露您的用户信息。</li>
  954. </ol>
  955. <p>(四)共享、转让、公开披露信息时事先征得授权同意的例外</p>
  956. <p>请您理解,根据法律法规及相关国家标准,以下情形中,我们共享、转让、公开披露您的用户信息无需征得您的授权同意:</p>
  957. <ol>
  958. <li>与国家安全、国防安全直接相关的;</li>
  959. <li>与公共安全、公共卫生、重大公共利益直接相关的;</li>
  960. <li>与犯罪侦查、起诉、审判和判决执行等直接相关的;</li>
  961. <li>出于维护您或其他个人的生命、财产等重大合法权益但又很难得到本人同意的;</li>
  962. <li>您自行向社会公众公开的信息;</li>
  963. <li>从合法公开披露的信息中收集的,如合法的新闻报道、政府信息公开等渠道。</li>
  964. </ol>
  965. <p>四、我们如何保护您的用户信息</p>
  966. <ol>
  967. <li>我们已使用符合业界标准的安全防护措施保护您提供的用户信息,防止数据遭到未经授权的访问、公开披露、使用、修改、损坏或丢失。我们会采取一切合理可行的措施,保护您的用户信息。例如,在您的浏览器与“服务”之间交换数据时受
  968. SSL
  969. 加密保护;我们同时对网站提供https安全浏览方式;我们会使用加密技术确保数据的保密性;我们会使用受信赖的保护机制防止数据遭到恶意攻击;我们会部署访问控制机制,确保只有授权人员才可访问用户信息;以及我们会举办安全和隐私保护培训课程,加强员工对于保护用户信息重要性的认识。
  970. </li>
  971. <li>目前,我们的重要信息系统已通过信息安全等级保护(三级)测评和备案。</li>
  972. <li>我们已建立专门的管理系统、流程和组织,确保信息安全。例如,我们严格限制有信息访问权限的人员,要求这些人员遵循其保密义务,并对此进行审查。</li>
  973. <li>我们会采取一切合理可行的措施,确保未收集无关的用户信息。我们只会在达成本政策所述目的所需的期限内保留您的用户信息,除非需要延长保留期或受到法律的允许。</li>
  974. <li>互联网并非绝对安全的环境,而且电子邮件、即时通讯、及与其他用户的交流方式并未加密,我们强烈建议您不要通过此类方式发送用户信息。</li>
  975. <li>我们将定期更新并公开安全风险、用户信息安全影响评估等报告的有关内容。您可通过以下方式获得:</li>
  976. <li>
  977. 互联网环境并非百分之百安全,我们将尽力确保您发送给我们的任何信息的安全性。即使我们做出了很大努力,采取了一切合理且必要的措施,仍然有可能无法杜绝您的用户信息被非法访问、被非法盗取,被非法篡改或毁坏,导致您的合法权益受损,请您理解信息网络的上述风险并自愿承担。
  978. </li>
  979. <li>
  980. 在不幸发生用户信息安全事件后,我们将按照法律法规的要求,及时向您告知:安全事件的基本情况和可能的影响、我们已采取或将要采取的处置措施、您可自主防范和降低风险的建议、对您的补救措施等。我们将及时将事件相关情况以邮件、信函、电话、推送通知等方式告知您,难以逐一告知用户信息主体时,我们会采取合理、有效的方式发布公告。同时,我们还将按照监管部门要求,主动上报用户信息安全事件的处置情况。
  981. </li>
  982. </ol>
  983. <p>五、您的权利</p>
  984. <p>按照中国相关的法律、法规、标准,以及其他国家、地区的通行做法,我们保障您对自己的用户信息行使以下权利:</p>
  985. <p>(一)访问您的用户信息</p>
  986. <p>您有权访问您的用户信息,法律法规规定的例外情况除外。如果您想行使数据访问权,可以通过以下方式自行访问:<a
  987. href="https://ask.dcloud.net.cn/">https://ask.dcloud.net.cn/</a></p>
  988. <p>如果您无法通过上述链接访问这些用户信息,您可以随时使用我们的 Web 表单联系,或发送电子邮件至<a
  989. href="mailto:service@dcloud.io">service@dcloud.io</a>。我们将在30天内回复您的访问请求。</p>
  990. <p>对于您在使用我们的产品或服务过程中产生的其他用户信息,只要我们不需要过多投入,我们会向您提供。如果您想行使数据访问权,请发送电子邮件至<a
  991. href="mailto:service@dcloud.io">service@dcloud.io</a>。</p>
  992. <p>(二)更正您的用户信息</p>
  993. <p>当您发现我们处理的关于您的用户信息有错误时,您有权要求我们作出更正。您可以通过“(一)访问您的用户信息”中罗列的方式提出更正申请。 如果您无法通过上述链接更正这些用户信息,您可以随时使用我们的 Web
  994. 表单联系,或发送电子邮件至<a href="mailto:service@dcloud.io">service@dcloud.io</a>。我们将在30天内回复您的更正请求。</p>
  995. <p>(三)删除您的用户信息</p>
  996. <p>在以下情形中,您可以向我们提出删除用户信息的请求:</p>
  997. <ol>
  998. <li>如果我们处理用户信息的行为违反法律法规;</li>
  999. <li>如果我们收集、使用您的用户信息,却未征得您的同意;</li>
  1000. <li>如果我们处理用户信息的行为违反了与您的约定;</li>
  1001. <li>如果您不再使用我们的产品或服务,或您注销了账号;</li>
  1002. <li>如果我们不再为您提供产品或服务。</li>
  1003. </ol>
  1004. <p>
  1005. 我们将会根据您的删除请求进行评估,若满足相应规定,我们将会采取相应步骤进行处理。当您向我们提出删除请求时,我们可能会要求您进行身份验证,以保障账户的安全。当您从我们的服务中删除信息后,因为适用的法律和安全技术,我们可能不会立即从备份系统中删除相应的信息,我们将安全存储您的信息直到备份可以清除或实现匿名化。
  1006. </p>
  1007. <p>(四)改变您授权同意的范围</p>
  1008. <p>每个业务功能需要一些基本的用户信息才能得以完成(见本政策“第一部分”)。对于用户信息的收集和使用,您可以随时给予或收回您的授权同意。您可以通过以下方式自行操作:<a
  1009. href="https://ask.dcloud.net.cn/">https://ask.dcloud.net.cn/</a></p>
  1010. <p>当您收回同意后,我们将不再处理相应的用户信息。同时也请您注意,您撤销授权同意可能会导致某些后果,例如我们可能无法继续为您提供相应的服务或特定的功能,但您收回同意的决定,不会影响此前基于您的授权而开展的用户信息处理。</p>
  1011. <p>(五)用户信息主体注销账户</p>
  1012. <p>您随时可注销此前注册的账户,您可以通过以下方式自行操作:<a href="https://ask.dcloud.net.cn/">https://ask.dcloud.net.cn/</a></p>
  1013. <p>在注销账户之后,我们将停止为您提供产品或服务并依据您的要求,删除或匿名化您的信息,法律法规另有规定的除外。这也将可能导致您失去对您账户中数据的访问权,请您谨慎操作。</p>
  1014. <p>(六)用户信息主体获取用户信息副本</p>
  1015. <p>您有权获取您的用户信息副本,您可以通过以下方式自行操作:<a href="https://ask.dcloud.net.cn/">https://ask.dcloud.net.cn/</a></p>
  1016. <p>在技术可行的前提下,例如数据接口匹配,我们还可按您的要求,直接将您的用户信息副本传输给您指定的第三方。</p>
  1017. <p>(七)约束信息系统自动决策</p>
  1018. <p>在某些业务功能中,我们可能仅依据信息系统、算法等在内的非人工自动决策机制作出决定。如果这些决定显著影响您的合法权益,您有权要求我们作出解释,我们也将提供适当的救济方式。</p>
  1019. <p>(八)响应您的上述请求</p>
  1020. <p>为保障安全,您可能需要提供书面请求,或以其他方式证明您的身份。我们可能会先要求您验证自己的身份,然后再处理您的请求。</p>
  1021. <p>我们将在三十天内作出答复。如您不满意,还可以通过以下途径投诉:<a href="mailto:service@dcloud.io">service@dcloud.io</a></p>
  1022. <p>
  1023. 对于您合理的请求,我们原则上不收取费用,但对多次重复、超出合理限度的请求,我们将视情况收取一定成本费用。对于那些无端重复、需要过多技术手段(例如,需要开发新系统或从根本上改变现行惯例)、给他人合法权益带来风险或者非常不切实际的请求,我们可能会予以拒绝。也请您理解,出于安全保障的考虑、相关法律法规的要求或技术上的限制,对于您的某些请求我们可能无法做出响应,例如以下情形:
  1024. </p>
  1025. <ol>
  1026. <li>与用户信息控制者履行法律法规规定的义务相关的;</li>
  1027. <li>与国家安全、国防安全直接相关的;</li>
  1028. <li>与公共安全、公共卫生、重大公共利益直接相关的;</li>
  1029. <li>与犯罪侦查、起诉、审判和执行判决等直接相关的;</li>
  1030. <li>用户信息控制者有充分证据表明用户信息主体存在主观恶意或滥用权利的;</li>
  1031. <li>出于维护用户信息主体或其他个人的生命、财产等重大合法权益但又很难得到本人同意的;</li>
  1032. <li>响应用户信息主体的请求将导致用户信息主体或其他个人、组织的合法权益受到严重损害的;</li>
  1033. <li>涉及商业秘密的。</li>
  1034. </ol>
  1035. <p>六、我们如何处理儿童的个人信息</p>
  1036. <p>我们非常重视儿童个人信息的保护,我们的产品、网站和服务主要面向成人。如果没有父母或监护人的同意,儿童不应创建自己的用户账户。尽管当地法律和习俗对儿童的定义不同,但我们将不满 14 周岁的任何人均视为儿童。</p>
  1037. <p>对于经父母或监护人同意而收集儿童用户信息的情况,我们只会在受到法律允许、父母或监护人明确同意或者保护儿童所必要的情况下储存、使用或公开披露此信息,否则我们会设法尽快删除相关数据。</p>
  1038. <p>
  1039. 鉴于现有技术和业务模式的限制,我们很难主动识别儿童的个人信息,如果您发现我们在不知情的情况下或在未事先获得可证实的监护人同意的情况下收集了儿童的个人信息,您可以及时联系我们,我们将在发现后设法及时删除,如果我们自己发现前述情形的,我们也会及时删除,法律要求我们保留的除外。
  1040. </p>
  1041. <p>七、您的用户信息如何储存以及如何在全球范围转移</p>
  1042. <p>
  1043. 原则上,我们在中华人民共和国境内收集和产生的用户信息,将存储在中华人民共和国境内。我们只会在本政策所述目的和用途所需的期限内和法律法规规定的最短期限内保留您的用户信息,超出上述保留期间后,我们会根据适用法律法规的要求删除您的用户信息或匿名化处理。法律法规另有规定,或出于公共利益、科学历史研究等的目的,或您的另行授权同意的除外,我们可能需要较长时间保留相关数据。
  1044. </p>
  1045. <p>由于我们通过遍布全球的资源和服务器提供产品或服务,这意味着,在获得您的授权同意后,您的用户信息可能会被转移到您使用产品或服务所在国家/地区的境外管辖区,或者受到来自这些管辖区的访问。</p>
  1046. <p>
  1047. 此类管辖区可能设有不同的数据保护法,甚至未设立相关法律。在此类情况下,我们会确保您的用户信息得到在中华人民共和国境内足够同等的保护。例如,我们会请求您对跨境转移用户信息的同意,或者在跨境数据转移之前实施数据去标识化等安全举措。
  1048. </p>
  1049. <p>八、本政策如何更新</p>
  1050. <p>我们的隐私政策可能变更。未经您明确同意,我们不会削减您按照本隐私政策所应享有的权利。我们会在本页面上发布对本政策所做的任何变更。</p>
  1051. <p>对于重大变更,我们还会提供更为显著的通知。本政策所指的重大变更包括但不限于:</p>
  1052. <ol>
  1053. <li>我们的服务模式发生重大变化。如处理用户信息的目的、处理的用户信息类型、用户信息的使用方式等;</li>
  1054. <li>我们在所有权结构、组织架构等方面发生重大变化。如业务调整、破产并购等引起的所有者变更等;</li>
  1055. <li>用户信息共享、转让或公开披露的主要对象发生变化;</li>
  1056. <li>您参与用户信息处理方面的权利及其行使方式发生重大变化;</li>
  1057. <li>我们负责处理用户信息安全的责任部门、联络方式及投诉渠道发生变化时;</li>
  1058. <li>用户信息安全影响评估报告表明存在高风险时。</li>
  1059. </ol>
  1060. <p>我们还会将本政策的旧版本存档,供您查阅。</p>
  1061. <p>九、如何联系我们</p>
  1062. <p>如果您对本隐私政策有任何疑问、意见或建议,通过以下方式与我们联系:</p>
  1063. <p>电子邮件:<a href="mailto:service@dcloud.io">service@dcloud.io</a></p>
  1064. <p>一般情况下,我们将在三十天内回复。</p>
  1065. <p>如果您对我们的回复不满意,特别是我们的用户信息处理行为损害了您的合法权益,您还可以通过以下外部途径寻求解决方案:<a
  1066. href="mailto:service@dcloud.io">service@dcloud.io</a></p>
  1067. </div>
  1068. <script type="text/javascript">
  1069. var sUserAgent = navigator.userAgent;
  1070. if (sUserAgent.indexOf('Android') > -1 || sUserAgent.indexOf('iPhone') > -1 || sUserAgent.indexOf('iPad') > -1 ||
  1071. sUserAgent.indexOf('iPod') > -1 || sUserAgent.indexOf('Symbian') > -1) {
  1072. //手机端不显示二维码
  1073. } else {
  1074. var qrcode = new QRCode(document.getElementById("qrcode"), {
  1075. text: location.href,
  1076. width: 160,
  1077. height: 160
  1078. });
  1079. document.getElementById("mobile").style.display = "block"
  1080. }
  1081. </script>
  1082. </body>
  1083. </html>