最全的javascript验证数字乱码等问题
web开发中js导致乱码解决方案
web开发中js导致乱码解决方案web开发中不可避免会使用js,为了给页面良好的瘦身我们一般都会将js代码放在外部,然后通过src引用,如果web页面与js采用的编码方式不一致,就会产生乱码,接下来与大家分享下解决方法,感兴趣的朋友可以参考下哈在web开发中我们一般都会不可避免的使用js。
我们可以将js代码直接放在页面中即通过内部使用js。
但是为了给页面良好的"瘦身"我们一般都会将js代码放在外部,然后通过s rc引用。
这个时候我们就需要注意一个问题:编码问题。
如果web页面与js采用不同编码,这个时候就会出现乱码。
(内部使用js不需要注意编码问题,因为他们采用的是同一种编码)对于大多数的web页面,我们一般都是使用如下两种编码:UTF-8、GB2312。
所以我们只需要统一页面和js编码就可以解决乱码问题:对于GBK页面引用编码为UTF-8编码的JavaScript文件如果出现乱码问题,可以使用下面的代码来解决复制代码代码如下:<script type=”text/javascript” src=”test.js” charset=”utf-8″></script>同样在UTF-8页面中引入编码为GBK的JavaScript文件乱码问题了,可以使用如下方式:复制代码代码如下:<script type=”text/javascript” src=”test.js” charset=”gb2312″></script>此方法是对于在js文件中出现汉字中文,以及其他容易造成在GBK与UTF-8编码错误字符的时候使用,对于纯英文的就不需要了。
如果为了保险,加上也可以....。
js数字字符串判断方法
js数字字符串判断方法判断一个字符串是否为数字可以使用多种方法。
以下是一些常见的方法:1. 使用isNaN函数,JavaScript中的isNaN函数可以用来判断一个值是否为NaN(非数字)。
当传入的参数无法被转换为数字时,isNaN函数返回true,否则返回false。
因此,可以利用这一特性来判断一个字符串是否为数字。
示例代码:javascript.function isNumeric(str) {。
return !isNaN(str);}。
console.log(isNumeric('123')); // true.console.log(isNumeric('abc')); // false.2. 使用正则表达式,可以使用正则表达式来判断一个字符串是否符合数字的格式。
例如,可以使用/^[-+]?[0-9]+(\.[0-9]+)?$/.test(str)来判断一个字符串是否为整数或浮点数。
示例代码:javascript.function isNumeric(str) {。
return /^[-+]?[0-9]+(\.[0-9]+)?$/.test(str);}。
console.log(isNumeric('123')); // true.console.log(isNumeric('abc')); // false.3. 使用parseInt或parseFloat函数,可以尝试使用parseInt或parseFloat函数将字符串转换为数字,然后判断转换后的结果是否为NaN。
如果不是NaN,则说明字符串是一个数字。
示例代码:javascript.function isNumeric(str) {。
return !isNaN(parseInt(str)) &&isFinite(parseFloat(str));}。
js几种常用的数据校验方法
js几种常用的数据校验方法在前端开发中,数据校验是非常重要的一环。
通过对用户输入的数据进行校验,可以有效地防止错误数据的提交,提高系统的安全性和稳定性。
下面将介绍几种常用的js数据校验方法。
1. 正则表达式校验正则表达式是一种强大的文本匹配工具,可以用来对字符串进行复杂的校验。
在js中,可以使用RegExp对象来创建正则表达式,并使用test()方法来进行匹配校验。
例如,可以使用正则表达式来校验手机号码的格式是否正确:```javascriptfunction validatePhone(phone) {var reg = /^1[3456789]\d{9}$/;return reg.test(phone);}```2. 内置校验方法在HTML5中,提供了一些内置的校验方法,可以直接在表单元素上使用。
例如,可以使用required属性来校验必填项,使用type属性来校验输入的数据类型。
例如,可以使用type="email"来校验邮箱地址的格式是否正确:```html<input type="email" required>```3. 自定义校验方法除了使用正则表达式和内置校验方法外,还可以自定义校验方法来满足特定的需求。
可以通过编写自定义函数来实现校验逻辑,并在需要校验的地方调用该函数。
例如,可以自定义一个校验密码强度的方法:```javascriptfunction validatePassword(password) {// 校验密码强度的逻辑// ...return true; // 返回校验结果}```4. 第三方库校验除了自己编写校验方法外,还可以使用一些第三方库来简化数据校验的过程。
例如,jQuery Validation是一个常用的表单校验插件,可以通过简单的配置来实现各种校验需求。
使用该插件可以方便地对表单进行校验,并提供了丰富的错误提示功能。
完美解决JS中汉字显示乱码问题(已解决)
完美解决JS中汉字显⽰乱码问题(已解决)如题,刚才看了⼏篇⼤家的讨论,忽然也想起要将⾃⼰最近研究的问题贴出来,凡是和JS中乱码相关的问题都发到这⾥把,⼤家⼀起研究。
:)场景⼀:write写出来的内容是utf-8格式的,如果保存的write数据中有不是utf-8编码的中⽂,对write嵌套俩次以上就会有乱码。
由于⼿头没有现成的⽂件,刚才临时制作了⼀个,这是1.htm页⾯的代码:复制代码代码如下:<html><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312"><script language="JavaScript" src="1.js"></script></head><body onload=myjs(1)></body></html>这是引⽤的1.js⽂件代码,俩个⽂件均⽤简体中⽂保存⽽不是utf-8复制代码代码如下://这是JS递归⾃写过程中汉字乱码的演⽰程序//不光是中⽂内容不⾏,就连注释如果是中⽂有时候也不⾏//感觉JS⼀碰上中⽂就变得很不稳定=_='//Dec. 29th 2005 created by shouhaimu(QQ:30836570)function myjs(i){var t="<html>\n";t+="<head>\n";t+="<meta http-equiv='Content-Type' content='text/html; charset=gb2312'>\n";t+="<script language='JavaScript' src='1.js'></script>\n";t+="</head>\n";t+="<body>\n";t+="<input type=button onclick=myjs("+(i+1)+" value='这是演⽰程序,已经运⾏了"+i+"次!'>\n";//上⾯这⾏如果改成下⾯这句就可以正常显⽰,看来确实是JS对汉字的⽀持不够好://t+="<input type=button onclick=myjs("+(i+1)+" value='This is my code,it has run "+i+" times!'>\n";t+="</body>\n";t+="</html>\n";document.open();document.write(t);document.close();}运⾏第2次以上就会有乱码。
如何在JavaScript中实现表单的验证和数据校验
如何在JavaScript中实现表单的验证和数据校验表单验证和数据校验在Web开发中非常重要,可以确保用户提供的数据符合预期并在后端进行处理。
在JavaScript中,可以使用各种技术和库来实现表单验证和数据校验。
接下来,我将为您提供一种基本的方法,用于实现表单验证和数据校验。
1. HTML5表单验证HTML5提供了一些表单验证的内置功能,可以在客户端进行基本的数据校验。
以下是一些常用的HTML5表单验证属性:- required:设置字段为必填字段,如果没有填写将无法提交表单。
- pattern:使用正则表达式验证字段的值。
- type属性验证:比如email类型会验证输入是否为有效的电子邮件地址。
这些HTML5表单验证属性可以帮助我们在不使用JavaScript的情况下进行表单校验。
然而,它们的功能有限,无法满足特定的验证需求。
2.自定义JavaScript表单验证自己编写JavaScript代码来实现表单验证可以很灵活,满足更多的验证需求。
以下是一个基本的示例代码,用于验证表单字段:```javascript//获取表单元素和错误提示元素const form = document.querySelector('form');const errorElement = document.getElementById('error');form.addEventListener('submit', (event) => {event.preventDefault(); //阻止表单提交//验证表单字段const name = document.getElementById('name').value;const email = document.getElementById('email').value;if (name === '' || email === '') {errorElement.textContent = '请填写所有字段';return;}if (!validateEmail(email)) {errorElement.textContent = '请输入有效的电子邮件地址'; return;}//提交表单form.submit();});//验证电子邮件地址的函数function validateEmail(email) {const re = /^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;return re.test(String(email).toLowerCase());}```上述代码通过添加事件监听器来捕获表单的提交事件。
JavaScript中代码错误排查与修复技巧
JavaScript中代码错误排查与修复技巧JavaScript是一种广泛使用的脚本语言,但由于其动态性和弱类型特性,常常容易出现错误。
为了排查和修复这些错误,开发人员需要掌握一些技巧和方法。
以下是一些常见的JavaScript代码错误排查与修复技巧。
1.使用开发者工具浏览器提供了强大的开发者工具,可以帮助我们调试JavaScript代码。
其中包括控制台(console)、断点调试(debugger)、性能分析器(profiler)等工具。
通过使用这些工具,我们可以查看变量值、调用堆栈、错误消息等信息,从而更好地理解和排查错误。
2.仔细阅读错误消息当JavaScript代码出现错误时,浏览器会显示错误消息。
仔细阅读错误消息,可以帮助我们确定错误的类型和位置。
错误消息通常包含错误类型、文件名、行数等信息,这些信息对于定位错误非常重要。
3.缩小错误范围当出现错误时,我们可以通过逐步缩小错误范围来定位问题所在。
可以通过注释代码的方式或者分步执行代码的方式,逐步排除可能出错的部分。
当确定问题所在后,就可以针对性地进行修复。
4.使用断言和异常处理断言(assertion)和异常处理(exception handling)是JavaScript 代码中常用的技术。
断言可以帮助我们在代码中设置预期条件,以便在运行时验证这些条件是否成立。
异常处理则用于捕获和处理代码运行时发生的异常。
通过使用这些技术,我们可以更早地发现和处理错误。
5.编写单元测试单元测试可以帮助我们验证代码的正确性,并在代码发生变动后发现潜在的错误。
使用测试框架,编写各种场景的测试用例,以覆盖代码的不同执行路径和边界条件。
通过运行这些单元测试,我们可以更好地捕捉和修复潜在的错误。
6.代码审查和团队合作在项目开发过程中,通过代码审查和团队合作也可以发现和修复错误。
代码审查可以帮助我们发现潜在的问题,并提供改进的建议。
团队合作可以让我们共同面对问题,并集思广益,找到最佳的解决方案。
JavaScript代码调试与错误排查的方法与工具
JavaScript代码调试与错误排查的方法与工具JavaScript作为一种广泛应用于网页开发和前端技术的编程语言,调试和错误排查是开发过程中不可或缺的一部分。
本文将介绍一些常用的方法和工具,以帮助开发人员更高效地进行JavaScript代码调试与错误排查。
一、使用浏览器内置的开发者工具进行调试现代浏览器都内置了强大的开发者工具,提供了一系列调试功能。
其中,常用的调试功能包括:1. 控制台(Console):开启浏览器的开发者工具,切换到控制台选项卡,可以查看和调试JavaScript代码。
在控制台中,可以输出日志、检查变量的值、执行代码片段等。
2. 断点调试(Breakpoints):在代码中设置断点,可以暂停代码的执行,以便逐行查看和分析代码执行过程。
开发者可以在断点暂停时检查变量的值、观察代码执行流程等。
3. 监视器(Watch):使用监视器功能,可以跟踪和观察指定变量的值的变化,帮助开发者更好地理解代码的执行情况。
4. 堆栈追踪(Stack Trace):在调试过程中,浏览器会记录代码的调用栈,即从主函数开始到当前执行位置的函数调用序列。
通过堆栈追踪,可以溯源到错误发生的代码位置,便于快速定位问题。
二、使用eslint等静态代码检查工具静态代码检查工具可以帮助开发人员在编码阶段发现潜在的问题和错误,并提供相应的修复建议。
其中,eslint是一款广泛使用的JavaScript静态代码检查工具。
通过在代码中添加eslint规则,可以在代码编写过程中实时检查错误和潜在问题,提高代码质量。
eslint支持自定义规则,并提供了一系列预设规则,涵盖了JavaScript编码中的各个方面。
开发人员可以根据自己的项目需求和编码规范进行配置。
三、使用Chrome DevTools的追踪和性能分析功能除了常规的调试功能,Chrome DevTools还提供了一些高级的追踪和性能分析工具,帮助开发人员更深入地理解和优化JavaScript代码。
javascript验证数字特殊字符乱码
更多 是否为正整数 信息
是否为电话号码
/*
用途:检查输入字符串是否符合国内固话或者传真格式
输入:
s:字符串 格式例如:020-87110252
返回:
如果通过验证返回true,否则返回false
*/
function isTel(s){
if(r==null)return false;
var d= new Date(r[1], r[3]-1, r[5]);
...
更多 判断是否是日期 信息
字母数字下划线
/*
用途:检查输入字符串是否只由英文字母和数字和下划线组成
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
var reg=/^((0\d{2,3})-)?(\d{7,8})(-(\d{3,}))?$/;
if(!reg.test(s))...
更多 是否为电话号码 信息
是否为端口号
/*
用途:检查输入对象的值是否符合端口号格式
输入:str 输入的字符串
返回:如果通过验证返回true,否则返回false
输入:str
返回:
如果全是空返回true,否则返回false
*/
function isNull(str) {
if (str == "") return true;
var regu = "^[ ]+$";
.....
更多 为空或全是空格 信息
判断是否是日期
/*
如何使用JavaScript实现表单验证和数据校验
如何使用JavaScript实现表单验证和数据校验表单验证和数据校验在网页开发中是非常重要的一环。
通过对用户输入的表单数据进行验证和校验,可以保证数据的完整性和准确性,从而提高用户体验和数据的可靠性。
下面我们将介绍如何使用JavaScript实现表单验证和数据校验。
一、表单验证的基本原理表单验证的基本原理是通过JavaScript代码对用户输入的表单数据进行检查和验证。
在用户提交表单之前,我们可以通过编写一些验证规则和逻辑来检查表单中的每个输入字段是否符合要求,如是否为空、是否为数字、长度是否满足要求等等。
如果表单数据不符合验证规则,则需要提示用户进行修正,直到表单数据完全符合要求才能提交。
二、如何编写表单验证的JavaScript代码1. 获取表单对象首先,我们需要获取表单对象,这可以通过使用JavaScript中的`document.getElementById()`方法来实现。
例如,如果表单的id属性为"myForm",则可以使用以下代码获取该表单对象:```javascriptvar form = document.getElementById("myForm");```2. 绑定表单提交事件接下来,我们需要为表单提交按钮绑定一个事件处理函数。
当点击提交按钮时,我们将运行该事件处理函数,该函数可以对表单数据进行验证和校验。
绑定表单提交事件可以通过给表单对象的`onsubmit`属性赋值一个事件处理函数来实现。
例如:```javascriptform.onsubmit = function() {// 在此处进行表单验证和数据校验的代码}```3. 编写表单验证逻辑在表单提交事件处理函数中,我们可以编写自定义的表单验证逻辑。
根据具体的需求,我们可以使用一些常见的验证规则进行判断,如判断是否为空,判断是否是数字,判断长度是否满足要求等等。
以下是一些常见的表单验证代码示例:```javascriptif (input.value === "") {alert("请输入内容");return false;}if (isNaN(input.value)) {alert("请输入数字");return false;}if (input.value.length < 6) {alert("密码长度不能少于6位");return false;}```在验证过程中,如果发现表单数据不符合要求,可以通过`alert()`、`console.log()`等方法进行提示。
JSP验证码大全之验证码使用与乱码解决
JSP验证码大全之验证码使用与乱码解决2009-06-22 14:51 以上两篇文章的内容介绍了有关JSP中产生数字验证码跟中文验证码的源代码并做了分析,本文中介绍如何对以上产生的数字跟中文验证码进行使用,以及如何解决中文验证码的乱码无法正确验证的问题。
对验证码的使用分为两个部分,分别为验证码的调用和验证过程,以下分别做说明介绍。
三、在JSP中调用验证码使用验证码直接在图片处调用产生验证码的JSP文件即可,同时在刷新验证码按钮处的js代码中使用JSP验证码文件,页面源码如下。
<form id="dForm" method=post action="val.jsp"><ul class="sFrm"><li><b></b><img id="code" border=0 src="Num.jsp"/><input type="button" value="看不清,换一张" onClick="document.getElementById('code').src='ColorChinese.jsp'"><div class="clear0"></div></li> <li><b>验证码</b><input type="text" name="input" maxlength=8 value="" styleClass="sIpt itemFm "><div class="clear0"></div></li><li class="bar"><b></b><input type="submit" value="验证测试" styleClass="logbtn3"></li></ul></form>四、在JSP中验证码的验证过程以及中文乱码处理获取用户输入的验证码并与Session中的验证码比较,相同即通过,否则拒绝,对于JSP中中文验证码的处理注意要在页面中定义JSP页面编码跟获取Session的字符编码一致,此处使用的是统一的GB2312编码,否则将出现验证码无法成功验证的情况。
js使用时遇到的一些问题的解决方法
js使用时遇到的一些问题的解决方法
一、客户端脚本引擎的问题
1. 无法识别 JavaScript 语法
解决办法:检查 JavaScript 语法是否正确,以及其它相关配置,如 HTML 代码中的 <script> 标记、文件编码等。
2. 无法解析 JavaScript 语句
解决办法:检查 JavaScript 语法是否正确,如缺少分号或不正确的结构等。
3. 当前客户端脚本引擎可能会有所不同
解决办法:检查当前客户端脚本版本是否有所更新,根据客户端的版本来决定是否需要更改 JavaScript 语法,以便在客户端的脚本引擎中执行。
二、内存管理的问题
1. JavaScript 中的引用计数内存泄漏
解决办法:检查 JavaScript 中的引用计数,使用合理的内存管理手段,如缓存器,来避免内存泄漏。
2. 内存溢出问题
解决办法:使用良好的程序设计,避免内存溢出,尽量使用内存缓存来减少重复分配内存的情况,以及释放不再使用的内存,从而最大限度地节省内存。
三、浏览器兼容性问题
1. CSS 兼容的问题
解决办法:使用浏览器的开发者工具来查看不同浏览器的 CSS 支持情况,并根据不同浏览器的具体情况来使用兼容的 CSS 语法。
2. JavaScript 兼容的问题
解决办法:检查 JavaScript 代码中的兼容性问题,使用相应的兼容性库或框架来解决浏览器兼容性问题。
四、网络连接问题
1. 超时问题
解决办法:检查服务器端网络连接是否正常,可以使用 Ajax 重试技术来处理超时问题。
2. 请求头丢失
解决办法:检查服务器端网络连接是否正常,并重新发送请求头。
JSURL传中文参数引发的乱码问题
JSURL传中⽂参数引发的乱码问题解决⽅法如下:1、在JS⾥对中⽂参数进⾏两次转码复制代码代码如下:var login_name = document.getElementById("loginname").value;login_name = encodeURI(login_name);login_name = encodeURI(login_name);2、在服务器端对参数进⾏解码复制代码代码如下:String loginName = ParamUtil.getString(request, "login_name");loginName = .URLDecoder.decode(loginName,"UTF-8");在使⽤url进⾏参数传递时,经常会传递⼀些中⽂名的参数或URL地址,在后台处理时会发⽣转换错误。
在有些传递页⾯使⽤GB2312,⽽在接收页⾯使⽤UTF8,这样接收到的参数就可能会与原来发⽣不⼀致。
使⽤服务器端的urlEncode函数编码的URL,与使⽤客户端javascript的encodeURI函数编码的URL,结果就不⼀样。
javaScript中的编码⽅法:escape() ⽅法:采⽤ISO Latin字符集对指定的字符串进⾏编码。
所有的空格符、标点符号、特殊字符以及其他⾮ASCII字符都将被转化成%xx 格式的字符编码(xx等于该字符在字符集表⾥⾯的编码的16进制数字)。
⽐如,空格符对应的编码是%20。
unescape⽅法与此相反。
不会被此⽅法编码的字符: @ * / +如果是gb2312编码的可以使⽤escape,不能⽤encodeURIComponent,要不会乱码。
escape的使⽤⽅法:https:///w3school/jsref/jsref_escape.htm英⽂解释:MSDN JScript Reference: The escape method returns a string value (in Unicode format) that contains the contents of [the argument]. All spaces, punctuation, accented characters, and any other non-ASCII characters are replaced with %xx encoding, where xx is equivalent to the hexadecimal number representing the character. For example, a space is returned as "%20."Edge Core Javascript Guide: The escape and unescape functions let you encode and decode strings. The escape function returns the hexadecimal encoding of an argument in the ISO Latin character set. The unescape function returns the ASCII string for the specified hexadecimal encoding value.encodeURI() ⽅法:把URI字符串采⽤UTF-8编码格式转化成escape格式的字符串。
js数字校验正则
js数字校验正则1、前言在前端开发中,经常需要校验输入框中输入的内容是否为数字类型。
而JavaScript中提供了正则表达式的使用,可以方便地对数字进行校验。
接下来,本文将结合实例详细介绍JavaScript数字校验正则表达式的使用。
2、JavaScript数字校验正则表达式常见的数字校验正则表达式有以下三种:2.1、整数类型校验整数类型可以使用以下正则表达式:```/^-?\d+$/```其中:- ^ 表示以数字开头- -? 表示可有可无的负号- \d+ 表示一个或多个数字- $ 表示以数字结尾使用示例:```javascriptconst reg = /^-?\d+$/;console.log(reg.test('-1234')); // true console.log(reg.test('1234')); // trueconsole.log(reg.test('0')); // trueconsole.log(reg.test('12a3')); // false ```2.2、浮点数类型校验浮点数类型可以使用以下正则表达式:```/^-?\d+\.?\d{0,}$/```其中:- ^ 表示以数字开头- -? 表示可有可无的负号- \d+ 表示一个或多个数字- \.? 表示小数点可有可无- \d{0,} 表示零个或多个数字- $ 表示以数字结尾使用示例:```javascriptconst reg = /^-?\d+\.?\d{0,}$/;console.log(reg.test('-1234.56')); // true console.log(reg.test('1234.56')); // trueconsole.log(reg.test('0')); // trueconsole.log(reg.test('12a3.56')); // false ```2.3、正数类型校验正数类型可以使用以下正则表达式:```/^\d+\.?\d{0,}$/```其中:- ^ 表示以数字开头- \d+ 表示一个或多个数字- \.? 表示小数点可有可无- \d{0,} 表示零个或多个数字- $ 表示以数字结尾使用示例:```javascriptconst reg = /^\d+\.?\d{0,}$/;console.log(reg.test('1234.56')); // trueconsole.log(reg.test('0')); // trueconsole.log(reg.test('-1234.56')); // false```3、总结本文通过讲解JavaScript数字校验正则表达式,介绍了三种常见的数字类型校验方法,并配有详细的使用示例。
使用JavaScript实现表单验证与数据校验
使用JavaScript实现表单验证与数据校验随着互联网的快速发展,网页表单在我们的日常生活中扮演着重要的角色。
无论是网上购物还是在线报名活动,我们都需要填写各种表单。
而为了确保数据的准确性和完整性,表单验证与数据校验就成为了必要的环节。
一、为什么需要表单验证与数据校验?表单验证和数据校验是防范恶意用户输入和保护服务器数据完整性的关键步骤。
对于表单来说,我们需要确保用户提交的数据格式正确,避免用户输入无效或不安全的数据。
而在数据校验方面,我们需要确保从服务器返回的数据没有被篡改,以保证用户获取到的是可靠的信息。
二、基本的表单验证类在JavaScript中,我们可以通过使用正则表达式或者内置的一些方法实现表单验证。
下面是一些常见的表单验证类:1. 空值验证:确保必填字段不为空,可以通过判断输入框是否为空或者使用正则表达式判断。
2. 字符长度验证:用于限制字符长度,可以通过使用length属性来判断输入的字符数是否在规定的区间内。
3. 数字验证:用于限制输入的内容是否为数字,可以使用isNaN方法判断。
4. 邮箱验证:用于验证邮箱格式是否正确,可以使用正则表达式判断。
5. 手机号码验证:用于验证手机号码格式是否正确,可以使用正则表达式判断。
三、实时验证与异步数据校验除了基本的表单验证,一些表单还需要实时验证和异步数据校验。
例如,当用户在输入框中输入内容时,我们可以实时检查输入的格式是否正确,给出相应的提示信息。
在提交表单时,我们还可以通过异步请求向服务器发送数据校验请求,确保返回的数据不被篡改。
对于实时验证,我们可以使用JavaScript中的事件监听器来实现,例如监听输入框的change事件或者keyup事件,然后根据用户输入的内容做出实时验证反馈。
而对于异步数据校验,我们可以使用Ajax技术向服务器发送请求,并在服务器端进行数据校验。
服务器返回校验结果后,我们可以根据结果给出相应的提示信息。
四、数据安全性与防御措施在进行表单验证与数据校验时,我们还需要考虑数据的安全性。
JavaScriptBASE64算法实现(完美解决中文乱码)
JavaScriptBASE64算法实现(完美解决中⽂乱码)JavaScript 的 BASE64 算法var BASE64={enKey: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',deKey: new Array(-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,-1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1),encode: function(src){//⽤⼀个数组来存放编码后的字符,效率⽐⽤字符串相加⾼很多。
var str=new Array();var ch1, ch2, ch3;var pos=0;//每三个字符进⾏编码。
while(pos+3<=src.length){ch1=src.charCodeAt(pos++);ch2=src.charCodeAt(pos++);ch3=src.charCodeAt(pos++);str.push(this.enKey.charAt(ch1>>2), this.enKey.charAt(((ch1<<4)+(ch2>>4))&0x3f));str.push(this.enKey.charAt(((ch2<<2)+(ch3>>6))&0x3f), this.enKey.charAt(ch3&0x3f));}//给剩下的字符进⾏编码。
JavaScript判断输入是否为数字类型的方法总结
JavaScript判断输⼊是否为数字类型的⽅法总结JavaScript判断输⼊是否为数字类型的⽅法总结前⾔很多时候需要判断⼀个输⼊是否位数字,下⾯简单列举集中⽅法。
第⼀种⽅法 isNaNisNaN 返回⼀个 Boolean 值,指明提供的值是否是保留值 NaN (不是数字)。
NaN 即 Not a Number isNaN(numValue)但是如果numValue果是⼀个空串或是⼀个空格,⽽isNaN是做为数字0进⾏处理的,⽽parseInt与parseFloat是返回⼀个错误消息,这个isNaN检查不严密⽽导致的。
第⼆种⽅法正则表达式function checkRate(input) { var re = /^[0-9]+.?[0-9]*/;//判断字符串是否为数字//判断正整数/[1−9]+[0−9]∗]∗/ if (!re.test(nubmer)) { alert(“请输⼊数字”); }}第三种⽅法利⽤parseFloat的返回值function isNotANumber(inputData) { //isNaN(inputData)不能判断空串或⼀个空格 //如果是⼀个空串或是⼀个空格,⽽isNaN是做为数字0进⾏处理的,⽽parseInt与parseFloat是返回⼀个错误消息,这个isNaN检查不严密⽽导致的。
if (parseFloat(inputData).toString() == “NaN”) { //alert(“请输⼊数字……”); return false; } else { return true; }}如有疑问请留⾔或者到本站社区交流讨论,感谢阅读,希望通过本⽂能帮助到⼤家,谢谢⼤家对本站的⽀持!。
js中文乱码
js中⽂乱码代码如下:$.ajax({ dataType : ‘json',type : ‘POST',url : ‘http://localhost/test/test.do',data : {id: 1, type: ‘商品'},success : function(data){ } } );问题: 提交后后台action程序时,取到的type是乱码解决⽅法: ⽅法⼀:提交前采⽤encodeURI两次编码,记住⼀定是两次 1.修改以下代码复制代码代码如下:data:{id:1, type:encodeURI(encodeURI(‘商品'))}2.在后台action⾥要对取得的字符串进⾏decode 1、String type = request.getParameter(“type”); 2、type = URLDecoder.decode(type, “UTF-8″); ⽅法⼆:ajax配置contentType属性,加上charset=UTF-8 在ajax⽅法中加⼊以下参数 contentType: “application/x-www-form-urlencoded; charset=UTF-8″使⽤其它js框架或者xhr都是差不多,设置header中contentType即可, 这⾥关键是charset=UTF-8,如果没有这个,是不⾏的,默认jQuery⾥的contentType是没有的⼀、测试环境 jQuery:1.3.2 tomcat:5.5.17 ⼆、测试⽅法 1.使⽤get⽅式服务器端java代码:复制代码代码如下:String name = new String(request.getParameter("name").getBytes("iso8859-1"),"utf-8");客户端js代码:复制代码代码如下:$.ajax({url: "2.jsp",type: "get",data: {name:"中⽂"},success: function(response){ alert(response); }});结果:正确显⽰复制代码代码如下:$.ajax({url: "2.jsp",type: "get",data: "name=中⽂",success: function(response){ alert(response); }});结果:乱码复制代码代码如下:$.get("2.jsp", { name: "中⽂" },function(response){ alert(response); });结果:正确显⽰复制代码代码如下:$.get("2.jsp", "name=中⽂",function(response){ alert(response); });结果:乱码2.post⽅式服务器端java代码:复制代码代码如下:request.setCharacterEncoding("UTF-8"); String name = request.getParameter("name");客户端js代码:复制代码代码如下:$.ajax({url: "3.jsp",type: "post",data: "method=testAjaxPost&name=中⽂",success: function(response){ alert(response); }});结果:正确显⽰复制代码代码如下:$.ajax({url: "3.jsp",type: "post",data: {name:"中⽂"},success: function(response){ alert(response); }});结果:正确显⽰复制代码代码如下:$.post("3.jsp", { name: "中⽂" },function(response){ alert(response); });结果:正确显⽰复制代码代码如下:$.post("3.jsp", "name=中⽂",function(response){ alert(response); });结果:正确显⽰三、使⽤filter复制代码代码如下:public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; if (req.getHeader("X-Requested-With") != null && req.getHeader("X-Requested-With").equalsIgnoreCase("XMLHttpRequest")) { request.setCharacterEncoding("utf-8"); } else { request.setCharacterEncoding("gbk"); } chain.doFilter(request, response); }jQuery在使⽤ajax的时候会在header中加⼊X-Requested-With,值为:XMLHttpRequest,filter中判断是jQuery的ajax请求时就把字符编码设为utf8,这样可以解决post提交中的中⽂乱码问题,不需要在代码中设置request.setCharacterEncoding("UTF-8"); 对于get⽅式的中⽂乱码问题,建议不使⽤get⽅式提交中⽂,统统改为post ^-^为了和prototype.js处理中⽂的⽅式⼀致,可以使⽤如下的⽅式,⾃定义header中的属性RequestType复制代码代码如下:$.ajax({ url: "3.jsp", type: "post", data: {name:"中⽂"}, beforeSend: function(XMLHttpRequest){XMLHttpRequest.setRequestHeader("RequestType", "ajax"); alert("开始"); }, success: function(data, textStatus){ alert(data); }, error: function(XMLHttpRequest, textStatus, errorThrown){ alert("错误:" + textStatus); }, complete: function(XMLHttpRequest, textStatus){alert("完成:" + textStatus); } });filter代码如下:复制代码代码如下:public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; if (req.getHeader("RequestType") != null &&req.getHeader("RequestType").equalsIgnoreCase("ajax"))) { request.setCharacterEncoding("utf-8"); } else {request.setCharacterEncoding("gbk"); } chain.doFilter(request, response); }。
JS传值中文乱码解决方案
JS传值中⽂乱码解决⽅案JS传值中⽂乱码解决⽅案⼀、相关知识1,Java相关类:(1).URLDecoder类 HTML格式解码的实⽤⼯具类,有⼀个静态⽅法:public static String decode(String 变量名,String 编码格式);给变量指定解码。
(2).URLEncoder类 HTML格式编码的实⽤⼯具类,有⼀个静态⽅法:public static String encode(String 变量名,String 编码格式);给变量指定编码。
2,JavaScript的编码函数: encodeURI(String URIstring):把字符串作为 URI 进⾏编码。
⼆、解决JS传值中⽂乱码1,问题: js在url中传值,前台和后台编码不⼀致,导致中⽂乱码;2,解决⽅案:(1)⽅案⼀:前台:js代码使⽤encodeURI()函数:url = encodeURI(url);注意:这⾥是整个URL地址,也可以是具体乱码变量。
后台:java代码String linename = new String(request.getParameter("name").getBytes("ISO-8859-1"),"UTF-8");(2)⽅案⼆:前台:jsp代码对url使⽤两次encodeURI()函数:url=encodeURI(encodeURI(url));//⽤了2次encodeURI后台:java代码使⽤.URLDecoder.decode(String 变量,String 编码);对指定变量解码三、⽰例前台:var yhdh = encodeURI(yhdh);top.Dialog.open({URL : "user.do?ywtype=loadXq&type=update&user.yhdh=" +encodeURI(yhdh), //两次使⽤encodeURI()函数(这是js函数)后台:try {String searchtext =.URLDecoder.decode(userForm.getUser().getYhdh(),"UTF-8"); //进⾏解码,会抛异常,直接捕获即可。
JS传值出现中文参数乱码的解决方法
JS传值出现中⽂参数乱码的解决⽅法本⽂实例讲述了JS传值出现中⽂参数乱码的解决⽅法。
分享给⼤家供⼤家参考,具体如下:function PopupFK(cNum,type){var url = "contract!Paying.action";url = url + "?contract.contractNum="+cNum+"&payingType="+type;// if(isEmpty($(_this).attr("payId"))){// url = url + "&s_paymentId="+paymentId;// url = url + "&s_paymentDtlId="+paymentDtlId;// }else{// url = url + "&s_payId="+$(_this).attr("payId");// }url = url+"&random="+Math.random();//在这⾥。
⽤encodeURI进⾏两次转码。
后台Action接收的时候。
在进⾏⼀次。
就不会出现乱码问题url = encodeURI(url);url = encodeURI(url); var ret = window.showModalDialog(url,"","dialogWidth=950px;dialogHeight=600px;center=yes;border=thick;status=no;help=no;scrollbars=no");}下⾯是Action代码⽚段String cNum = contract.getContractNum();String Num;try {Num = URLDecoder.decode(cNum,"utf8");System.out.println(Num);c = csl.queryOneByNum(Num);} catch (UnsupportedEncodingException e) {throw new RuntimeException("合同数据错误,请联系管理员");}更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家JavaScript程序设计有所帮助。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
两个日期比较
/*
用途:检查开始日期是否小于等于结束日期
输入:
s:字符串 开始日期 格式:2001-5-4
e:字符串 结束日期 格式:2002-5-4
返回:
如果通过开始日期小于等于结束日期返回true,否则返回false
*/
function data_compare(s,e)
更多 是否为身份证号码 信息
是否为邮政编码
/*
用途:检查输入字符串是否符合邮政编码格式
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isZipcode(str)
{
var reg = /^\d+$/;
返回:如果通过验证返回true,否则返回false
*/
function isPort(str) {
return (isNumber(str) && str < 65536);
}
更多 是否为端口号 信息
是否为身份证号码
/*
用途:检查输入字符串是否符合身份证格式
返回:如果通过验证返回true,否则返回false
*/
function isFirstMatch(str1, str2) {
var index = str1.indexOf(str2);
if (index == 0) return true;
return false;
}
更多 字符1以字符串2开始 信息
return false;
} ....
更多 是否为时间 信息
是否为正整数
/*
用途:检查输入字符串是否符合正整数格式
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isNumber(s) {
var regu = "^[0-9]+$";
/*
用途:校验ip地址的格式
输入:strIP:ip地址
返回:如果通过验证返回true,否则返回false;
*/
function isIP(strIP) {
if (isNull(strIP)) return false;
var re = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式
var regu = /^[1][0-9][0-9]{9}$/;
var re = new RegExp(regu);
if (re.test(s)) ....
更多 是否为手机号码 信息
是否为数字
/*
用途:检查输入字符串是否是数字
输入:
str:字符串
返回:
如果通过验证返回true,否则返回false
更多 英文数字组成 信息
var d= new Date(r[1], r[3]-1, r[5]);
...
更多 判断是否是日期 信息
字母数字下划线
/*
用途:检查输入字符串是否只由英文字母和数字和下划线组成
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isNumberOr_Letter(s) {//判断是否是数字或字母
*/
function isNull(str) {
if (str == "") return true;
var regu = "^[ ]+$";
.....
更多 为空或全是空格 信息
判断是否是日期
/*
用途:判断是否是日期
输入:date:日期;匹配的格式: 2010-5-16
if (re.test(strIP)) {
if (RegExp.$1
更多 校验ip地址 信息
汉字字母数字
/*
用途:检查输入字符串是否只由汉字、字母、数字组成
输入:
value:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isChinaOrNumbOrLett(s) {//判断是否是汉字、字母、数字组成
var re = new RegExp(regu);
if (s.search(re) != -1) ...
更多 是否为正整数 信息
是否为电话号码
/*
用途:检查输入字符串是否符合国内固话或者传真格式
输入:
s:字符串 格式例如:020-87110252
返回:
如果通过验证返回true,否则返回false
*/
function isTel(s){
var reg=/^((0\d{2,3})-)?(\d{7,8})(-(\d{3,}))?$/;
if(!reg.test(s))...
更多 是否为电话号码 信息
是否为端口号
/*
用途:检查输入对象的值是否符合端口号格式
输入:str 输入的字符串
if (myReg.test(str)) return true;
return false;
}
更多 是否为email 信息
是否为手机号码
/*
用途:检查输入手机号码是否正确
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function checkMobile(s) {
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isIDno(strIDno)
{
var aCity={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江....
if (str1.length == index + str2.length) return true;
return false;
}
更多 字符1以字符串2结束 信息
字符1包含字符串2
/*
用途:字符1是包含字符串2
输入:str1:字符串;str2:被包含的字符串
返回:如果通过验证返回true,否则返回false
var regu = "^[0-9a-zA-Z\_]+$";
var re = new RegExp(regu);
if (re.test(s))...
更多 字母数字下划线 信息
字符1以字符串2开始
/*
用途:字符1是否以字符串2开始
输入:str1:字符串;str2:被包含的字符串
返回:如果通过验证返回true,否则返回false
*/
function isDate(str){
if (isNull(str)) return false;
var r = str.match(/^(\d{4})(-|\/)(\d{1,2})(-|\/)(\d{1,2})$/);
if(r==null)return false;
{
var arr=s.split("-");
var starttime=new Date(arr[0],arr[1],arr[2]);...
更多 两个日期比较 信息
为空或全是空格
/*
用途:检查输入字符串是否为空或者全部都是空格
输入:str
返回:
如果全是空返回true,否则返回false
输入:str 输入的字符串
返回:如果通过验证返回true,否则返回false
*/
function isInteger(str) {
var regu = /^[-]{0,1}[0-9]{1,}$/;
return regu.test(str);
}
更多 是否是整数 信息
校验ip地址
如果通过验证返回true,否则返回false
*/
function isZh(str){
var reg = /^[\u4e00-\u9fa5]+$/;
if (reg.test(str)) ...
更多 是否只为汉字 信息
是否是整数
/*
用途:检查输入对象的值是否符合整数格式
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
function isNumberOrLetter(s) {//判断是否是数字或字母
var regu = "^[0-9a-zA-Z]+$";
var re = new RegExp(regu);
if (re.test(s))...
*/
function isNumber(str)
{
var reg = /^\d+$/;
if (reg.test(str))...