fieldIsAllow.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. import {toString} from "./typeTool";
  2. let requiredRuleItem = {require: true,message:'该项为必填项'}
  3. let phoneRule = [{
  4. type: 'string',
  5. length: 11,
  6. message: '手机号长度必须是11字符'
  7. },{
  8. regex: /^1(3\d|4[5-9]|5[0-35-9]|6[2567]|7[0-8]|8\d|9[0-35-9])\d{8}$/,
  9. message: '手机号格式不正确'
  10. }]
  11. let passwordRule= [{
  12. type: 'string',
  13. minLength: 6,
  14. maxLength: 18,
  15. message: '密码长度为6-18'
  16. }]
  17. let imeiRule = [{
  18. type: 'string',
  19. length: 15,
  20. message: 'IMEI号长度应该为15位'
  21. }]
  22. const ownerRule= [
  23. requiredRuleItem,
  24. {
  25. type: 'string',
  26. minLength: 1,
  27. maxLength: 16,
  28. message: '用户名owner类型或者长度不一致'
  29. },
  30. ]
  31. const captchaRule = [{
  32. type: 'string',
  33. length: 4,
  34. message: '验证码长度为4'
  35. }]
  36. const nameRule = [
  37. {
  38. type: 'string',
  39. min: 1,
  40. max: 25,
  41. message: '名称长度不符合'
  42. }
  43. ]
  44. const hrefRule = [
  45. {
  46. type: 'string',
  47. min: 1,
  48. max: 500,
  49. message: '链接长度不符合'
  50. },
  51. {
  52. type: 'string',
  53. // 是否符合url地址,支持域名与ip/^http(s)?:\/\/([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?$/
  54. regex: /(https?|ftp|file):\/\/[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[-A-Za-z0-9+&@#/%=~_|]/,
  55. message: '链接格式不正确'
  56. },
  57. ];
  58. const requireIdRule = [
  59. requiredRuleItem,
  60. ]
  61. let checkCode = function (val) {
  62. let p = /^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
  63. let factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
  64. let parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
  65. let code = val.substring(17);
  66. if(p.test(val)) {
  67. let sum = 0;
  68. for(let i=0;i<17;i++) {
  69. sum += val[i]*factor[i];
  70. }
  71. console.log(typeof parity[sum % 11])
  72. console.log(typeof code.toUpperCase())
  73. if(toString(parity[sum % 11]) === code.toUpperCase()) {
  74. return true;
  75. }
  76. }
  77. return false;
  78. }
  79. let checkDate = function (val) {
  80. var pattern = /^(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)$/;
  81. if(pattern.test(val)) {
  82. var year = val.substring(0, 4);
  83. var month = val.substring(4, 6);
  84. var date = val.substring(6, 8);
  85. var date2 = new Date(year+"-"+month+"-"+date);
  86. if(date2 && date2.getMonth() === (parseInt(month) - 1)) {
  87. return true;
  88. }
  89. }
  90. return false;
  91. }
  92. let checkProv = function (val) {
  93. let pattern = /^[1-9][0-9]/;
  94. let provs = {11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江 ",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北 ",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏 ",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门"};
  95. if(pattern.test(val)) {
  96. if(provs[val]) {
  97. return true;
  98. }
  99. }
  100. return false;
  101. }
  102. const checkID = function (val) {
  103. if(checkCode(val)) {
  104. console.log('code')
  105. let date = val.substring(6,14);
  106. if(checkDate(date)) {
  107. if(checkProv(val.substring(0,2))) {
  108. console.log('匹配成功')
  109. return true;
  110. }
  111. }
  112. }
  113. return false;
  114. }
  115. const cardRule = [
  116. requiredRuleItem,
  117. function(val){
  118. return checkID(val)?'':'身份证验证失败';
  119. }]
  120. const paramsRules = [
  121. {
  122. keys: ['name','workerName','buildingName','entranceName'],
  123. rules: nameRule,
  124. },
  125. {
  126. keys: ['imei','IMEI','Imei'],
  127. rules: imeiRule,
  128. },
  129. {
  130. keys: ['workerType','type','cameraType','buildingAbout','entranceId'],
  131. rules: [requiredRuleItem],
  132. },
  133. {
  134. keys: ['phone','workerPhone','companyPhone'],
  135. rules: phoneRule,
  136. },
  137. {
  138. keys:['captcha','captchaImg'],
  139. rules:captchaRule
  140. },
  141. {
  142. keys:['owner','account'],
  143. rules:ownerRule
  144. },
  145. {
  146. keys:['passwd', 'password'],
  147. rules:passwordRule
  148. },
  149. {
  150. keys: ['card', 'workerCard'],
  151. rules: cardRule,
  152. },
  153. {
  154. keys: ['href', 'url'],
  155. rules: hrefRule,
  156. },
  157. {
  158. keys: [/id/gi,'fileData'],
  159. rules: requireIdRule
  160. }
  161. ]
  162. function _isEmpty(s) {
  163. return s === undefined || s === '';
  164. }
  165. // code 1 通过
  166. // code 2 不通过
  167. // code 3 无对应的
  168. let code_pass = 1,
  169. code_notPass = 2,
  170. code_notMatch = 3;
  171. function _c(key,value){
  172. // 查找对应规则
  173. let _obj = paramsRules.find(item=>{
  174. // 判断是否为正则
  175. for (const _matchKey of item.keys) {
  176. // 判断是否为正则
  177. if(_matchKey instanceof RegExp){
  178. // console.log(`使用正则进行匹配,${_matchKey.test(key)}`);
  179. if(_matchKey.test(key)){
  180. // console.log(`通过正则匹配规则成功,${_matchKey.test(key)}`);
  181. return true;
  182. }
  183. }else{
  184. // console.log(`比较是否全等,${_matchKey} === ${key} ?${_matchKey === key}`);
  185. if(_matchKey === key){
  186. // console.log(`通过字符${_matchKey}匹配成功`);
  187. return true;
  188. };
  189. }
  190. }
  191. return false;
  192. });
  193. console.log(_obj)
  194. if(!_obj || !_obj.rules){
  195. return [code_notMatch];
  196. }
  197. // 开始匹配规则
  198. for(let _rule of _obj.rules ){
  199. if(typeof _rule === 'function'){
  200. let _msg = _rule(value);
  201. // console.log(_msg)
  202. if(_msg){
  203. return [code_notPass,_msg]
  204. }
  205. }
  206. if(_rule.require && _isEmpty(value)){
  207. return [code_notPass, _rule.message]
  208. }
  209. if(_rule.type && typeof value !== _rule.type){
  210. return [code_notPass, _rule.message]
  211. }
  212. if(_rule.length && value.length !== _rule.length){
  213. return [code_notPass, _rule.message]
  214. }
  215. if(_rule.minLength && value.length < _rule.minLength){
  216. return [code_notPass, _rule.message]
  217. }
  218. if(_rule.maxLength && value.length > _rule.maxLength){
  219. return [code_notPass, _rule.message]
  220. }
  221. if(_rule.regex && !_rule.regex.test(value)){
  222. return [code_notPass, _rule.message]
  223. }
  224. }
  225. return [code_pass]
  226. }
  227. /**
  228. * 检查对应字段值是否符合规则,不规则则返回对应的错误码
  229. * @param _o
  230. * @param isMustMatch
  231. * @returns {string|*}
  232. */
  233. function checkField(_o,isMustMatch=false){
  234. console.log(_o)
  235. for (const _oKey in _o) {
  236. let value = _o[_oKey];
  237. let r = _c(_oKey,value);
  238. if(r[0] === code_notPass){
  239. return r[1]
  240. }else if(isMustMatch && r[0] === code_notMatch){
  241. return `字段没有对应匹配项`
  242. }
  243. }
  244. }
  245. export default checkField;