atitit.数据验证--db数据库数据验证约束

1. 为了加强账户数据金额的安全性,需要增加验证字段。。1

2. 创建帐户1

3. 更改账户2

4. ---code3

5. --fini4

1. 为了加强账户数据金额的安全性,需要增加验证字段。。

调用::

在创建,更改金额的时候,都要更改前验证。。。

更改金额的时候,还要严重数据库里面的数据准确性

更改时的加密数据从哪里来,直接从校验器来就是了。。

new SqlCheckor().getValideVal(new_money);

作者::  ★(attilax)>>>   绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://www.cnblogs.com/attilax/

2. 创建帐户

public void createAcc(String uname, double d) {

BigDecimal money=new BigDecimal(d);

String v_vali=new SqlCheckor().getValideVal(money);

String   $sql = "insert into   ecs_users( "+

"   user_name,user_money,vali_val )values('@u@',  "+String.valueOf(d)+"" +

",'$vali$' )";

$sql= $sql.replace("@u@", uname).replace("$vali$", v_vali);

System.out.println("---"+  $sql);

sqlCkSrv.valideValCheck4newRow(money, v_vali);

int r=dbx.execSql_retInt($sql);

System.out.println("----ret int:"+String.valueOf(r));

3. 更改账户

public int addAmount(String uid, BigDecimal i) {

iniAcc(uid);

String sql = strUtil.fmt( "select * from ecs_users where user_name='$uid$'",uid);

Map row=dbx.uniqueResult2row(sql);

if(row==null)

throw new CantFindAcc("uid="+uid);

BigDecimal now=(BigDecimal) row.get("user_money");

//SqlCheckor sqlCkSrv=

if(row.get("vali_val")!=null)   //for compati  olddata no vali

sqlCkSrv.valideValCheck4oldrow(row.get("user_money"),row.get("vali_val").toString() );

BigDecimal  new_money=now.add(i);

String new_money_valinew SqlCheckor().getValideVal(new_money);

new SqlCheckor().valideValCheck4newRow(new_money, new_money_vali);

//DataLogicSales

// TODO Auto-generated method stub

/* 更新用户信息 */

String sql2 = "UPDATE   ecs_users "+

" SET user_money =$newMoney$,vali_val='$vali$'"+

" WHERE user_name = '"+uid+"' LIMIT 1";

String   $sql = sql2.replace("$newMoney$", new_money.toString()).replace("$vali$",new_money_vali);

System.out.println("---"+  $sql);

int r=dbx.execSql_retInt($sql);

if(r!=1)

throw new AccEx(" acc ex ret is:"+String.valueOf(r) +" uid:"+uid);

System.out.println("----ret int:"+String.valueOf(r));

return r;

}

}

4. ---code

public void valideValCheck4oldrowString sql,String col,String valide_col) {

//Map row=sqlSrv.executeQueryFirstRow(sql);

//String v=(String) row.get(col);

//String valid=(String) row.get(valide_col);

//if(! AesV2q421.encrypt(v, "ilovmole").equals(valid))

//

//throw new ValidValCheckEx("sql:"+sql);

}

public void valideValCheck4newRow(Object val,String valEncoded) {

if(! AesV2q421.encrypt(val.toString(), "ilovmole").equals(valEncoded))

throw new ValidValCheckEx("val.encode:"+val+"-"+valEncoded);

}

public String getValideVal(Object v)

{

return AesV2q421.encrypt(v.toString(), "ilovmole");

}

/**should str2 dec compare..cant dec2str comapre..cause to db and from db ,then num point maybe changte...but true val is not change..

attilax    2016年4月25日  下午10:24:55

* @param object

* @param object2

*/

public void valideValCheck4oldrow(Object val, String valEncoded) {

//8CBAC0UjkdSjLBFwKNB2iA==

BigDecimal money=new BigDecimal(  AesV2q421.decrypt(valEncoded, "ilovmole"));

if(money.compareTo(   (BigDecimal) val)!=0)

throw new ValidValCheckEx("val.encode:"+val+"-"+valEncoded);

5. --fini

}

atitit.数据验证--db数据库数据验证约束的更多相关文章

  1. 通过读取excel数据和mysql数据库数据做对比(二)-代码编写测试

    通过上一步,环境已搭建好了. 下面开始实战, 首先,编写链接mysql的函数conn_sql.py import pymysql def sql_conn(u,pwd,h,db): conn=pymy ...

  2. java 对excel操作 读取、写入、修改数据;导出数据库数据到excel

    ============前提加入jar包jxl.jar========================= // 从数据库导出数据到excel public List<Xskh> outPu ...

  3. 通过读取excel数据和mysql数据库数据做对比(一)-win环境准备

    要想操作excel和mysql首先需要安装python,然后是安装excel和mysql插件: 第一步安装python: 直接百度搜索,下载安装就可以了. 第二步安装excel插件: 首先到这个htt ...

  4. C#在listview控件中显示数据库数据

    一.了解listview控件的属性 view:设置为details columns:设置列 items:设置行 1.将listview的view设置为details 2.设置列属性 点击添加,添加一列 ...

  5. ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动

    一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...

  6. 01- ajax, 登录验证,json数据,文件上传

    1.ajax简介 1.向服务器发送请求的途径 # 向服务器发送请求的途径 1. 浏览器地址栏,默认get请求 2. form表单: get请求 post请求 3. a标签,默认get请求 4. Aja ...

  7. Oracle 数据库表中已有重复数据添加唯一键(唯一约束)

    Oracle 数据库表中已有重复数据添加唯一键(唯一约束) 问题描述 以 demo 举例,模拟真实场景. 表 TEST_TABLE 有如下字段和数据:id 是主键,code 没有设置键和索引 ID C ...

  8. 第十节:数据批注(DataAnnotationModel)和自定义验证(包括Model级别的验证)

    一. 简介 写完上一个章节MVC中的常用特性,迫不及待将该系列补全,该章节主要介绍数据批注(也叫:注解). 一听[数据批注],好高大上的名字,但仔细一看,它们其实是[System.ComponentM ...

  9. 我这么玩Web Api(二):数据验证,全局数据验证与单元测试

    目录 一.模型状态 - ModelState 二.数据注解 - Data Annotations 三.自定义数据注解 四.全局数据验证 五.单元测试   一.模型状态 - ModelState 我理解 ...

随机推荐

  1. 利用Solr服务建立的站内搜索雏形---solr1

    最近看完nutch后总感觉像好好捯饬下solr,上次看到老大给我展现了下站内搜索我便久久不能忘怀.总觉着之前搭建的nutch配上solr还是有点呆板,在nutch爬取的时候就建立索引到solr服务下, ...

  2. 推荐20个很有帮助的 Web 前端开发教程

    在平常的搜索中,我碰到过很多有趣的信息,应用程序和文档,我把它们整理在下面这个列表.这是收藏的遇到的有用内容的一个伟大的方式,可以在你需要的时候方便查阅.相信你会在这个列表中发现对你很有用的资料. 您 ...

  3. Javascript内存泄露

    在过去一些的时候,Web开发人员并没有太多的去关注内存泄露问题.那时的页面间联系大都比较简单,并主要使用不同的连接地址在同一个站点中导航,这样的设计方式是非常有利于浏览器释放资源的.即使Web页面运行 ...

  4. javaccript学习3

    JavaScript - 捕获错误 当我们在网上冲浪时,总会看到带有 runtime 错误的 Javascript 警告框,同时会询问我们“是否进行 debug?”.像这样的错误信息或许对开发人员有用 ...

  5. 谷歌插件Image downloader开发之 content script

    自己运营了一个公众号,在发文章的时候,需要在网上找一些图,而有些网站的图片可能隐藏在属性或者背景图中,要下载的时候经常审查元素,查看源码,不太方便,最近在看一些谷歌插件的api,便顺手做了一个插件Im ...

  6. SQL Server存储(6/8) :理解DCM页

    我们已经讨论了各种不同的页,包括数据页.GAM与SGAM页.PFS页,还有IAM页.今天我们来看下差异变更页(Differential Change Map:DCM ),还有差异备份(differen ...

  7. SQL Server获取下一个编码字符实现继续重构与增强

        我在SQL Server获取下一个编码字符实现的博文中,虽然实现了这个问题,但是感觉维护起来比较麻烦,例如如果调整编码字符串的固定长度,就需要变更三个函数,这样的为何成本确实比较大.面向对象编 ...

  8. 浅谈图片蒙版效果-webkit-mask

    会用PS的童鞋一定知道“蒙版”的概念,它可以在图片上实现一定的遮罩效果,当然这里我们不介绍ps里的蒙版,而是介绍利用CSS3的新属性-webkit-mask来实现网页中的图片遮罩效果. 大家对-web ...

  9. Android SDK Manager国内更新代理

    在Android SDK Manager Setting 窗口设置HTTP Proxy server和HTTP Proxy Port这个2个参数,分别设置为: HTTP Proxy server:mi ...

  10. Java中不同转换符实现不同数据类型到字符串的转换

    String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprintf()方法,两者有类似之处.format()方法有两种重载形式. form ...