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. Oracle数据库常见的误操作恢复方法(上)

    实验环境:Linux6.4 + Oracle 11g 面向读者:Oracle开发维护人员 概要: 1.误操作drop了emp表 2.误操作delete了emp表 3.误操作delete了emp表的部分 ...

  2. java实现将汉字转为拼音

    有时候为了方便操作程序的开发,需要将汉字转为拼音等操作.下面这个是自己结合网上的资料,加上自己在公司项目中的亲自实践.完整的实现了将汉字转为拼音的操作.这个Demo只是负责将其转换,在main方法中测 ...

  3. 如何禁用事件的浮升(div的子元素的点击事件会触发父元素的点击事件)

    <div onclick="alert();"> <div onclick="alert();"></div> </d ...

  4. ASP.NET MVC必知必会知识点总结(一)

    一.URL Routing 1.添加URL路由映射的一般方法(在RegisterRoutes方法中添加): //第一种(建议采用这种): routes.MapRoute( "MyRoute& ...

  5. linux的计划

    我接触linux也有好几年了,至少有5年了.最近公司在搞内部培训,人人都可以报名培训别人.想到自己在linux浸淫多年,应该出来出一份力.一直以来想就linux写一个专题.今天刚好在做相关的ppt,借 ...

  6. C#使用Process调用批处理阻塞问题

    PS:又见到熟悉的C#代码了,好开心,哈哈哈.这次又跳坑了,好不容易才爬起来.   公司有自己开发的一套Submit.Compile.Publish的生命周期系统. 在Compile时,需要调用外部的 ...

  7. ajax携带状态值

  8. 使用PackageManager获得应用(包)信息

    PackageManager是Android中一个很有用的类,能够获取已安装的应用(包)的信息,如应用名称.图标.权限,安装.删除应用(包)等. 以下代码可以获得已安装应用(包)的信息: // 包管理 ...

  9. Eclipse上GIT插件EGIT使用手册

    http://blog.csdn.net/luckarecs/article/details/7427605 Eclipse上GIT插件EGIT使用手册   一_安装EGIT插件 http://dow ...

  10. NYOJ 746---整数划分(四)(区间DP)

    题目链接 描述 暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近遇到了一个难题,让他百思不得其解,他非常郁闷..亲爱的你能帮帮他吗? 问题是我们经 ...