mysql 怎样限制输入字符_input怎么限制用户输入一些字符

思路

动态获取当前输入的字符,判断是否符合要求,如果不符合,就用旧的正确值填充(这个旧的正确值,是你在正确的时候保存的)

难点就是动态获取当前输入的字符

下面是实现方法

get_focus_position:function(input){

var position=0;

if(typeof input.selectionStart=="undefined"){

input.focus();

var sel=document.selection.createRange();

sel.moveStart("character",-input.value.length);

position=sel.text.length;

}else{

position=input.selectionStart;

}

/*

对于chrome来说,如果输入的时候用的是输入法,那么获取的一直是零,这是就取value的长度

*/

return position==0?input.value.length:position;

}

limit_input:function(elem,opt){

elem.setAttribute("history_value",elem.value);

utils.bindInput(elem,function(event){

var value=elem.value,isOk=true;

if(typeof opt.length!="undefined"){

if(elem.value.length>opt.length){

isOk=false;

opt.error&&opt.error("length");

}

}

if(typeof opt.char!="undefined"){

var position=utils.get_focus_position(elem);

var newValue=value.charAt(position-1);

if(opt.char(newValue)){//不能输入的元素

isOk=false;

opt.error&&opt.error("char");

}

}

if(isOk){

elem.setAttribute("history_value",elem.value);

opt.success&&opt.success(value,position,newValue);

}else{

elem.value=elem.getAttribute("history_value");

}

});

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中验证输入字符串长度是否超过MySQL的text字段长度可以通过查询MySQL数据库元数据来获取text字段的长度,然后再进行比较。以下是一个简单的示例代码: ```java import java.sql.*; public class Main { public static void main(String[] args) { String input = "这是一个超过MySQL text字段长度的字符串,用于测试。"; String columnName = "text_column"; // 数据库表中的text字段名称 int maxLength = getMaxLength(columnName); // 获取text字段的最大长度 if (input.length() > maxLength) { System.out.println("输入字符串长度超过了MySQL text字段的最大长度。"); } else { System.out.println("输入字符串长度没有超过MySQL text字段的最大长度。"); } } private static int getMaxLength(String columnName) { int maxLength = 0; try { Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT CHARACTER_MAXIMUM_LENGTH FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'my_table' AND COLUMN_NAME = '" + columnName + "'"); if (rs.next()) { maxLength = rs.getInt("CHARACTER_MAXIMUM_LENGTH"); } rs.close(); stmt.close(); conn.close(); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } return maxLength; } } ``` 注意:该示例代码仅供参考,实际应用需要根据具体情况进行修改和优化。同时,为了安全起见,建议使用预处理语句和参数化查询来避免SQL注入攻击。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值