utilHelper.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. /**
  2. * @desc : 유효한 주민번호인지 점검한다.
  3. * <pre>
  4. * 1. 주민번호 13자리중 12자리를 처음부터 A라고 하면 12자리
  5. * 까지만 다음식을 시행한다.
  6. * Total = (A * 2) + (B * 3) + (C * 4) + (D * 5) + (E * 6)
  7. * + (F * 7) + (G * 8) + (H * 9) + (I * 2) + (J * 3)
  8. * + (K * 4) + (L * 5)
  9. * 2. Total을 11로 나눈 나머지를 취한다. --> X
  10. * 3. 나머지를 11에서 뺀 차를 취한다. --> 11 - X = Y
  11. * 4. 차를 구한 값을 다시 10으로나눈 나머지를 취한다.
  12. * --> Y % 10 = Z
  13. * 5. 1,2,3,4에서 구한 값이 주민번호 끝자리가 된다. --> 'Z'
  14. * 6. 'Z'와 끝자리수를 비교해서 틀리면 주민번호 오류.
  15. * </pre>
  16. * @param : pResidnetNo - 구분자를 제외한 주민번호 13자리 문자열
  17. * @return : true/false
  18. * @---------------------------------------------------
  19. */
  20. function isResidentNo(pResidnetNo)
  21. {
  22. if(isNaN(pResidnetNo)) return false;
  23. if(pResidnetNo.length != 13) return false;
  24. var c = pResidnetNo.substr(6,1);
  25. if(c == '5' || c == '6') return true;
  26. last = pResidnetNo.substr(12,1);
  27. regNo = new Array(12); regNo[12] = 0;
  28. for(var i = 0; i < (regNo.length - 1); i++) {
  29. regNo[i] = eval(pResidnetNo.substr(i, 1)) * ((i % 8) + 2);
  30. }
  31. for(var i = 0; i < (regNo.length - 1); i++) {
  32. regNo[12] += regNo[i];
  33. }
  34. var result = ((11 - (regNo[12] % 11)) % 10);
  35. if(result == eval(last)) {
  36. return true;
  37. } else {
  38. //주민등록번호가 유효하지 않은 경우, 외국인 주민등록번호 체크 로직 수행
  39. return isForegnResidentNo(pResidnetNo);
  40. }
  41. }
  42. /**
  43. * @desc : 현재일자를 기준으로 나이계산
  44. * @param : pResidentNo - 중간 구분자를 제외한 주민번호 13자리
  45. * @param : pDate - 기준이 되는 Date Object 일자 (default는 오늘 일자)
  46. * @param : pPosition - 1세이하시 개월 계산
  47. * <pre>
  48. *
  49. * 함수 호출시 다음과 같은 두가지 형태로 사용한다.
  50. *
  51. * 1) getFullAge("1234567890123"); --> 오늘 일자를 기준으로 나이계산
  52. * 2) getFullAge("1234567890123", date); --> parameter 값으로 넘겨받은 date를 기준으로 나이계산
  53. *
  54. * </pre>
  55. * @return : 숫자 (오류시 -1)
  56. * @---------------------------------------------------
  57. */
  58. function getFullAge(pResidentNo, pDate, pPosition)
  59. {
  60. if(isNaN(pResidentNo)) return -1;
  61. var pivotYY = "";
  62. var pivotMM = "";
  63. var pivotDD = "";
  64. var regYY = "";
  65. var regMM = "";
  66. var regDD = "";
  67. if(typeof(pDate) == "undefined" || pDate == "" || pDate == null) {
  68. var today = new Date();
  69. pivotYY = today.getYear();
  70. pivotMM = today.getMonth() + 1;
  71. pivotDD = today.getDate();
  72. } else {
  73. pivotYY = pDate.getYear();
  74. pivotMM = pDate.getMonth() + 1;
  75. pivotDD = pDate.getDate();
  76. }
  77. if(pResidentNo.length == 13 && isResidentNo(pResidentNo)){
  78. gender = pResidentNo.substr(6, 1);
  79. regYY = eval(pResidentNo.substr(0, 2));
  80. regMM = eval(pResidentNo.substr(2, 2));
  81. regDD = eval(pResidentNo.substr(4, 2));
  82. if(gender == '3' || gender == '4' || gender == '7' || gender == '8') {
  83. regYY += 2000;
  84. } else if(gender == '0' || gender == '9') {
  85. regYY += 1800;
  86. } else {
  87. regYY += 1900;
  88. }
  89. }else if(pResidentNo.length == 8 && isValidDateTime(pResidentNo, "YYYYMMDD")){
  90. regYY = eval(pResidentNo.substr(0, 4));
  91. regMM = eval(pResidentNo.substr(4, 2));
  92. regDD = eval(pResidentNo.substr(6, 2));
  93. }else{
  94. return -1;
  95. }
  96. var age = pivotYY - regYY;
  97. if(age > 0) {
  98. if(pivotMM == regMM) {
  99. if(pivotDD < regDD) {
  100. age -= 1;
  101. }
  102. } else if(pivotMM < regMM) {
  103. age -= 1;
  104. }
  105. }
  106. if ( pPosition == "M")
  107. {
  108. //12개월이하일때 계산
  109. if(age <= 0){
  110. if(pivotYY > regYY) {
  111. pivotMM += 12;
  112. }
  113. age = pivotMM - regMM ;
  114. if(pivotDD < regDD) {
  115. age -= 1;
  116. }
  117. age = "0."+age;
  118. }
  119. }
  120. return age;
  121. }
  122. /**
  123. * @desc : 성별을 Return
  124. * @param : pResidnetNo - 중간 구분자를 제외한 주민번호 13자리 혹은 주민번호 뒤 7자리 문자열
  125. * @return : M(ale)/F(emale) , 오류시 "" 반환
  126. * @---------------------------------------------------
  127. */
  128. function getGender(pResidentNo)
  129. {
  130. if(pResidentNo.length != 13 && pResidentNo.length != 7) return false;
  131. var rrns = 0;
  132. if(pResidentNo.length == 13) {
  133. rrns = eval(pResidentNo.substr(6, 1));
  134. } else {
  135. rrns = eval(pResidentNo.substr(0, 1));
  136. }
  137. return (rrns % 2) ? "M" : "F";
  138. }
  139. /**
  140. * @desc : 유효한 사업자 등록번호인지 점검
  141. * @param : pWorkNo - 구분자를 제외한 사업자 등록번호
  142. * @return : true/false
  143. * @---------------------------------------------------
  144. */
  145. function isBusinessNo(pWorkNo)
  146. {
  147. if(isNaN(pWorkNo)) return false;
  148. if(pWorkNo.length != 10) return false;
  149. var chkValue = new Array(1,3,7,1,3,7,1,3,5);
  150. var epNo = new Array(10);
  151. for(var i = 0; i < 10; i++) epNo[i] = eval(pWorkNo.substr(i, 1));
  152. for(var i = 0, sum = 0; i < 9; i++) sum += epNo[i] * chkValue[i];
  153. sum += ((epNo[8] * 5) / 10);
  154. var mod = sum % 10;
  155. var epNoChk = ((mod == 0) ? 0 : 10 - mod);
  156. return ((epNoChk == epNo[9]) ? true : false);
  157. }
  158. /**
  159. * @desc : 메일이 올바른지 검사한다.
  160. * @param : pEmail - eMail 주소
  161. * @return : true/false
  162. * @---------------------------------------------------
  163. */
  164. function isEMail(pEmail)
  165. {
  166. var email = pEmail.split("@");
  167. if(email.length != 2) return false;
  168. if(email[0].replace(/(^\s*)|(\s*$)/g, "").length == 0) return false;
  169. var domain = email[1].split(".");
  170. if(domain.length != 2 || domain.length != 3) return false;
  171. if(domain[0].replace(/(^\s*)|(\s*$)/g, "").length == 0) return false;
  172. if(domain[1].replace(/(^\s*)|(\s*$)/g, "").length == 0) return false;
  173. return true;
  174. }
  175. /**
  176. * @desc : 올바른 DDD번호인지 점검 (필요할까?)
  177. * @param : pDDD - DDD 번호 문자열 혹은 숫자
  178. * @return : true/false
  179. * @---------------------------------------------------
  180. */
  181. function isTelephoneZoneNo(pDDD)
  182. {
  183. //pDDD 숫자 점검 logic 필요
  184. var strDDD = pDDD + "";
  185. if( strDDD != "02" &&
  186. strDDD != "031" &&
  187. strDDD != "032" &&
  188. strDDD != "033" &&
  189. strDDD != "041" &&
  190. strDDD != "042" &&
  191. strDDD != "043" &&
  192. strDDD != "051" &&
  193. strDDD != "052" &&
  194. strDDD != "053" &&
  195. strDDD != "054" &&
  196. strDDD != "055" &&
  197. strDDD != "061" &&
  198. strDDD != "062" &&
  199. strDDD != "063" &&
  200. strDDD != "064" ) return false;
  201. return true;
  202. }
  203. /**
  204. * @desc : 파일을 읽어 TextStream을 반환
  205. * @param : pFilePath - 파일의 Full Path
  206. * @param : pMode - Optional. File 읽기,쓰기 Mode
  207. * @return : 파일의 TextStream
  208. * @deprecated : 사용하지 않음. - 필요시 요청할것.
  209. * @---------------------------------------------------
  210. var OpenFileForReading = 1 ;
  211. var OpenFileForWriting = 2 ;
  212. var OpenFileForAppending = 8 ;
  213. function getReadFile(pFilePath, pMode)
  214. {
  215. var fso = new ActiveXObject("Scripting.FileSystemObject");
  216. var TextStream;
  217. if (pMode == null) {
  218. TextStream = fso.OpenTextFile(pFilePath, OpenFileForReading);
  219. } else {
  220. TextStream = fso.OpenTextFile(pFilePath, pMode);
  221. }
  222. return TextStream;
  223. }
  224. */
  225. /**
  226. * @desc : 파일 Copy
  227. * @param : srcFilePath
  228. * @param : targetFilePath
  229. * @deprecated : 사용하지 않음. - 필요시 요청할것.
  230. * @---------------------------------------------------
  231. function getCopyFile(srcFilePath, targetFilePath)
  232. {
  233. var fso = new ActiveXObject("Scripting.FileSystemObject");
  234. var sLine;
  235. var File = fso.GetFile(srcFilePath)
  236. var TextStream = File.OpenAsTextStream(OpenFileForReading)
  237. var MyFile = fso.CreateTextFile(targetFilePath, true)
  238. while(!TextStream.AtEndOfStream)
  239. {
  240. sLine = TextStream.ReadLine() + "\r\n";
  241. MyFile.WriteLine(sLine);
  242. }
  243. TextStream.Close();
  244. MyFile.Close();
  245. }
  246. */
  247. //바코드 폰트를 등록한다.
  248. function installBarcodeFont(fontNm){
  249. // 2008.02.19 해당 ocx 변경. - 김기호
  250. //body.createChild("xforms:object", "id:obj_barcodefont; clsid:{ad1a9e73-cddd-4636-b4aa-f121453af3bb}; visibility:hidden; left:0px; top:0px; width:0px; height:0px; ");
  251. body.createChild("xforms:object", "id:LiveUtil; clsid:{7b1f53ab-6137-4773-88cc-53a46af2d289}; visibility:hidden; left:0px; top:0px; width:0px; height:0px;");
  252. if (fontNm == null || fontNm == "") {
  253. fontNm = "FREE3OF9.TTF";
  254. }
  255. LiveUtil.installFont(fontNm);
  256. }
  257. /**
  258. * @desc : 외국인 주민등록번호에 대한 검증을 수행
  259. */
  260. function isForegnResidentNo(pResidnetNo) {
  261. var sum = 0;
  262. var odd = 0;
  263. buf = new Array(13);
  264. for (i = 0; i < 13; i++) {
  265. buf[i] = parseInt(pResidnetNo.charAt(i));
  266. }
  267. odd = buf[7]*10 + buf[8];
  268. //기관번호 검사, 기관번호를 2로 나눈 경우, 나머지 있는 경우, 주민등록번호 무효
  269. if (odd%2 != 0) {
  270. return false;
  271. }
  272. //등록자구분이 아래와 같지 않은 경우 오류
  273. // 6 : ??
  274. // 7 : 외국국적동포
  275. // 8 : 재외국인
  276. // 9 : 순수외국인
  277. if ((buf[11] != 6)&&(buf[11] != 7)&&(buf[11] != 8)&&(buf[11] != 9)) {
  278. return false;
  279. }
  280. //주민번호 13자리 중 12자리를 처음부터 12자리까지 배열값의 순서대로 곱한 후 합계를 낸다.
  281. //Total = (A * 2) + (B * 3) + (C * 4) + (D * 5) + (E * 6) + (F * 7)
  282. // + (G * 8) + (H * 9) + (I * 2) + (J * 3) + (K * 4) + (L * 5)
  283. multipliers = [2,3,4,5,6,7,8,9,2,3,4,5];
  284. for (i = 0, sum = 0; i < 12; i++) {
  285. sum += (buf[i] *= multipliers[i]);
  286. }
  287. sum=11-(sum%11);
  288. if (sum>=10) sum-=10;
  289. sum += 2;
  290. if (sum>=10) sum-=10;
  291. if ( sum != buf[12]) {
  292. return false;
  293. }
  294. else {
  295. return true;
  296. }
  297. }