1. 程式人生 > >js各類驗證和資料處理

js各類驗證和資料處理

/**
 * 驗證密碼複雜度(必須包含數字字母)
 * @param str
 * @returns true:滿足規則,false:不滿足
 */
function validateStr(str){
	var reg1 = /^(([0-9]{1,})([a-z]{1,}))|(([a-z]{1,})([0-9]{1,}))$/;
	var reg2 = /^(([0-9]{1,})([A-Z]{1,}))|(([A-Z]{1,})([0-9]{1,}))$/;
	//var reg3 = /^([a-zA-Z]{0,})[0-9a-z-A-z]{0,}[~`[email protected]#$%^&*.]{0,}$/;
	str = valueTrim(str);
	//if(reg3.test(str)){
	//	return true;
	//}
	if(reg1.test(str)){
		return true;
	}
	if(reg2.test(str)){
		return true;
	}
	return false;
}




/**
 * 判斷字串長度 必須大於8位小於20位,一般用於密碼
 * @param str 字串
 * @returns 滿足返回true
 */
function valiDateLength(str){
	if(str==null || str==''){
		return false;
	}
	str = valueTrim(str);
	if(parseFloat(str.length)<8 ){
		return false;
	}
	if(parseFloat(str.length)>20){
		return false;
	}
	return true;
}
/**
 * 驗證時間
 * @param dataValue 格式為:YYYY-MM-DD
 * @returns 匹配返回true 不匹配返回false
 */
function valiDate(dateValue){
	var result = dateValue.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/);
	if(result==null){
		return false;
	}
	return true;
}


/**
 * 驗證電話號碼
 * @param phoneValue 要驗證的電話號碼
 * @returns 匹配返回true 不匹配返回false
 */
function validatePhone(phoneValue) {
	phoneValue = valueTrim(phoneValue);
	var reg = /^[1][0-9]{10}$/;
	return reg.test(phoneValue);
}
/**
 * 驗證郵箱
 * @param emailValue 要驗證的郵箱
 * @returns 匹配返回true 不匹配返回false
 */
function validateEmail(emailValue){
	var reg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
	return reg.test(emailValue);
}
/**
 * 判斷是否是數字
 * @param numberValue 要驗證的資料
 * @returns 匹配返回true 不匹配返回false
 */
function isNumber(numberValue){
	//定義正則表示式部分    
	var reg1 = /^[0-9]{0,}$/;
	var reg2 = /^[1-9]{1}[0-9]{0,}$/;
	//alert(numberValue);
	if(numberValue ==null || numberValue.length==0){
		return false;
	}
	numberValue = valueTrim(numberValue);
	//判斷當數字只有1位時
	if(numberValue.length<2){
		return reg1.test(numberValue);
	}
	return reg2.test(numberValue);;
}
/***
 * 金額
 * @param value
 * @returns
 */
function isMoney(value) {
	if(value==''){
		return false;
	}
	value = valueTrim(value);
	value = value.replace(/(^\s*)|(\s*$)/g, "");
	var reg = /^[0-9]*\.?[0-9]{0,2}$/;
	if(isNumber(value)){
		return true;
	}
	if(value.length>3){
		if(value.substr(0, 1)=="0"){
			if(value.substr(3,value.length).length>2){
				return false;
			} 
		}
	}
	return reg.test(value);
}
/***
 * 判斷是否是0到100之間的數
 * @param value
 * @returns
 */
function isZeroToOne(value) {
	if(value==''){
		return false;
	}
	value = valueTrim(value);
	if(isMyFloat(value)){
		if(parseFloat(value)<100 && parseFloat(value)>0){
			return true;
		}
	}
	return false;
}


/**
 * 驗證是否是浮點數
 * @param floatValue 要驗證的資料
 * @returns 匹配返回true 不匹配返回false
 */
function isMyFloat(floatValue){
	if(floatValue==''){
		return false;
	}
	floatValue = valueTrim(floatValue);
	var reg = /^(\d+)(\.\d+)$/;
	if(isNumber(floatValue)){
		return true;
	}
	if(floatValue.length>3){
		if(floatValue.substr(0, 1)=="0"){
			if(floatValue.substr(0, 2)!="0."){
				return false;
			} 
		}
	}
	return reg.test(floatValue);
}
/**
 * 判斷是否是漢字
 * @param charValue 要驗證的資料
 * @returns 匹配返回true 不匹配返回false
 */
function isCharacter(charValue){
	var reg = /^[\u4e00-\u9fa5]{0,}$/;
	return reg.test(charValue);
}
/**
 * 驗證座機號
 * @param telValue 要驗證的座機號
 * @returns 匹配返回true 不匹配返回false
 */
function valiDateTel(telValue){
	var reg = /^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$/;
	telValue = valueTrim(telValue);
	if(!reg.test(telValue)){
		return false;
    }
	return true;
}


var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ];    // 加權因子   
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];            // 身份證驗證位值.10代表X
/**
 * 驗證身份證
 * @param idCard 需要驗證的身份證號
 * @returns 匹配返回true 不匹配返回false
 */
function IdCardValidate(idCardValue) {
	//去掉字串頭尾空格
	idCardValue = valueTrim(idCardValue.replace(/ /g, ""));                     
    if (idCardValue.length == 15) {
    	//進行15位身份證的驗證 
        return isValidityBrithBy15IdCard(idCardValue);   
    } else if (idCardValue.length == 18) {
    	// 得到身份證陣列  
        var a_idCard = idCardValue.split(""); 
        //進行18位身份證的基本驗證和第18位的驗證
        if(isValidityBrithBy18IdCard(idCardValue)&&isTrueValidateCodeBy18IdCard(a_idCard)){
            return true;   
        }else {   
            return false;
        }   
    } else {
        return false;   
    }   
}   
/**  
 * 判斷身份證號碼為18位時最後的驗證位是否正確  
 * @param a_idCard 身份證號碼陣列  
 * @return  
 */  
function isTrueValidateCodeBy18IdCard(a_idCard) {   
    var sum = 0; // 宣告加權求和變數   
    if (a_idCard[17].toLowerCase() == 'x') {   
        a_idCard[17] = 10;// 將最後位為x的驗證碼替換為10方便後續操作   
    }   
    for ( var i = 0; i < 17; i++) {   
        sum += Wi[i] * a_idCard[i];// 加權求和   
    }   
    valCodePosition = sum % 11; // 得到驗證碼所位置   
    if (a_idCard[17] == ValideCode[valCodePosition]) {   
        return true;   
    } else {   
        return false;   
    }   
}   
/**  
  * 驗證18位數身份證號碼中的生日是否是有效生日  
  * @param idCard 18位書身份證字串  
  * @return  
  */  
function isValidityBrithBy18IdCard(idCard18){   
    var year =  idCard18.substring(6,10);   
    var month = idCard18.substring(10,12);   
    var day = idCard18.substring(12,14);   
    var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));   
    // 這裡用getFullYear()獲取年份,避免千年蟲問題   
    if(temp_date.getFullYear()!=parseFloat(year)   
          ||temp_date.getMonth()!=parseFloat(month)-1   
          ||temp_date.getDate()!=parseFloat(day)){   
            return false;   
    }else{   
        return true;   
    }   
}   
/**  
  * 驗證15位數身份證號碼中的生日是否是有效生日  
  * @param idCard15 15位書身份證字串  
  * @return  
  */  
function isValidityBrithBy15IdCard(idCard15){   
   var year =  idCard15.substring(6,8);   
   var month = idCard15.substring(8,10);   
   var day = idCard15.substring(10,12);   
   var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));   
   // 對於老身份證中的你年齡則不需考慮千年蟲問題而使用getYear()方法   
   if(temp_date.getYear()!=parseFloat(year)   
           ||temp_date.getMonth()!=parseFloat(month)-1   
           ||temp_date.getDate()!=parseFloat(day)){   
       return false;   
   }else{   
       return true;   
   }   
}   
//去掉字串頭尾空格   
function valueTrim(str) {   
    return str.replace(/(^\s*)|(\s*$)/g, "");   
}


/**
 * 檢驗18位身份證號碼(15位號碼可以只檢測生日是否正確即可,自行解決)
 * @param idCardValue 18位身份證號
 * @returns 匹配返回true 不匹配返回false
 */
function idCardVildate(cid){
    var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加權因子
    var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校驗碼
    var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/;
    if(reg.test(cid)){
        var sum = 0, idx;
        for(var i = 0; i < cid.length - 1; i++){
            // 對前17位數字與權值乘積求和
            sum += parseInt(cid.substr(i, 1), 10) * arrExp[i];
        }
        // 計算模(固定演算法)
        idx = sum % 11;
        // 檢驗第18為是否與校驗碼相等
        return arrValid[idx] == cid.substr(17, 1).toUpperCase();
    }else{
        return false;
    }
}


/**
 * 獲取指定日期之前或之後的第幾天
 * 
 * @param dayCount
 *            正數為以後時間,負數為以前時間 如:1表示為明天,-1為昨天
 * 
 */
function getDateStr(dates, dayCount) {
	var dateTime = dayCount * 24 * 60 * 60 * 1000;
	var dd = new Date();
	if (dates == "") {
		dd = new Date();
	} else {
		dd = new Date(dates);
	}
	var dateNumber = dd.getTime() + dateTime;
	var newDate = new Date(dateNumber);
	var y = newDate.getFullYear();
	var m = newDate.getMonth() + 1;// 獲取當前月份的日期
	var d = newDate.getDate();
	if (m < 10) {
		m = "0" + m;
	}
	if (d < 10) {
		d = "0" + d;
	}
	return y + "-" + m + "-" + d;
}
/**
 * 獲取指定月份的之前或之後的第幾個月
 * 
 * @param dayCount
 *            正數為以後月份,負數為以前月份 如:1表示為下月,-1為上月
 * 
 */
function getMonthStr(dates, monthCount) {
	var dd = new Date();
	if (dates == "") {
		dd = new Date();
	} else {
		dd = new Date(dates);
	}
	var y = dd.getFullYear();
	var m = dd.getMonth() + 1;// 獲取當前月份的日期
	m = m + monthCount;
	if (m == 0) {
		m = "12";
		y = y - 1;
	} else if (m < 10) {
		m = "0" + m;
	} else if (m > 12) {
		m = m - 12;
		m = "0" + m;
		y = y + 1;
	}
	return y + "-" + m;
}
/**
*
*對val值為undefined返回“”,否則返回原值
*/
function dealNull(val) {
	if (typeof (val) == "undefined") {
		return "";
	} else {
		return val;
	}
}

原文連結:http://blog.csdn.net/mr_smile2014/article/details/52084048

相關推薦

js各類驗證資料處理

/** * 驗證密碼複雜度(必須包含數字字母) * @param str * @returns true:滿足規則,false:不滿足 */ function validateStr(str){ var reg1 = /^(([0-9]{1,})([a-z]{1,

js前端驗證繞過

func 修改 span 執行 分享 sca rup ini src 一、js前端驗證 本篇基於上篇,修改了form.html 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4

js math 對數指數處理 expm1 log1p

pan style 應用 clas bsp mic ini exp spa 1、Math.expm1() Math.expm1(x)返回 ex - 1,即Math.exp(x) - 1。 Math.expm1(-1) // -0.6321205588285577

kettle案例五使用js指令碼進行json資料處理新增行

我們通過兩個例子來學習Js處理資料新增行: 例子一字串拆分 按照原始資料列”aaa bbb ccc ddd”把資料分成4行。 比如我們有原始資料行如下: id group person 1 A aaa bbb ccc ddd 我們需

https原理:證書傳遞、驗證資料加密、解密過程解析

寫的太好了,就是我一直想找的內容,看了這個對https立馬明白多了 我們都知道HTTPS能夠加密資訊,以免敏感資訊被第三方獲取。所以很多銀行網站或電子郵箱等等安全級別較高的服務都會採用HTTPS協議。 HTTPS簡介 HTTPS其實是有兩部分組成:HTTP + SSL / TLS,也就是在HTTP上又加了

sklearn中的交叉驗證資料劃分

給定一個訓練資料集合,尋找一個模型去fit這個訓練資料,如果在全部的訓練資料上訓練獲得模型並且在全部的訓練資料上測試模型,則測試結果會很好; 但是對於未知的資料泛化效果會很不好,即過擬合。所以需要在不同的資料集上訓練和測試。 import numpy as np from

Falcon(一)——資料集管理資料處理平臺

目的: 使終端使用者在面向Hadoop叢集進行資料集處理和資料集管理更加容易。 原因 在Hadoop環境中,在各種資料集和處理關係之間建立關係 在叢集中進行資料集管理例如資料集宣告週期、資料集複製等 抓取資料集或者處理過程的血統資訊。 允許本地資料和

【 D3.js 選擇集與資料詳解 — 4 】 enterexit的處理方法以及處理模板

繫結資料之後,選擇集分為三部分:update、enter、exit。這三部分的處理辦法是什麼呢?本文將講解其處理方法,以及一個常用的處理模板。1. enter的處理方法如果沒有足夠的元素,那麼處理方法通常是使用append()新增元素。請看下面的程式碼:[javascript

node 利用crypto進行hash加密URLSafeBase64處理 (node.js郵箱驗證)

最近用node.js做註冊郵箱驗證時,用到urlBase64位字串: //實現思路: //1、資料庫表中新增一個啟用的狀態欄位0或1 (0為未啟用,1未啟用),在新增一個驗證碼欄位valida

Python下的資料處理機器學習,對資料線上及本地獲取、解析、預處理訓練、預測、交叉驗證、視覺化

<!doctype html> <html> <head> <title>Example Domain</title> <meta charset="utf-8" /> <meta http-equiv=

新思科技釋出Seeker最新版本 可針對基於 Web 的應用進行主動驗證敏感資料跟蹤

法國Parkeon公司託管企業服務部首席資訊保安官曾經表示:“我們選擇Seeker是因為測試人員和開發人員不需要投入很多時間或者具備十分專業的知識就可以定期執行安全測試任務。Seeker提供漏洞與受影響原始碼之間的關聯,從而減少開發人員的工作量。 近日,美國新思科技公司(Synopsys,

R語言-預測海藻數量1(資料準備缺失資料處理)

準備工作 安裝要用到得到包 install.packages("DMwR") 載入並檢視資料 > library(lattice) > library(grid) > library(DMwR) > summary(algae) season

時間格式的處理資料填充分頁---laravel

時間格式文件地址:http://carbon.nesbot.com/docs/   這是些時間格式,只需要我們這麼做就可以 我們在模板層,找到對應的模型物件那裡進行處理就可以啦 2018-11-08 16:10:32 轉換 Nov 8, 2018 這樣就ok了  

spring5-驗證資料繫結型別轉換

5.1 介紹 {#toc_1} JSR-303/JSR-349 Bean Validation 在設定支援方面,Spring Framework 4.0支援Bean Validation 1.0(JSR-303)和Bean Validation 1.1(JSR-349),也將其改寫成了Spr

pythonshell處理資料的程式整理

1把檔案按行拼接(shell腳步) 檔案f1 1 2 3 filename=$1 abc=`cat $filename | awk ' BEGIN{count=1;str=""} {     if(count==1)  

資料處理神器map-reduce實現(僅pythonshell版本)

熟悉java的人直接可以使用java實現map-reduce過程,而像我這種不熟悉java的怎麼辦?為了讓非java程式設計師方便處理資料,我把使用python,shell實現streaming的過程,也即為map-reduce過程,整理如下: 1.如果資料不在hive裡面,而在

Asp.net 面向介面可擴充套件框架之資料處理模組及EntityFramework擴充套件Dapper擴充套件(含乾貨)

原文: Asp.net 面向介面可擴充套件框架之資料處理模組及EntityFramework擴充套件和Dapper擴充套件(含乾貨) 介面資料處理模組是什麼意思呢?實際上很簡單,就是使用面向介面的思想和方式來做資料處理。 還提到EntityFramework和Dapper,EntityFramework和

js jquery驗證上傳檔案的格式大小

// 驗證附件格式和大小 function confirmData() { var flag = true; var message = ""; var errorSize = ""; var fileSuffix = $("#fileSuffix").val(

IOS資料處理及版本特性-NSKeyedArchiver儲存解析

建立一個繼承自物件的類可被序列化和反序列化,這樣的話就可以歸檔到磁碟中火網路中 import Foundation class UserModel: NSObject , NSCoding {     var name:NSString!     va

資料入門環境搭建整理、大資料入門系列教程合集、大資料生態圈技術整理彙總、大資料常見錯誤合集、大資料的離線實時資料處理流程分析

本篇文章主要整理了筆者學習大資料時整理的一些文章,文章是從環境搭建到整個大資料生態圈的常用技術整理,環境希望可以幫助到剛學習大資料到童鞋,大家在學習過程中有問題可以隨時評論回覆! 大資料生態圈涉及技術: Hadoop、MapReduce、HDFS、Hive、Hbase、Spark、Scala